Download presentation
1
Embedded Systems and Hardware/Software Codesign
مرتضي صاحب الزماني
2
انواع طراحي سيستم ديجيتال بزرگ
پيادهسازي نرمافزاري: اجراي برنامه کاربردي با پردازنده نهفته و برنامه سطح بالا روي آن پيادهسازي سختافزاري: طراحي سختافزار خاصمنظوره کد HDL و سنتز و ... منابع سختافزاري FPGA (logic blocks، Multipliers، ...)
3
انواع طراحي سيستمهاي ديجيتال بزرگ
تفاوتها: نرمافزاري: انعطاف بالا توصيف الگوريتم به زبان سطح بالا آسان سختافزاري: سرعت بالا هزينه بالا
4
The Von Neumann Computer
Sequential execution tcycle = cycle execution time One instruction needs tinstruction = 5*tcycle 3 instructions: in 15*tcycle Pipelining: no improvement. 3 instructions: in 7*tcycle in the ideal case. Increased throughput Even with pipeline and other improvement like cache, the execution remain sequential.
5
Application-Specific Processors
ASIC implementation: The complete execution is done in parallel in one clock cycle run-time = tclock= delay longest path from input to output ASIC Example: Implementation of a VN computer if (a < b) then { d = a+b; c = a*b; } else d = a+1; c = b-1; At least 3 instructions run-time >= 3*tinstruction
6
انواع طراحي سيستمهاي ديجيتال بزرگ
روش سوم: استفاده از مزاياي هر دو: پيادهسازي بخشهاي غيربحراني با نرمافزار (کنترل هزينه) پيادهسازي بخشهاي بحراني روي سختافزار
7
انواع طراحي سيستمهاي ديجيتال بزرگ
طراحي توامان افراز (partitioning) تحليل زماني + تحليل هزينه + تحليل توان مصرفي سعي و خطا بهترين افراز
8
JPEG Encoder
9
JPEG Encoder Profiling: gprof در Linux 11٪ خواندن تصویر 89٪ کد کردن
10
تعيين بورد و/يا تراشه FPGA
جريان طراحي توأمان تصميمهاي اوليه افراز انتخاب زبان نرمافزاري انتخاب زبان توصيف سختافزار تعيين بورد و/يا تراشه FPGA جریان طراحی سختافزار جریان طراحی نرمافزار
11
جریان طراحی انتخاب بورد: بوردهای توسعه در فهرست بورد خودتان:
مشخصات کامل (نوع تراشه FPGA + امکانات ارتباطی + تراشههای جانبی + اتصال پینها) موجود است بورد خودتان: مشخصات را بدهید به هر حال نوع تراشه مشخص میشود.
12
جريان طراحي توأمان جریان طراحی سختافزار جریان طراحی نرمافزار
تعیین پردازنده و پیکربندی آن ایجاد پروژه نرمافزار افزودن وسایل جانبی و هستههای سختافزاری توسعه نرمافزار انتخاب نوع ارتباط وسایل جانبی با پردازنده کامپایل و لینک مجتمعسازی بخشهای سختافزاری انتقال برنامه به حافظه سنتز، جایابی، و مسیریابی جریان نرمافزار مستقل از جریان سختافزار نیست. نوع پردازنده، پیکربندی آن، نحوه ارتباط نرمافزار با سختافزار تولید دنباله بیتی انتقال به FPGA
13
جریان طراحی سختافزار تعیین پردازنده: پردازنده سخت: پردازنده نرم
ARM Cortex PowerPC سریع، مساحت کمتر، توان مصرفی کم عدم نیاز به استفاده از Logic Blockها یکی یا بیشتر پردازنده نرم
14
جریان طراحی سختافزار تعیین پردازنده: پردازنده نرم
PicoBlaze (Xilinx) MicroBlaze (Xilinx) NIOS II (Altera) OR1200 (Open Cores) (متن باز) اگر تراشه دارای هسته سخت دارد، استفاده از نرم توجیه چندانی ندارد) انعطافپذیری بالا (پیکربندی و تنظیم پارامترها بسته به کاربرد) مثال: استفاده از PicoBlaze 8 بیتی بجای پردازنده قوی مجموعه دستورالعملها عمق خط لوله دستورالعملها ....
15
جریان طراحی سختافزار پیکربندی پردازنده: فرکانس ساعت
پهنای باس داده و آدرس اندازه حافظه نهان داده و دستورالعمل نوع گذرگاه ارتباطی خصوصیات Reset (مثبت یا منفی) FPU؟ و تنظیمات آن ...
16
افزودن وسایل جانبی و هستههای سختافزاری
سختافزار جانبی: انتخاب بلوکهای IP آماده در کتابخانه ابزار و پیکربندی آن کنترلر حافظه (پیکربندی مشخصات حافظه) مدار UART (تنظیم نرخ ارسال/دریافت داده، اندازه داده و نوع توازن) FIFO با ابعاد مشخص خرید IP از شرکتهای طراح طراحی مستقل بلوک (در ابزار نیست و خرید مقرون به صرفه نیست) توصیف با VHDL یا Verilog سنتز و ....
17
Xilinx Core Generator
18
انتخاب نوع ارتباط وسایل جانبی با پردازنده
دو نوع: ارتباط نقطه به نقطه گذرگاه (bus)
19
انتخاب نوع ارتباط وسایل جانبی
ارتباط نقطه به نقطه دادهها: به صورت دنباله نمونه: FSL (شرکت LogiCore) ارتباط مبتنی بر FIFO Peripheral Device 1 Microprocessor Peripheral Device 2
20
انتخاب نوع ارتباط وسایل جانبی
گذرگاه (bus) چند سختافزار جانبی با اتصالات مشترک درخواست استفاده از گذرگاه توسط داور بررسی (پذیرفته یا رد) میشود Bus Arbiter Peripheral Device 1 Microprocessor Peripheral Device 2
21
انتخاب نوع ارتباط وسایل جانبی
گذرگاه (bus) دو گذرگاه با سرعتهای مختلف: سریعها روی گذرگاه سیستم (حافظهها و ....) کندها روی گذرگاه جانبی (serial port، GPIO) System Bus Peripheral Bus Microprocessor Bridge Peripheral Device 3 Peripheral Device 4 Memory Controller Peripheral Device 2
22
انواع گذرگاه گزینهها: تفاوت در کارایی و هزینه سختافزاری (LEها)
PLB (Xilinx) از کتابخانه CoreConnect برای ارتباط وسایل جانبی سریع هنوز در ابزارها موجود است داده 128 بیتی هزینه بالا
23
انواع گذرگاه گزینهها: AXI (Xilinx) مبتنی بر AMBA (شرکت ARM)
برای ارتباط وسایل جانبی سریع (مانند حافظه و اترنت) برای حافظه داخلی FPGA از LMB استفاده میشود. در ابزارهای جدیدتر AXI-Lite برای وسایل جانبی کندتر (UART یا صفحه کلید)
24
انواع گذرگاه گزینهها:
Avalon (Altera) Avalon-ST: نقطه به نقطه Avalon-MM: گذرگاه مشترک Wishbone (SiliCore) متن باز قابل تغییر طراح انتخاب میکند – ابزار سختافزار ایجاد میکند
25
مجتمعسازی بخشهای سختافزاری
پردازنده(ها) سیستم ارتباطی سختافزارهای جانبی و حافظهها تولید دنباله بیتی Export به محیط نرمافزار: ارسال مشخصات hardware platform
26
جریان توصیف نرمافزار مراحل ایجاد پروژه (C یا C++) برنامه نویسی
معمولا ویرایش الگوهای موجود ارتباط با سختافزار به کمک APIها اشکالزدایی انتقال برنامه به حافظه داخلی FPGA یا خارجی (اگر جا نشد)
27
نکات متفرقه سیستم چندپردازندهای پیادهسازی سیستم پایه سیستم عامل:
حافظه مجازی مدیریت پردازش چندنخی .... مثال: سیستم عامل لینوکس روی FPGA امکان اجرای انواع نرمافزارهای موجود سربار زیاد (سیکل اضافه پردازنده، حافظه، توان) فقط وقتی که لازم است
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.