1 Operating Systems for Reconfigurable Computing Systems Xuequn(Robin) Li Instructor: Prof. Shawki Areibi School of Engineering School of Engineering.

Slides:



Advertisements
Similar presentations
CSE 413: Computer Networks
Advertisements

Network II.5 simulator ..
University of South Australia Distributed Reconfiguration Avishek Chakraborty, David Kearney, Mark Jasiunas.
Implementation Approaches with FPGAs Compile-time reconfiguration (CTR) CTR is a static implementation strategy where each application consists of one.
Memory Management Chapter 7.
CMPT 300: Final Review Chapters 8 – Memory Management: Ch. 8, 9 Address spaces Logical (virtual): generated by the CPU Physical: seen by the memory.
Dr Mohamed Menacer College of Computer Science and Engineering Taibah University CS-334: Computer.
CS 104 Introduction to Computer Science and Graphics Problems
Context Switch in Reconfigurable System Sun, Yuan-Ling ESL of CSIE, CCU
CMPT 300: Final Review Chapters 8 – Memory Management: Ch. 8, 9 Address spaces Logical (virtual): generated by the CPU Physical: seen by the memory.
Chapter 9 Virtual Memory Produced by Lemlem Kebede Monday, July 16, 2001.
Chapter 11 Operating Systems
MEMORY MANAGEMENT By KUNAL KADAKIA RISHIT SHAH. Memory Memory is a large array of words or bytes, each with its own address. It is a repository of quickly.
Computer Organization and Architecture
Lecture 9: SHELL PROGRAMMING (continued) Creating shell scripts!
Operating System Concepts
Silberschatz, Galvin and Gagne  Operating System Concepts Multistep Processing of a User Program User programs go through several steps before.
03/05/2008CSCI 315 Operating Systems Design1 Memory Management Notice: The slides for this lecture have been largely based on those accompanying the textbook.
CS364 CH08 Operating System Support TECH Computer Science Operating System Overview Scheduling Memory Management Pentium II and PowerPC Memory Management.
Layers and Views of a Computer System Operating System Services Program creation Program execution Access to I/O devices Controlled access to files System.
Memory Management ◦ Operating Systems ◦ CS550. Paging and Segmentation  Non-contiguous memory allocation  Fragmentation is a serious problem with contiguous.
Reconfigurable Hardware in Wearable Computing Nodes Christian Plessl 1 Rolf Enzler 2 Herbert Walder 1 Jan Beutel 1 Marco Platzner 1 Lothar Thiele 1 1 Computer.
Chapter 3 Memory Management: Virtual Memory
Review of Memory Management, Virtual Memory CS448.
Swapping and Contiguous Memory Allocation. Multistep Processing of a User Program User programs go through several steps before being run. Program components.
Memory Management Chapter 7.
MEMORY MANAGEMENT Presented By:- Lect. Puneet Gupta G.P.C.G. Patiala.
Operating Systems for Reconfigurable Systems John Huisman ID:
Chapter 5 Operating System Support. Outline Operating system - Objective and function - types of OS Scheduling - Long term scheduling - Medium term scheduling.
1 © 2003, Cisco Systems, Inc. All rights reserved. CCNA 2 Module 9 Basic Router Troubleshooting.
Cosc 2150: Computer Organization Chapter 6, Part 2 Virtual Memory.
Chapter 4 Storage Management (Memory Management).
CIS250 OPERATING SYSTEMS Memory Management Since we share memory, we need to manage it Memory manager only sees the address A program counter value indicates.
Hardware Implementation of a Memetic Algorithm for VLSI Circuit Layout Stephen Coe MSc Engineering Candidate Advisors: Dr. Shawki Areibi Dr. Medhat Moussa.
Memory Management 1 Tanenbaum Ch. 3 Silberschatz Ch. 8,9.
By Teacher Asma Aleisa Year 1433 H.   Goals of memory management  To provide a convenient abstraction for programming  To allocate scarce memory resources.
Hardware process When the computer is powered up, it begins to execute fetch-execute cycle for the program that is stored in memory at the boot strap entry.
Operating Systems David Goldschmidt, Ph.D. Computer Science The College of Saint Rose CIS 432.
Memory. Chapter 8: Memory Management Background Swapping Contiguous Memory Allocation Paging Structure of the Page Table Segmentation.
1 Memory Management Chapter 7. 2 Memory Management Subdividing memory to accommodate multiple processes Memory needs to be allocated to ensure a reasonable.
By Teacher Asma Aleisa Year 1433 H.   Goals of memory management  To provide a convenient abstraction for programming.  To allocate scarce memory.
Task Graph Scheduling for RTR Paper Review By Gregor Scott.
Operating System Principles And Multitasking
Memory Management Operating Systems CS550. Memory Manager Memory manager - manages allocation and de-allocation of main memory Plays significant impact.
1 Memory Management Chapter 7. 2 Memory Management Subdividing memory to accommodate multiple processes Memory needs to be allocated to ensure a reasonable.
Main Memory. Chapter 8: Memory Management Background Swapping Contiguous Memory Allocation Paging Structure of the Page Table Segmentation Example: The.
Virtual Memory The memory space of a process is normally divided into blocks that are either pages or segments. Virtual memory management takes.
We will focus on operating system concepts What does it do? How is it implemented? Apply to Windows, Linux, Unix, Solaris, Mac OS X. Will discuss differences.
1 Computer Systems II Introduction to Processes. 2 First Two Major Computer System Evolution Steps Led to the idea of multiprogramming (multiple concurrent.
Basic Memory Management 1. Readings r Silbershatz et al: chapters
Concurrency, Processes, and System calls Benefits and issues of concurrency The basic concept of process System calls.
Hardware process When the computer is powered up, it begins to execute fetch-execute cycle for the program that is stored in memory at the boot strap entry.
© imec 2003 Designing an Operating System for a Heterogeneous Reconfigurable SoC Vincent Nollet, P. Coene, D. Verkest, S. Vernalde, R. Lauwereins IMEC,
1 Process Description and Control Chapter 3. 2 Process A program in execution An instance of a program running on a computer The entity that can be assigned.
Memory Management Program must be brought (from disk) into memory and placed within a process for it to be run Main memory and registers are only storage.
Operating Systems: Summary INF1060: Introduction to Operating Systems and Data Communication.
Embedded Real-Time Systems Processing interrupts Lecturer Department University.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 8: Main Memory.
Computer Architecture Chapter (8): Operating System Support
Lesson Objectives Aims Key Words Paging, Segmentation, Virtual Memory
Chapter 2 Memory and process management
Understanding Operating Systems Seventh Edition
William Stallings Computer Organization and Architecture
Introduction to Operating System (OS)
Chapter 8: Main Memory.
Multistep Processing of a User Program
Chapter 8: Memory management
Outline Module 1 and 2 dealt with processes, scheduling and synchronization Next two modules will deal with memory and storage Processes require data to.
Lecture 3: Main Memory.
Presentation transcript:

1 Operating Systems for Reconfigurable Computing Systems Xuequn(Robin) Li Instructor: Prof. Shawki Areibi School of Engineering School of Engineering University of Guelph University of Guelph Mar 30, 2004

2 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Outline IntroductionTasks –Allocation –Partitioning –Placement –Routing Case Study –Design Concepts –Implementation Concepts SummaryReferences

3 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) LiIntroduction Reconfigurable Computing System –Tradeoff between ASIC (Performance) and General Processor (Flexibility) and General Processor (Flexibility) –Logic (FPGA) –Embedded Control –Computer based RC Traditional OS –Device management –Process & resource management –Memory management –File management

4 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li OS for RCS With the development of the reconfigurable computing systems, designers are looking towards multitasking reconfigurable computers Multitasking an FPGA will require an OS to manage the loading, swapping and allocation of the tasks to the FPGA surface As the status of the FPGA changes in time, the designs will have to be completed at run-time, and not statically compiled. The partitioning, placement and routing need be handled by the OS.

5 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li History 1996, G. Brebner first presented the description of hardware multitasking 1999, Wigley discussed the services of OS for RCS, including devices partitioning, placement and routing 2003,Herbert Walder proposed a Reconfigurable Hardware OS prototype ……

6 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Benefits Speed up development cycles –Re-use tested and reliable codes and circuits Increase portability –Recompilation/resynthesis Ease system re-partitioning –Between different HW components or even between HW and SW components Simplify debugging –Monitor and trigger facilities

7 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Tasks of OS for RCS General Tasks – Loader – Scheduler – Memory management – Circuit protection – I/O – Inter-process communication Special Tasks –Allocation –Partitioning –Placement –Routing multiple circuits on one or more FPGA

8 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Scheduling Algorithms First-in-first-served algorithms First-in-first-served algorithms – simple but not efficient Genetic algorithms: Reduce the time delay in serving large number of tasks Genetic algorithms: Reduce the time delay in serving large number of tasks –Belong to the class of stochastic search methods –Other than operate on a single solution to the problem at hand, genetic algorithms operate on a population of solutions

9 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Allocation in OS for RCS Take the next application from the loader to be executed on the real surface and given minimum area requirement Search the logic frame free list for an area contiguous set of frames which meet the area requirement Determine where or if the free logic is available for the application

10 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Allocation Algorithms Compare the free space on the real FPGA surface with the total required area –If not enough, partition the application, with parts executing, and the others being held elsewhere on the real surface or on the virtual surface Determine of there is an available free frame on the real FPGA surface Once the frame has been found, the space will be marked; otherwise, OS will invoke the partitioning algorithms

11 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Partitioning in OS for RCS The process in which a large circuit is broken into smaller ones to fit onto available space on the FPGA –Increase the performance –Minimize communication between partitions

12 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Partitioning in OS for RCS (contd) Identify a rearrangement of the running task on the FPGA that free sufficient logic for the waiting task Identify a rearrangement of the running task on the FPGA that free sufficient logic for the waiting task Use a scheduler mechanism to minimize the delay in the execution time of the chosen tasks Use a scheduler mechanism to minimize the delay in the execution time of the chosen tasks The deterministic and bounded run time is important to avoid unpredictable time which would reduce the ability of OS The deterministic and bounded run time is important to avoid unpredictable time which would reduce the ability of OS

13 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Partitioning Algorithms Calculate the As Soon As Possible (ASAP) execution levels of each node Use these levels to allocate the nodes to the desired partition until the partition reaches the user selected capacity Invoke the placement algorithm and if the placement fails, the OS reduces the user selected capacity and attempts to re- partition and re-place the application.

14 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Placement in OS for RCS Determining where modules of the application partitions are located in logic partitions Minimizing the area, routing delays and run time After successful complete placement, the router will be invoked by OS

15 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Placement Algorithms Objective: Placing the connecting logic modules close to each other Place the first node to the right of the parent Place the second mode on top of the parent Repeat until all modules have been placed; otherwise, re-allocate or reduce the number of logic modules

16 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Routing in OS for RCS Create an electrical connection between two logic modules by setting the appropriate routing switches Routing must have a predicable time All logic modules have been internally placed and routed

17 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Routing Algorithms Modeled on a simple rule-based router Route all nearest neighbour connections Handle those routes that are not nearest neighbour Create a list for the detail of each route, so OS can easily rip up the fail routes or removed routes If routing fails, OS restart to invoke allocation algorithm with different specifications

18 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Case Study An OS for RCS Prototype Design concepts that define basic abstractions & operating system services Implement concepts on Xilinx technology, including a multitasking environment, memory management unit, and device drivers & triggers to connect external I/O

19 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Design Concepts Reconfigurable Surface Partitioning –OS frame –User area Hardware Tasks OS modules –Host CPU –FPGA

20 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li OS for RCS Benchmark A set of benchmark applications to evaluate OS for RCS Not available right now, but should include these quality metrics –Area overheads –Runtime overheads –Fragmentation External fragmentation Internal fragmentation

21 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Implementation Concepts Target technology and Platform –XESS XSV-800 as platform –A Virtex XCV-800 SRAM-based FPGA –A set of I/O devices: Ethernet, RS232,display elements, DAC etc. FPGA Surface Partitioning –OS –frame –Task slots Task Slots Placeholders for HW tasks –Width –STI (Standard task interface) –IFCC (Inter-frame communication channels)

22 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li XESS Prototyping Board

23 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Example Function: –Generate an artificial audio signal –Display light patterns on LED bar –Receive UDP (User Datagram Protocol ) packets via the Ethernet interface and forward to RS232 interface or the audio codec –Reply to incoming ARP (Address Resolution Protocol) and ICMP (Internet Control Message Protocol) echo requests

24 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Summary New technology Future works –Larger FPGAs –Improved algorithms –More practicable Thanks ! Thanks !

25 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li References [1] Operating System----A modern Perspective By Gary Nutt [2] The Development of an Operating System for Reconfigurable computing By Grant Wigley, David KearneyUniv. of South Australia By Grant Wigley, David KearneyUniv. of South Australia [3] Reconfigurable Hardware Operating Systems: From Design Concepts to Realizations By Herbert Walder and Macor Platzner Swiss Federal Institute of Technology [4] Reconfigurable Hardware OS Prototype By Herbert Walder and Macor Platzner Swiss Federal Institute of Technology

26 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Questions ? ? ?

27 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li To achieve run-time reconfigurable, the system specification (typically, a task graph) must be partitioned into temporal exclusive segments (called reconfiguration contexts). This process is usually known as temporal partitioning. A different approach is to find an execution order for a set of tasks that meets system-design objectives (i.e., minimize the application execution time). This is known as DRL (dynamically Reconfigurable Logic) multi-context scheduling. Fine-grained or Coarse-grained

28 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Create a population of genomes then applies crossover and mutation to the individuals in the population to generate new individuals Stop generation when one generated solution match the solution. 3. Enhanced force directed scheduling (FDS) technique: aims at reducing the communication and gate cost through “balancing the number of nodes in each time step given overall deadline when the schedule must be completed”.

29 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li OS generates a table that keeps track of loaded circuits and the amount of logic they reserved OS scans that FPGA surface and looks for the amount of free logic required for the next circuit

30 Operating Systems for Reconfigurable Computing Systems Presented by Robin (Xuequn) Li Performance Measure Use benchmark circuits Calculate gate cost: if gates are split evenly over context Ci, the number of gates per context is the maximum number of gates per any Ci communication cost: the number of signals that need to be stored at any give time, recall the scheduling example performance: Examine the execution sequence to find maximum time needed between user clocks.