دیباگر یکی از ابزارهایی است که درجه اهمیت آن برای یک برنامه نویس مانند نون شب است. این تیتری است که در ابتدای این آموزش تا پایان آن باید به خاطر بسپارید. برای اینکه بتوانید نهایت استفاده را از یک دیباگر داشته باشید، داشتن دانش عمیق در رابطه با برنامه نویسی اسمبلی، معماری های حافظه و … ضروری و مفید است. این قسمت یکی از کوتاه ترین قسمت های این سری آموزشی است.
چرا که قراره با دیباگر در یک کامپیوتر با معماری سی پی یو 64 بیتی و در محیط سیستم عامل لینوکس آشنا شویم و از آنجا که این محیط ،دریایی وسیع و عمیق از مفاهیمی کامپیوتری است که اشاره شد و هدف ما از معرفی دیباگر، استفاده از آن برای میکروکنترلرهاست تنها نگاهی اجمالی به دیباگر GDB در این محیط می اندازیم و در قسمت های بعدی به شرح کامل تری از آن در استفاده برای میکروکنترلرها می پردازیم. با سیسوگ همراه باشید.
این مقاله قسمت سوم از سری آموزشی آموزش RTOS در STM32 می باشد. شما می توانید کلیه دوره های آموزش RTOS را در سیسوگ مشاهده نمایید.
و اما تعریف GDB از زبان پروژه GNU:
GDB یا GNU Debugger ابزاری است که امکاناتی در اختیار شما قرار می دهد تا بتوانید ببینید درون برنامه تان چه اتفاقی میفتد یا در حین ایجاد یک مشکل در کدتان، کد چگونه عکس العمل نشان می دهد. GDB از طریق متوقف کردن برنامه در لحظات مشخص و همچنین شروع برنامه از نقاط مشخص به شما در پیدا کردن اشکال های برنامه تان کمک می کند.
حالا که با هدف تولید GDB آشنا شدیم، می توانیم کار کردن با آن را شروع کنیم:
1 | sudo apt install gdb |
و برای مطمئن شدن از نصب GDB به صورت زیر عمل می کنیم:
1 | gdb -v |
تا به اینجا دو تا خبر دارم، خبر خوب اینه که gdb نصب شد اما خبر بد اینه که کار کردن با gdb در محیط ترمینال خیلی جالب نیس و به همین دلیل در قسمت های بعدی خواهیم دید که از این دیباگر در IDE هایی مثل Eclips استفاده خواهیم کرد. اما برای اینکه در این قسمت بتوانیم یک خاطره نسبتا خوب از کار با gdb در محیط ترمینال ثبت کنیم، از یک اکستنشن کاربردی برای شکیل تر کردن ظاهر gdb در ترمینال استفاده می کنیم. نام این اکستنشن gdb-dashboard است که از اینجا می توانید آن را دانلود و استفاده کنید.
حالا باید در حین کامپایل برنامه پارامتر دیباگ را به برنامه اضافه کنیم اما چطور؟
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | CFileDir := src src2 cfiles := $(foreach dir,$(CFileDir),$(wildcard $(dir)/*.c)) objects := $(foreach dir,$(CFileDir),$(patsubst $(dir)/%.c,object/%.o,\ $(filter pattern $(dir)/%.c,$(cfiles)))) vpath %.c $(CFileDir) vpath %.h ./header output : $(objects) gcc $^ -o $@ object/%.o : %.c math.h gcc -g -c -I ./header $< -o $@ #test : # $(info $(cfiles)) # $(info $(objects)) clean : rm -f $(objects) output .PHONY : clean test |
Makefile بالا همان فایلی است که در قسمت های قبلی آن را نوشتیم. همانطور که می بینید در خط زیر پارامتر دیباگ را به فرایند کامپایل برنامه اضافه کرده ایم:
1 | gcc -g -c -I ./header $< -o $@ |
پس از کامپایل برنامه برای دیباگ آن به شیوه زیر عمل می کنیم:
1 | gdb output |
پس از اجرای دستور بالا با یک صفحه سیاه و کلی توضیح و البته یک مکان نمای چشمک زن رو به رو می شوید که خبر خوبی است و این یعنی که ما می توانیم دستورات GDB را در این محل وارد کنیم.
آموزش امبدد لینوکس از مقدماتی تا پیشرفته + پروژه
سه دستور بالا دستورات ورود و خروج به محیط دیباگ برنامه هستند و اما دستوراتی که دلیل استفاده از دیباگر هستند:
سه دستور بالا نیز دستوراتی برای حرکت گام به گام در برنامه بودند اما گاهی اوقات ما قصد توقف برنامه در یک نقطه خاص یا شروع برنامه از یک نقطه مشخص را داریم، در این صورت از دستورات زیر استفاده می کنیم:
1 2 3 | Break main.c:10 b main.c:10 Break 10 |
همانطور که در دستور بالا می بینید می توانید نام فایل موردنظر و شماره خطی که میخواهید برنامه در آن نقطه متوقف شود را، برای ایجاد یک breakpoint استفاده کنید یا تنها شماره خط را استفاده کنید که در این صورت breakpoint در فایل جاری ایجاد می شود.
برای حذف breakpoint های ایجاد شده نیز از دو راه زیر می توانید استفاده کنید:
1 2 | Clear main.c:10 Clear |
شاید براتون سوال شده باشه که پس از ایجاد یک breakpoint با کدام دستور برنامه را به حالت اجرا تا زمان رسیدن به breakpoint در بیاورم؟ جواب اینجاست:
دستورات زیر هم اطلاعاتی در مورد متغیر های local یا global برنامه، breakpoint های ایجاد شده و … به ما ارائه می دهد:
خب این قسمت های به بخش پایانی خودش رسید. در این قسمت سعی شد به طور اجمالی شما را با دیباگر رایگان و قدرتمند gdb یکی دیگر از محصولات محبوب پروژه gnu آشنا کنیم. در قسمت بعد برنامه نویسی به روشی عمیق برای میکروکنترلرهای cortex m رو شروع خواهیم کرد و قراره کارهای خیلی جذابی انجام بدیم.
در ضمن قسمت نظرات هم خیلی خلوته و بالا بودن انرژی مطالب نظرات شما بزرگواران خواننده رو می طلبه.
دوره خیلی عالی هست ولی حیف که دیر به دیر منتشر میشه قسمت هاش
سلام
ممنون از زحمتی که برای آموزش کشیدین
من با کیل کار کردم این امکانات که توضیح دادین اونجا سر جمع و بی درد سر در دسترس بود متوجه نمی شم چرا باید از این روش بریم
منتظر آموزش خود قضیه rtos هستم
ممنون
سلام
نکته ای که هست اینه که برای اینکه ما بتونیم یک سیستم عامل روی میکروکنترلر پیاده سازی کینم باید درک خوبی از میکروکنترلر و نحوه برنامه نویسی برای اون داشته باشیم و زمانی به این درک می رسیم که بدونیم دقیقا کامپایلر یا دیباگر یا … چطوری کار میکنند.
در قسمت صفرم آموزش هم به این موضوع اشاره شده و دلیل اینکه چرا از کیل استفاده نمی کنیم رو هم می تونید از لینک زیر مطالعه کنید.
مقایسه تخصصی کامپایلر کیل و GCC
از قسمت آینده برنامه نویسی برای میکروکنترلرها رو شروع میکنیم و خودتون متوجه این موضوع میشید.
سلام
GDB قابلیت اجرا در stm cube IDE را دارد؟
سلام بله.
stm32cubeide به صورت پیش فرض از دیباگر gdb برای دیباگ برنامه استفاده می کنه که میتونید از قسمت Debug Configurations این موضوع رو ببینید.
خیلی جالب شد!!
ویژگی چاپ متغیر محلی خیلی کاربردی است.
این ویژگی در کیل با بریک پوینت و پنجره واتچ یا دستور printf امکان پذیره.
سوال منم همین جاست که آیا به بریک پوینت نیازه یا از منابع خود میکرو همانند prtintf استفاده میکنه؟
سپاس
سلام
سوالتون رو درست متوجه نشدم اما
به طور کلی هسته های cortexm دارای امکاناتی هستند که می توانند از طریق درگاه SWD یا JTAG اطلاعات مورد نیاز برای دیباگ برنامه مثل مقدار متغیرها و … رو با کامپیوتر ردوبدل کنند. بنابراین اگر منظور شما از printf استفاده از uart برای دیباگ برنامه ست نیازی به این کار نیست. در مورد بریک پوینت هم باید بگم که شما در هر کجا از برنامه که اجرا رو متوقف کنید می تونید متغیرهای local همون قسمت و متغیرهای global برنامه رو آنالیز کنید. در همین راستا بریک پوینت به عنوان یکی از ویژگی های هر دیباگری برنامه رو در نقطه خاصی از اجرا متوقف میکنه.
امیدوارم که پاسخ سوالتون رو گرفته باشید و اگر هنوز ابهامی مونده در مورد اینکه یک دیباگر مثل GDB چطور برنامه روی میکروکنترلر رو دیباگ میکنه در قسمت آینده با مثال عملی توضیح داده میشه.
نویسنده شو !
سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.