آموزش نصب و راه اندازی سیستم عامل RTOS بر روی آردوینو

blog
۱۳۹۶-۰۲-۱۴
6 دقیقه

RTOS چیست ؟

هر وقت کلمه‌ی “سیستم‌عامل” را می‌شنویم ناخودآگاه به یاد سیستم‌عامل‌های لینوکس، مک، ویندوز، بی‌اس‌دی و دیگر سیستم‌عامل‌های آشنا می‌افتیم! کار اصلی یک سیستم‌عامل مدیریت منابع و ایجاد هماهنگی بین اجزاء یک سیستم و برنامه‌ها است. در سیستم‌عامل‌های رایج، مدیریت منابع سیستم بین برنامه‌های در حال اجرا تقسیم می‌شود و تمرکز بر ایجاد تعادل بین برنامه‌ها است. این دسته از سیستم‌عامل‌ها برای اجراشدن نیاز به سخت‌افزار قوی و میزان حافظه زیادی دارند که پیاده‌سازی آن‌ها را بر روی سیستم‌های مبتنی بر میکروکنترلر غیرممکن می‌کند.

اما نگران نباشید! سیستم‌عامل‌های دیگری وجود دارند که برای کار بر روی میکروکنترلرها طراحی و ساخته‌شده‌اند. ممکن است فکر کنید که “با محدودیت موجود در ساختار یک میکروکنترلر، چه منابعی وجود دارد که به مدیریت نیاز دارد؟ حجم برنامه‌ها و تعداد سخت‌افزارهای در دسترس این‌قدر محدود است که نیاز به مدیریت خاصی ندارد.”

در پاسخ به این سؤال باید عنوان کنم که یکی از اساسی‌ترین و کلیدی‌ترین منابع موجود در هر سیستمی، زمان است!

شما در طراحی هر سیستمی نیاز دارید که به‌صورت صحیح زمان را مدیریت کنید. اگر بعد از اعمال ورودی‌ها، سیستم در زمان مناسب قادر به ارائه خروجی نباشد، به این سیستم نمی‌توان به چشم یک سیستم کاربردی نگاه کرد. به‌عنوان‌مثال خودرویی تمام هوشمند را فرض کنید که با سرعت 60 کیلومتر بر ساعت در حال حرکت است و مانعی را شناسایی می‌کند. اگر نتواند به‌موقع بعد از شناسایی مانع عکس‌العمل نشان داده و خودرو را متوقف کند، خودرو با مانع برخورد کرده و باعث ایجاد خسارت خواهد شد. پس همان‌طور که مشاهده می‌کنید مدیریت زمان، مخصوصاً در سیستم‌های کنترلی از اهمیت بسیار بالایی برخوردار است.

مدیریت زمان با اتکا به سیستم سنتی Super Loop شاید برای برنامه‌های ساده و کوچک عملی باشد؛ ولی عملاً در برنامه‌های پیچیده غیرممکن خواهد بود. مثلاً برای پیاده‌سازی یک خلبان خودکار یا سیستم‌های پزشکی که زمان اهمیت بالایی دارد نمی‌توان از Super Loop برای کنترل برنامه استفاده کرد و سیستم به‌سرعت دچار خطا خواهد شد.

برای رفع این مشکل، سیستم‌عامل‌هایی خاص طراحی‌شده‌اند که مدیریت زمان را به بهترین نحو ممکن انجام می‌دهند. این دسته‌ی خاص از سیستم‌عامل‌ها real-time operating system نام دارند که به‌اختصار RTOS خوانده می‌شوند. همان‌طور که از نام این سیستم‌عامل‌ها بر می‌آید، تخصص آن‌ها در مدیریت زمان است.

 

RTOS چگونه زمان را مدیریت می‌کند؟

در سیستم‌های مبتنی بر  RTOS، هر وظیفه (Task) به شکل یک Super Loop مجزا و ایزوله (به لحاظ فضای حافظه) از بقیه وظیفه‌ها در نظر گرفته می‌شود و می‌توان با توجه به اهمیت وظیفه‌ی مربوطه، آنها را دسته‌بندی کرد. به‌عنوان‌مثال فرض کنید قصد داریم سیستم راننده خودکار را پیاده‌سازی کنیم. برای شروع سیستم ما سه وظیفه اساسی خواهد داشت: تشخیص مانع، رانندگی کردن و پخش موزیک!

اگر همه‌ی وظایف محوله به سیستم در یک اولویت قرار گیرند، قطعاً سیستم به‌درستی کار نخواهد کرد؛ چراکه هنگام پخش موزیک فراموش می‌کند که جاده را اسکن کرده و موانع را تشخیص دهد. اما به‌راحتی می‌توان اولویت‌ها را تغییر داد: یعنی تشخیص موانع بالاترین اولویت را داشته باشد. بعدازآن رانندگی و در آخر پخش موزیک! قطعاً همه ترجیح می‌دهند که سالم از ماشین خود پیاده شوند تا این‌که یک موزیک را بدون اختلال گوش کرده باشند!

آموزش نصب و راه اندازی سیستم عامل RTOS بر روی آردوینو

با توجه به تصویر فوق، وظیفه قرمز (Task 1)  بالاترین اولویت را دارا خواهد بود؛ یعنی تشخیص موانع. بعدازآن رانندگی است که بارنگ آبی (Task 2) مشخص‌شده و در آخر پخش موزیک که بارنگ سبز (Task 3) نشان داده‌شده است. همان‌طور که در تصویر مشاهده می‌کنید در طول زمان اول لازم است جاده برای تشخیص موانع اسکن شود و بعدازآن سیستم به رانندگی بپردازد و اگر زمان باقی ماند، موزیک پخش کند. برای همین است که Task3 دارای زمان یکسانی برای اجرا نیست!

 

از کدام RTOS استفاده کنم؟

امروزه انواع بسیار زیادی از RTOS ها در دسترس هستند؛ از RTOS های تجاری که توسط شرکت‌های بزرگ، طراحی و پیاده‌سازی شده‌اند تا RTOS های رایگان و متن‌بازی که توسط هزاران برنامه‌نویس در سراسر جهان توسعه یافته‌اند. با توجه به این میزان تنوع در انتخاب، قطعاً باید معیارهای زیر را برای انتخاب درست در نظر گرفت که در ادامه دچار مشکل نشویم:

  • محدودیت‌های سخت‌افزار
  • نوع کار تعریف‌شده
  • میزان حساسیت آن

در خصوص معیار اول، قطعاً شما نمی‌توانید RTOS ای که برای هسته‌های ARM پایه‌ریزی شده است را بر روی AVR استفاده کنید و یا برعکس. هم‌چنین هر سیستم‌عاملی برای راه‌اندازی نیاز به یک حداقل Ram و حافظه برنامه خواهد داشت که باید آن را در نظر گرفت. به‌عنوان نمونه شما نمی‌توانید از ucLinux بر روی AVR بهره ببرید چراکه برای اجرای این سیستم‌عامل نیاز به چند ده مگابایت رم دارید؛ درصورتی‌که بالاترین میزان حافظه در AVR چند ده کیلوبایت است.

مسئله مهم بعد میزان حساسیت کار است. میزان حساسیت کار سیستمی که خط تولید یک کارخانه را کنترل کند، چندان بالا نیست و می‌توان از یک RTOS معمولی هم استفاده کرد. ولی اگر قصد طراحی سیستمی داشته باشید که خلبان خودکار یک وسیله پرنده باشد، قطعاً باید از RTOS خاص، با مدیریت دقیق زمان و ضریب اطمینان بسیار بالا استفاده کنید.

برای مشاهده لیست RTOS های موجود می‌توانید به سایت osrtos مراجعه کنید.

ما در این مقاله قصد داریم که نحوه راه‌اندازی و کانفیگ یکی از پرطرفدارترین RTOS های موجود را آموزش دهیم:  FREE RTOS ؛ که علاوه بر رایگان بودن متن‌باز هم هست و به‌صورت خیلی ساده طراحی‌شده که قابلیت پشتیبانی از 31  نوع میکروکنترلر متفاوت را دارا باشد. پس بهترین گزینه برای خیلی از پروژه‌ها، این RTOS است.

 

نصب FREE RTOS بر روی آردوینو:

برای شروع کار با FreeRTOS باید کتابخانه‌های لازم را بر روی ادیتور آردوینو نصب کنیم. جهت نصب ابتدا به منوی  Sketch  رفته و از زیر منوی Include Library  گزینه Library Manager را انتخاب کنید.

آموزش نصب و راه اندازی سیستم عامل RTOS بر روی آردوینو

بعدازآن از پنجره بازشده، واژه Free Rtos را جستجو کرده و سپس با فشردن کلید Install آن را نصب کنید.

آموزش نصب و راه اندازی سیستم عامل RTOS بر روی آردوینو

 

چگونه با FREE RTOS یک پروژه ایجاد کنیم؟

ابتدا به منوی Sketch رفته و پس از آن از زیر‌منوی Include Library گزینه FreeRtos را انتخاب می‌کنیم.

آموزش نصب و راه اندازی سیستم عامل RTOS بر روی آردوینو

 

پس از انتخاب گزینه مربوطه، هدر Arduino_FreeRTOS.h به پروژه اضافه خواهد شد. دقت کنید که نصب سیستم‌عامل نیاز به فضای کافی دارد و در صورت نبود فضای کافی، با خطای کامپایلر هنگام کامپایل مواجه خواهید شد.

با توجه به جدول زیر می‌توانید فضای موردنیاز جهت  FreeRTOS و مقدار حافظه موردنیاز وقتی‌که از FreeRTOS استفاده نمی‌کنید را در بردهای مختلف مشاهده کنید.

همان‌طور که مشخص است بر روی آردوینو Uno در حالت بدون سیستم‌عامل، بدون هیچ برنامه‌ای 444 بایت از حافظه کد اشغال خواهد شد و بعد از نصب سیستم‌عامل 7340 بایت که یعنی سیستم‌عامل فقط 21 درصد از فضای برنامه را اشغال کرده است.

چگونگی شروع برنامه نویسی با Free Rtos:

در برنامه‌ی زیر ما سعی کرده‌ایم که ساده‌ترین برنامه ممکن را با استفاده از Free RTOS بنویسیم . در‌واقع کار برنامه این است که دو LED متصل به پورت های 12 و 13 را با سرعت متفاوتی به چشمک زدن وادار کند. برای این کار ما دو تسک ایجاد کردیم که یکی LED متصل به پورت 12 و دیگری LED  متصل به پورت 13 را کنترل می‌کند.

 

 

نحوه عملکرد Free RTOS بر روی برد آردوینو:

 

اطلاعات
21
0
لینک و اشتراک
profile

Zeus ‌

متخصص الکترونیک

زئوس هستم ساکن المپ

مقالات بیشتر
slide

پالت | بازار خرید و فروش قطعات الکترونیک

قطعات اضافه و بدون استفاده همیشه یکی از سرباره‌‌های شرکتها و طراحان حوزه برق و الکترونیک بوده و هست. پالت سامانه‌ای است که بصورت تخصصی اجازه خرید و فروش قطعات مازاد الکترونیک را فراهم می‌کند. فروش در پالت
family

آیسی | موتور جستجوی قطعات الکترونیک

سامانه آی سی سیسوگ (Isee) قابلیتی جدید و کاربردی از سیسوگ است. در این سامانه سعی شده است که جستجو، انتخاب و خرید مناسب تر قطعات برای کاربران تسهیل شود. وقتی شما در این سامانه، قطعه الکترونیکی را جستجو می‌کنید؛ آی سی به سرعت نتایج جستجوی شما در اکثر فروشگاه‌های آنلاین در حوزه قطعات الکترونیک را نمایش می‌دهد. جستجو در آیسی
family

فروشگاه سیسوگ

فروشگاه سیسوگ مجموعه ای متمرکز بر تکنولوژی های مبتنی بر IOT و ماژول های M2M نظیر GSM، GPS، LTE، NB-IOT، WiFi، BT و ... جایی که با تعامل فنی و سازنده، بهترین راهکارها انتخاب می شوند. برو به فروشگاه سیسوگ
family

سیسوگ فروم | محلی برای پاسخ پرسش‌های شما

دغدغه همیشگی فعالان تخصصی هر حوزه وجود بستری برای گفتگو و پرسش و پاسخ است. سیسوگ فروم یک انجمن آنلاین است که بصورت تخصصی امکان بحث، گفتگو و پرسش و پاسخ در حوزه الکترونیک را فراهم می‌کند. پرسش در سیسوگ فرم
become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله
become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله
خانواده سیسوگ

پالت | بازار خرید و فروش قطعات الکترونیک

قطعات اضافه و بدون استفاده همیشه یکی از سرباره‌‌های شرکتها و طراحان حوزه برق و الکترونیک بوده و هست. پالت سامانه‌ای است که بصورت تخصصی اجازه خرید و فروش قطعات مازاد الکترونیک را فراهم می‌کند.
family

آیسی | موتور جستجوی قطعات الکترونیک

سامانه آی سی سیسوگ (Isee) قابلیتی جدید و کاربردی از سیسوگ است. در این سامانه سعی شده است که جستجو، انتخاب و خرید مناسب تر قطعات برای کاربران تسهیل شود. وقتی شما در این سامانه، قطعه الکترونیکی را جستجو می‌کنید؛ آی سی به سرعت نتایج جستجوی شما در اکثر فروشگاه‌های آنلاین در حوزه قطعات الکترونیک را نمایش می‌دهد.
family

فروشگاه سیسوگ

فروشگاه سیسوگ مجموعه ای متمرکز بر تکنولوژی های مبتنی بر IOT و ماژول های M2M نظیر GSM، GPS، LTE، NB-IOT، WiFi، BT و ... جایی که با تعامل فنی و سازنده، بهترین راهکارها انتخاب می شوند.
family

سیسوگ فروم | محلی برای پاسخ پرسش‌های شما

دغدغه همیشگی فعالان تخصصی هر حوزه وجود بستری برای گفتگو و پرسش و پاسخ است. سیسوگ فروم یک انجمن آنلاین است که بصورت تخصصی امکان بحث، گفتگو و پرسش و پاسخ در حوزه الکترونیک را فراهم می‌کند.
family

دیدگاه ها

profile
ابراهیم گفت :
۱۴۰۲-۱۰-۱۲ ۱۵:۵۷

ممنون بابت اموزشتون من تازه شروع به تولید محتوا کردم واقعا زحمت می کشید خیلی ممنون

profile
توفیق گفت :
۱۴۰۰-۰۳-۳۰ ۱۹:۰۶

چطور میتونم مستقیم و بدون استفاده از آردوینو یک free rtos رو روی یک میکرو آرم نصب کنم؟
اگه ممکنه راهنمایی کنید

profile
عرفان گفت :
۱۳۹۹-۱۲-۱۲ ۰۰:۲۷

سلام استاد
سوال دارم میشه منبع کتاب رو بگید ویا کمکم کنید؟
در مورد متغیر هست متغیری که در تابع دوم استفاده میکنم بر روی تابع اول تاثیر نداره
تعیرف متغیر رو هم بالا کنار فرخوانی کتابخانه ها هم نوشتم ولی تاثیر نداشت

profile
zeus گفت :
۱۴۰۰-۰۳-۰۵ ۰۸:۲۴

سلام و درود دوست عزیز
بهترین رفرنس کتابی هست که free-rtos منتشر شده و البته ظاهرا رایگان نیست ولی خوب فکر کنم برای دانلود بتونید توی اینترنت پیداش کنید.

profile
محمد گفت :
۱۳۹۹-۰۲-۲۷ ۱۴:۲۵

سلام. قبلا داخل loop قسمتی داشتم که هر 60 ثانیه یک بار یه سری اطلاعات رو چک می کرد(اتصال همه سنسورها در یک پروتکل ارتباطی ) و این کار رو داخل یک while انجام داده بودم که یعنی توقف برنامه تا انتهای این حلقه، سپس از نتایج این بررسی در ادامه استفاده می کردم. سوال اینجاست چطور میشه یه task ایجاد کرد که با همون زمان بندی (60 ثانیه یا هرچی) اجرا بشه؟
و سوال دوم: آیا از نتایج داخل این task میشه در لوپ اصلی استفاده کرد؟ یعنی متغیرهای داخل این task رو میشه در loop استفاده کرد؟ و اگر در لوپ دوباره بخواهیم این متغیرهارو تغییر بدیم و مجددا در task استفاده کنیم قابل اجراست؟

profile
زئوس Zeus گفت :
۱۳۹۹-۰۲-۲۸ ۱۳:۳۴

سلام دوست عزیز
سوال اولتون رو درست متوجه نشدم – شما میخواید ریت اسکن ثابت باشه ؟ خوب بعد از اتمام یک دور اسکن به اندازه کافی تاخیر ایجاد کنید.
در خصوص سوال دوم – بله میشه – یک راه غیر اصولی تعریف متغیر ها به شکل گلوبال هست که مشکلات خیلی زیادی ایجاد میکنه ولی راه اصولی هم وجود داره و اون هم استفاده از mailbox هست.
یعنی اطلاعاتی که باید در تسک دیگه ای قابل دسترسی باشند رو برای اون تسک با تعریف یک میل باکس ارسال کنید.

profile
احسان گفت :
۱۳۹۸-۱۱-۲۵ ۱۰:۳۵

سلام خسته نباشید
من میتونم از این کتابخونه برای esp8266 هم استفاده کنم؟؟؟

profile
زئوس Zeus گفت :
۱۳۹۸-۱۱-۳۰ ۱۲:۲۸

تا اونجایی که من اطلاع دارم پلتفرم آردوینو برای esp8266 از سیستم عامل استفاده نمیکنه !
و شما باید با sdk سیستم عامل دار خود شرکت استفاده کنید.

profile
موسوی گفت :
۱۳۹۸-۰۲-۰۲ ۲۲:۲۱

با سلام. یکی از بهترین، مفیدترین و کاربردی ترین مقالاتی بود که تا امروز خوندم. ازتون واقعا ممنونم.

profile
زئوس Zeus گفت :
۱۳۹۸-۰۲-۰۳ ۰۹:۱۳

خواهش میکنم دوست عزیز 🙂

profile
vali گفت :
۱۳۹۷-۰۱-۲۹ ۲۲:۳۰

با سلام.بابت مطلب مفیدتون ممنونم.فقط کمی در رابطه با stack size و اگر میشه یه کم برنامرو تحلیل کنید.کتشکرم

profile
زئوس Zeus گفت :
۱۳۹۷-۰۱-۳۰ ۱۱:۳۲

مفهوم استک ، همیشه مقداری گیج کننده بوده ، اما استک چست ؟ بذارید با یه مثال ساده مساله رو بازش کنم
اعمال افزودن و حذف در Stack را می‌توان مشابه وضعیت ظروف کثیفی در نظر گرفت که به منظور شسته شدن در آشپزخانه روی یکدیگر انباشته شده‌اند، عنصر (ظرف کثیف) جدید بر روی عناصر قبلی قرار می‌گیرد و هنگام حذف یک عنصر (برداشتن ظرف برای شسته شدن)، جدیدترین عنصری که به پشته اضافه شده است زودتر حذف می‌شود. از این رو به پشته، ساختمان داده‌ی LIFO نیز گفته می‌شود. دو کاربرد رایج از پشته‌ها در برنامه عبارتند از ارزیابی عبارات و فراخوانی توابع. به عنوان نمونه‌ای ملموس و ساده می‌توان گفت هنگام فراخوانی تابع، نام تابع همراه با پارامترهای آن به عنوان عنصری جدید وارد یک پشته می‌شوند. در صورتی که در این تابع، تابعی دیگر فراخوانی شود تابع دوم نیز به همین صورت وارد پشته می‌شود. به محض اینکه اجرای دستورات تابع دوم به پایان می‌رسد عمل Pop از پشته انجام می‌شود و تابع دوم از آن خارج می‌شود. به این ترتیب تابع کنونی که در حال اجراست همیشه در بالای این پشته قرار می‌گیرد.
میزان Stack هر تسک در هنگام تعریف آن قابل تنظیم است. ما در مثال ارائه شده به هر تسک 128 ورد (128*4 بایت) حافظه Stack اختصاص دادیم. که البته این مقادی با توجه به میزان فراخوانی توابع تو در تو و میزان حافظه مورد استفاده هر تابع متغیر باشد.
البته نباید محدودیت حافظه میکروکنترلر را فراموش کرد.

profile
امیرحسین مرادیان گفت :
۱۳۹۷-۱۱-۲۲ ۰۱:۱۷

سوال اول اینکه هرچی مقدار استک رو برای یه تسک بیشتر کنیم از حافظه ی فلش میکرومون بیشتر مصرف میشه؟
دوم اینکه من تو برنامم چنتا تسک مشخص کردم ک هرکدوم ب ترتیب کار
خوندن کلید های ورودی
نمایش روی ال سی دی
محاسبات زمانی (ثانیه رو کم کن صفر شد دقیقه رو کم کن و…)
خوندن مقدار سنسور رطوبت و دما
رو انجام میدن
حالا وقتی میخوام تسک جدید اضافه کنم برنامه اصلا ران نمیشه یعنی با تست های مختلف متوجه شدم حتی وارد ووید لوپ هم نمیشه چ برسه ب تسک ها
حال با تغیر استک میتونم بهترش کنم؟چطور؟
لطفا راجب استک مثال بزنید و سعی کنبد کمتر کلمات تصصی بکار ببرید تا دوستان بتونن بهتر استفاده کنن

profile
موسوی گفت :
۱۳۹۸-۰۲-۰۶ ۱۵:۳۷

والا این تسک های شما رو من روی STM32F103ZET6 می خواستم تست کنم، خطا داد چه برسه به AVR بد بخت.

profile
زئوس Zeus گفت :
۱۳۹۸-۰۲-۰۹ ۰۹:۳۵

این کد برای آردوینو مدل های Nano ؛ Uno تست شده و به خوبی کار میکنند ؛ شاید مشکل جای دیگه ای باشه !
شما از آردوینو استفاده میکنید ؟

profile
زئوس Zeus گفت :
۱۳۹۷-۱۱-۲۷ ۱۰:۵۵

اول – نه استک از حافظه RAM استفاده میکنه
دوم – میکروی شما چی هست و چند تا تسک دارید ؟ ؛ میدونید که تعریف هر تسک از حافظه رم مقداری رو بر میداره و اگر تسک ها تعدادشون بقدری زیاد بشه که از رم میکرو ؛ رم بیشتری لازم داشته بشه ؛ سیستم عامل اجرا نمیشه چون استک آورفلو اتفاق می افته.

profile
امیرحسین مرادیان گفت :
۱۳۹۷-۱۱-۳۰ ۱۱:۳۷

میکروی من اتمگا 328 هست (آردوینو یونو)
با اردوینو 2560 امتحان کردم مشکلی پیش نمیاد
چطور میشه محاسبه کرد چه مقدار فضا اشغال میکنه تا بشه فهمید چه میکرویی مناسبه؟
چطور میشه یه برنامه شبیه همین سیستم عاما فری ار تی او اس نوشت که کاراهارو موازی انجام بده؟

profile
امیرحسین مرادیان گفت :
۱۳۹۶-۱۲-۰۵ ۰۱:۴۱

میشه توضیح بفرمایید که اولویت هارو چطور تغیر بدیم و ب چ نحوی کار میکنه؟من این کتابخونه free rtos رو نصب کردم چارتا task مشخص کردم میخوام بدونم چ فرقی داره اگه priority هارو دستکاری کنم؟

profile
زئوس Zeus گفت :
۱۳۹۶-۱۲-۲۶ ۱۲:۴۴

تو همون قسمت Setup که تسک ها تعریف میشن میشه الویت ها رو تعیین کرد. که الان مقدار 1 و 2 رو دارن ، هرچی عدد بیشتر بشه اولویت اون تسک هم بیشتر میشه
اگر منظورتون تغییر در حین اجراست میتونید با تابع vTaskPrioritySet اولویت تسک مورد نظرتون رو تغییر بدید.

become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله
become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله