### **Reconfigurable Computing** for System on a Chip

Hiroto Yasuura Kazuaki Murakami System LSI Research Center (SLRC) Kyushu University E-mail: yasuura@slrc.kyushu-u.ac.jp

#### Outline

#### Background and Requirements

- Platforms for Reconfigurable Computing
  - DRP
  - DAP/DNA
- How to use Reconfigurable Computing in SoC
  - SysteMorph
- Conclusion

# Why Reconfigurable?

- Cost of Production
  - Drastic increase of design and mask cost is requesting new system architectures, especially for small scale production less than 1M.
- Customer Satisfaction
  - Various kinds of customers, each of which has different requirement and knowledge. A customized system for each user is attractive.
- Market Oriented SoC Design
  - The direction of the market changes quickly and various new services are introduced.
- Reliability and Security
  - Repairs and debugging on customer site.
  - Changing system configuration for security. (cryptography etc.)
- Global Environment Problem
  - Grow out of the throwaway society.
- Views of System Designers and Users

H. Yasuura, Kyushu Univ.

## **Example: Mobile Phone**

- New Services
  - I-mode (Internet Access: e-mail and WWW)
  - Built-in Digital Still Camera
  - Video Phone Service (MPEG-4 in NTT Foma)
  - Melody Calling
  - Music Down Load Service(MP3)
  - Electric Ticketing
  - Electric Money for Vending Machines
  - Simple Interface for Old People
  - Car Navigation Service
- Needs for a new system architecture solution
  - Reconfigurable computing is a possible solution.

# System Level Optimization

- What
  - Parameters for optimization
  - Goals of optimization QoS (Function, Performance, Energy, Reliability, Security,…)
- When
  - Design Stage, Compilation Stage, and Runtime
- Who
  - Designers, Service Providers, and also Users
- How
  - Reconfigurable Hardware Platforms
  - Software
  - Profiling and Design Optimization Techniques

H. Yasuura, Kyushu Univ.



#### **Runtime Reconfiguration**

- Dynamic: Optimization is performed…
  - After SoC is shipped to the market
  - While SoC is used in the field
- Online: Profiling and optimization are performed…
  - In parallel with the execution of application programs
  - During idle or sleeping time
- Adaptive: Optimization is repeated…
  - In the form of a feedback loop



H. Yasuura, Kyushu Univ.

#### When reconfiguration is done?



A system is not always active. Reconfiguration can be done in idle and sleep time.

H. Yasuura, Kyushu Univ.

#### A Possible Business Model: OSP (Optimization Service Provider)



#### Customizable Mobile Phone Your phone is evolving every battery charging!



H. Yasuura, Kyushu Univ.

# Reconfigurable Computing for System on a Chip

- Background and Requirements
- Platforms for Reconfigurable Computing
  - DRP
  - DAP/DNA
- How to use Reconfigurable Computing in SoC
  - SysteMorph
- Conclusion

#### Platforms for Reconfigurable Computing

#### Dynamically Reconfigurable Processor: DRP by NEC

#### DAP/DNA by IP Flex

#### Dynamically Reconfigurable Circuits by Sony

#### Platforms for Reconfigurable Computing

#### Granularity of Reconfiguration

- A Processor and Software
- An Processor Array
- Processing Elements
  - ALU, Multipliers, etc.
- Logic Gates (FPGA)
- Timing of Reconfiguration
  - Every Clock Cycle
  - Every Task Execution
  - Every Power-on

#### Dynamically Reconfigurable Processor:DRP



PE of DRP



16 instructions can be stored in the instruction memory of each PE.
An instruction specifies connections and operation of each processor.
The STC specifies the

address of instruction.

By NEC

H. Yasuura, Kyushu Univ.

### Dynamic Reconfiguration of DRP



The connection among PEs and operations of PEs can be changed in every clock cycle.

By NEC

H. Yasuura, Kyushu Univ.



# Features of DAP/DNA

DAP/DNA reconfigurable processor has the advanced features, including:

- •The DNA-Matrix architecture with dynamically reconfigurable hardware.
- •Reconfiguration of the DNA-Matrix in one clock.
- •Parallel data processing, not sequential data processing (Neumann Cycle), and extremely high performance with low power consumption due to the low clock frequency.
- •1-2 digits higher performance compared to existing solutions such as the CPUs and DSPs.
- •Dramatic reduction of the development cost and period compared to ASIC and fully custom devices.
- •Hardware design with software method (C language) enables flexible the design changes.
- 600MTr. 225m<sup>2</sup>

http://www.ipflex.com/english/product/dapdna\_feature.html ra. Kyushu Uniy. MPSOC'03

19



#### **DNA(Distributed Network Architecture)**



#### By IP Flex

DNA (Distributed Network Architecture) Matrix Architecture The DNA-Matrix is a dataflow type accelerator arrayed 148 dynamic reconfigurable operation units. The wiring among elements can be changed dynamically and can quickly constitute parallel/pipeline processing system according to each application operation unit processing. The DNA-Matrix internal constituent information is stored in configuration memory, and its constitution changes in one clock depending on applications.

- •148 of 32bit Operation Units
- •Data transfer between elements at single cycle

•Operating Frequency 100MHz

H. Yasuura, Kyushu Univ.

# Reconfigurable Computing for System on a Chip

- Background and Requirements
- Platforms for Reconfigurable Computing
  - DRP
  - DAP/DNA
- How to use Reconfigurable Computing in SoC
  - SysteMorph
- Conclusion

# SysteMorph K. Murakami (SLRC, Kyushu Univ.)

- Silicon Sea-Belt Project
- Just-in-Time (Dynamic, Online & Adaptive) HW/ISA/SW Co-optimization Technology
- Applications:
  - High Performance Computing
    - Molecular Orbit Computation (Chemistry)
    - Reducing Cost and Energy
  - Mobile Devices
    - Mobile phones
    - Sensor networking
    - Reducing Energy and Increase Service Quality

H. Yasuura, Kyushu Univ.

# Design Issues in SysteMorph

- What to profile
- How to profile them
- How to discover hints for optimization
- What to optimize
- How to optimize them
- How to reconfigure HW/ISA/SW

# Functionality Morphing: An Example of SysteMorph

- Design issues in SysteMorph
  - What to profile
  - How to profile them
  - How to discover hints for optimization
  - What to optimize
  - How to optimize them
  - How to reconfigure HW/ISA/SW

- Solutions in functionality morphing
  - Online hot-path profiling
    - Offload the functionality of hot-paths from SW to HW
    - Online HW resynthesis
  - Reconfigurable coprocessor
  - Dynamic binary rewriting

By K. Murakami

#### **Functionality Morphing** - Offload Hot Program Path to HW -Application programs are under Application programs are running... optimization... (3) Transform the (1) Monitor function of the (2) Detect and program path hot path into a predict hot (5) Replace the hot logic function program path path with a coprocessor call Target Target SvsteMorph SysteMorph Software Programs Software **Programs Instruction** ISA Instruction Execution Execution **Profiler Profiler** Processor Processor Reconfigurable Reconfigura Core Core Fabric Fabric SmartHardware (4) Reconfigure the hardware of a reconfigurable coprocessor (RCP By K. Murakami H. Yasuura, Kyushu Univ. MPSOC'03 25

## Offline vs. Online Profiling



## Online Hot-Path Profiling - Algorithm -

Program Path



Path: signature ABDG: A.0101 ABDGJ: A.01001 ABDHJ: A.01111 ACEIJ: A.10111 ACFIJ: A.11111

- Existing Algorithms
  - Efficient path profiling
  - NET prediction

H. Yasuura, Kyushu Univ.

Our Algorithm

- Profile the history of branch instruction' s behaviors (taken or not-taken, branch target)
- If the execution frequency at a path head exceeds the threshold, select the path head ("A" in the figure) as a candidate of the hot path head
- Traverse the object code, starting with the candidate ( "A" ), based on the branch history, and predict the hot path

By K. Murakami



H. Yasuura, Kyushu Univ.

# Offline vs. Online HW Synthesis



# Reconfigurable Computing for System on a Chip

- Background and Requirements
- Platforms for Reconfigurable Computing
  - DRP
  - DAP/DNA
- How to use Reconfigurable Computing in SoC
  - SysteMorph
- Conclusion

# **Reconfigurable Computing**

- Several platforms are ready to use. System architectures and application techniques for SoC are key issues.
  - Cost Reduction
    - Reduce design, mask, and test costs.
    - Reuse an SoC device into different consumer products.
  - Customer Satisfaction
    - Optimize devices for multiple applications and varieties of usage.
  - Speed-up of Business
    - Introduce new services without change of devices.
  - Reliability and Security
    - Repairs and debugging on customer site.
    - Frequent update of security procedures.
  - Environment and Ecology
    - Reuse devices in revised services.
    - Minimization of energy consumption for each user.

#### Thank you for your attention.

