WiMAX OSS Real Time Operating System (RTOS) Sugeng Widodo 5 Desember 2007
Real Time System Kendala Waktu Sistem dikatakan benar bukan hanya memberi output yang benar saja tetapi memberi output yan...
Hard vs Soft Real Time Kebutuhan tingkat kecepatan respon suatu sistem Keterlambatan respon pada hard real time dapat bera...
Contoh Hard Real Time <ul><li>Sistem kontrol pesawat tempur </li></ul><ul><li>Sistem kontrol reaktor nuklir </li></ul><ul>...
Contoh Soft Real Time <ul><li>Multimedia player </li></ul><ul><li>Video streaming </li></ul><ul><li>MAC upper layer </li><...
Karakteristik Real Time System <ul><li>Embedded  : merupakan komponen dari sistem yang lebih besar </li></ul><ul><li>Concu...
Real Time Operating System Tidak setiap Real Time System menggunakan RTOS RTOS sebenarnya adalah tools bagi developer untu...
Multi tasking / threading Permasalah sistem real time biasanya terdiri dari  beberapa jenis pekerjaan yang kecil-kecil yan...
Virtual paralel Karena processor yang digunakan hanya satu maka sebenarnya task-task tersebut tidak benar-benar berjalan s...
Hyperthread Beberapa prosesor yang modern sekarang mengenal konsep  hyperthread  dimana satu prosesor bisa menjalankan sec...
Re-entrant Karena ada banyak task/thread maka akan sering satu fungsi yang sama dipanggil oleh beberapa thread dalam waktu...
Scheduling Kernel berfungsi sebagai pengatur aktifitas task/thread kapan berhenti kapan berjalan.
Scheduling Pre-emptive Kernel Kernel dapat menghentikan task/thread yang sedang berjalan terutama apabila ada task/thread ...
Status Task/Thread pending suspended ready delayed
Priority Scheduling <ul><li>Task berstatus ready dengan prioritas paling tinggi yang akan dijalankan </li></ul><ul><li>Tas...
Round Robin Scheduling Task/thread yang berstatus ready dengan prioritas yang sama akan digilir waktu eksekusinya sesuai d...
Penanganan Interrupt Biasanya dibagi dua bagian : lower-half dan upper-half lower-half  : non pre-emptive, interrupt statu...
Tick Unit waktu yang digunakan kernel untuk berpindah dari satu task/thread ke task/thread yang lain Linux mempunyai tick ...
Komunikasi antar task/thread Kenyataannya antar task/thread tidaklah independen Sering antar task/thread harus berkomunika...
Semaphore Digunakan untuk sinkronisasi apabila ada beberapa task/thread ingin mengakses resource yang sama
Condition Variable Digunakan apabila suatu task/thread menunggu tanda dari task/thread yang lain sebelum melanjutkan eksek...
Mailbox Digunakan oleh task/thread untuk bertukar data dengan task/thread yang lain
Biasanya penggunakan semaphore, condition variable dan pembacaan mailbox membuat perubahan status thread dari ready menjad...
Sleep Cara lain bagi thread untuk berubah status dari ready ke delayed adalah dengan sleep selama waktu tertentu. Cara ini...
Linux Kernel linux yang asli adalah non pre-emptive Resolusi tick linux adalah 10ms Sebagian besar driver dalam linux tida...
LinuxRT Merupakan patching untuk kernel linux Membuat kernel linux menjadi pre-emptive Membuat resolusi tick yang lebih ha...
Linux RTAI Membuat kernel real time dibawah Linux Kernel Linux menjadi salah satu process/task dari kernel RTAI dengan pri...
eCOS Merupakan singkatan dari embedded Configurable Operating System Keunggulan utamanya adalah kemudahan dalam mengkonfig...
eCOS Mempunyai fitur untuk kebutuhan Real Time System seperti : pre-emptive kernel, priority dan round roubin schebuling, ...
Komponen eCOS <ul><li>HAL : hardware abstraction layer , hardware dependent , memudahkan porting </li></ul><ul><li>Device ...
Lisensi eCOS Modified GPL Modifikasi kernel harus tetap dengan lisensi yang sama Memungkinkan aplikasi yang dilinking deng...
Menggunakan eCOS <ul><li>Mengkonfigurasi kernel sesuai kebutuhan </li></ul><ul><li>Mengkompilasi kernel menjadi library </...
Upcoming SlideShare
Loading in …5
×

Rtos Wimax OSS Workshop

2,025 views
1,939 views

Published on

Published in: Technology
1 Comment
1 Like
Statistics
Notes
No Downloads
Views
Total views
2,025
On SlideShare
0
From Embeds
0
Number of Embeds
1
Actions
Shares
0
Downloads
53
Comments
1
Likes
1
Embeds 0
No embeds

No notes for slide

Rtos Wimax OSS Workshop

  1. 1. WiMAX OSS Real Time Operating System (RTOS) Sugeng Widodo 5 Desember 2007
  2. 2. Real Time System Kendala Waktu Sistem dikatakan benar bukan hanya memberi output yang benar saja tetapi memberi output yang benar dari dari suatu input pada saat yang tepat
  3. 3. Hard vs Soft Real Time Kebutuhan tingkat kecepatan respon suatu sistem Keterlambatan respon pada hard real time dapat berakibat bencana Keterlambatan pada soft real time hanya menurunkan kualitas
  4. 4. Contoh Hard Real Time <ul><li>Sistem kontrol pesawat tempur </li></ul><ul><li>Sistem kontrol reaktor nuklir </li></ul><ul><li>Sistem kontrol pacu jantung </li></ul><ul><li>MAC lowest layer (Burst Generator) – tidak berakibat bencana tapi sistem tidak akan berjalan </li></ul>
  5. 5. Contoh Soft Real Time <ul><li>Multimedia player </li></ul><ul><li>Video streaming </li></ul><ul><li>MAC upper layer </li></ul><ul><li>EML </li></ul><ul><li>Device driver </li></ul>
  6. 6. Karakteristik Real Time System <ul><li>Embedded : merupakan komponen dari sistem yang lebih besar </li></ul><ul><li>Concurrent : secara bersamaan mengontrol / bereaksi terhadap berbagai faktor yang melingkupinya </li></ul><ul><li>Safety : tidak hanya handal tapi juga aman, tidak menyebabkan kerusakan jika gagal </li></ul><ul><li>Reaktif : selalu beinteraksi dengan lingkungan dan bereaksi dengan benar </li></ul>
  7. 7. Real Time Operating System Tidak setiap Real Time System menggunakan RTOS RTOS sebenarnya adalah tools bagi developer untuk mempermudah membuat aplikasi untuk kebutuhan Real Time. Implementasi never-ending loop sering sudah cukup untuk mengimplementasikan Real Time System terutama bila bahasa assembler yang digunakan untuk pengembangan.
  8. 8. Multi tasking / threading Permasalah sistem real time biasanya terdiri dari beberapa jenis pekerjaan yang kecil-kecil yang dapat berjalan secara independen. RTOS mempermudah pembuatan aplikasi real time dimana terdapat banyak jenis pekerjaan yang harus dilakukan.
  9. 9. Virtual paralel Karena processor yang digunakan hanya satu maka sebenarnya task-task tersebut tidak benar-benar berjalan secara paralel akan tetapi berjalan secara bergantian. thread 1 thread 3 thread 2
  10. 10. Hyperthread Beberapa prosesor yang modern sekarang mengenal konsep hyperthread dimana satu prosesor bisa menjalankan secara paralel lebih dari satu thread. Intel Pentium misal bisa dua thread, sementara UltraSPARC T2 bisa sampai 16 thread Architecture yang lain adalah multi core yang tentu saja dapat menjalankan lebih dari satu thread bersama-sama.
  11. 11. Re-entrant Karena ada banyak task/thread maka akan sering satu fungsi yang sama dipanggil oleh beberapa thread dalam waktu bersamaan. Fungsi-fungsi harus bersifat re-entrant atau boleh dipanggil ulang oleh thread lain walaupun fungsi tersebut belum selesai. Jangan menggunakan variable global di semua fungsi
  12. 12. Scheduling Kernel berfungsi sebagai pengatur aktifitas task/thread kapan berhenti kapan berjalan.
  13. 13. Scheduling Pre-emptive Kernel Kernel dapat menghentikan task/thread yang sedang berjalan terutama apabila ada task/thread dengan prioritas yang lebih tinggi. Non-pre-emptive Kernel Task/Thread harus menghentikan dirinya sendiri supaya dapat digantikan oleh task/thread lain.
  14. 14. Status Task/Thread pending suspended ready delayed
  15. 15. Priority Scheduling <ul><li>Task berstatus ready dengan prioritas paling tinggi yang akan dijalankan </li></ul><ul><li>Task yang bersifat a-periodik biasanya mendapat proritas lebih tinggi dari yang periodik </li></ul><ul><li>Semakin tinggi prioritas sedapat mungkin waktu eksekusinya semakin pendek </li></ul><ul><li>Semakin tinggi prioritas sebaiknya semakin sering melakukan voluntary suspended/delayed </li></ul>
  16. 16. Round Robin Scheduling Task/thread yang berstatus ready dengan prioritas yang sama akan digilir waktu eksekusinya sesuai dengan jatah waktu yang diberikan
  17. 17. Penanganan Interrupt Biasanya dibagi dua bagian : lower-half dan upper-half lower-half : non pre-emptive, interrupt status clearing, aktifasi upper-half, secepat mungkin upper-half : pre-emptive, pengambilan dan pengolahan data, prioritas tergantung sifat data
  18. 18. Tick Unit waktu yang digunakan kernel untuk berpindah dari satu task/thread ke task/thread yang lain Linux mempunyai tick dengan resolusi 10ms , RTOS biasanya mempunyai resolusi yang lebih halus
  19. 19. Komunikasi antar task/thread Kenyataannya antar task/thread tidaklah independen Sering antar task/thread harus berkomunikasi untuk keperluan tukar-menukar data ataupun sinkronisasi
  20. 20. Semaphore Digunakan untuk sinkronisasi apabila ada beberapa task/thread ingin mengakses resource yang sama
  21. 21. Condition Variable Digunakan apabila suatu task/thread menunggu tanda dari task/thread yang lain sebelum melanjutkan eksekusinya
  22. 22. Mailbox Digunakan oleh task/thread untuk bertukar data dengan task/thread yang lain
  23. 23. Biasanya penggunakan semaphore, condition variable dan pembacaan mailbox membuat perubahan status thread dari ready menjadi pending/delayed sehingga posisinya bisa digantikan thread lain yang sudah ready
  24. 24. Sleep Cara lain bagi thread untuk berubah status dari ready ke delayed adalah dengan sleep selama waktu tertentu. Cara ini biasa digunakan oleh thread-thread dengan prioritas tinggi untuk memberi kesempatan kepada thread dengan prioritas lebih rendah untuk dieksekusi
  25. 25. Linux Kernel linux yang asli adalah non pre-emptive Resolusi tick linux adalah 10ms Sebagian besar driver dalam linux tidak mendukung sistem real time
  26. 26. LinuxRT Merupakan patching untuk kernel linux Membuat kernel linux menjadi pre-emptive Membuat resolusi tick yang lebih halus Aplikasi real time merupakan proses dalam linux
  27. 27. Linux RTAI Membuat kernel real time dibawah Linux Kernel Linux menjadi salah satu process/task dari kernel RTAI dengan prioritas rendah Aplikasi realtime bukan merupakan proses dalam linux
  28. 28. eCOS Merupakan singkatan dari embedded Configurable Operating System Keunggulan utamanya adalah kemudahan dalam mengkonfigurasi dan ukuran yang kecil cocok untuk aplikasi embedded.
  29. 29. eCOS Mempunyai fitur untuk kebutuhan Real Time System seperti : pre-emptive kernel, priority dan round roubin schebuling, tick yang halus dan mudah di konfigurasi, device driver yang mendukung real time dan lengkap
  30. 30. Komponen eCOS <ul><li>HAL : hardware abstraction layer , hardware dependent , memudahkan porting </li></ul><ul><li>Device Driver : hardware dependent </li></ul><ul><li>Kernel : Hardware Independent , Highly configurable </li></ul><ul><li>C Library : standard C , re-entrant </li></ul><ul><li>GDB : memudahkan debuging </li></ul>
  31. 31. Lisensi eCOS Modified GPL Modifikasi kernel harus tetap dengan lisensi yang sama Memungkinkan aplikasi yang dilinking dengan kernel mempunyai lisensi yang lain
  32. 32. Menggunakan eCOS <ul><li>Mengkonfigurasi kernel sesuai kebutuhan </li></ul><ul><li>Mengkompilasi kernel menjadi library </li></ul><ul><li>Membuat code aplikasi </li></ul><ul><li>Mengkompilasi aplikasi </li></ul><ul><li>Melingking aplikasi dengan kernel </li></ul><ul><li>meng-upload aplikasi ke device </li></ul>

×