بیت Carry یکی از بیت های رجیستر STATUS یا رجیستر شماره 0x03 می باشد. این رجیستر مربوط به وضعیت CPU می باشد. مثل این که حاصل محاسبه ای صفر شده است یا نه و…
بیت مربوط به carry یا حمل کننده یک بیت برای ذخیره مقدار های مربوط به RRF و RLF می باشد.
این متغیر مقدار های 0 یا 1 را ذخیره می کند. و بعد از استفاده از RRF و RLF به روز می شود.
دستور ADDWF دو مقدار را دریافت میکند، اولی مربوط به آدرس داده شده و دومی مربوط به فاصله (destination) می باشد.
وظیفه این دستور اضافه کردن مقدار رجیستر W به مقدار آدرس داده شده می باشد. اگر فاصله یا d برابر با 0 (یا F) بود نتیجه نهایی در رجیستر W میماند، در غیر این صورت اگر مقدار d برابر با 1 (یا W) بود مقدار در رجیستر داده شده ذخیره می شود.
اگر نتیجه محاسبه بیشتر از 255 باشد (از 8 بیت بیشتر) نتیجه برابر با 0 می شود.
این دستور نیز مانند دستور ADDWF دو مقدار آدرس (f) و فاصله (destination) را دریافت می کند.
این دستور مقدار رجیستر W را با مقدار رجیستر f (داده شده) را به صورت AND (&) محاسبه میکند، در صورتی که مقدار d برابر با 0 (یا F) بود نتیجه در رجیستر W ذخیره می شود، در غیر این صورت اگر مقدار برابر با 1 (یا W) بود، نتیجه در آدرس داده شده ذخیره می شود.
این دستور نیز همانند دستور های قبلی دو مقدار آدرس (f) و فاصله (d) را دریافت میکند.
عملکرد این دستور به این صورت است که بخش های 0 تبدیل به 1 می شوند و بخش های 1 در باینری تبدیل به 0 می شوند. برای مثال اگر مقدار باینری برابر با 0b00001111 باشد بعد از عملیات complement (~) مقدار برابر با 0b11110000 میشود.
اگر مقدار d برابر با 0 (یا F) بود نتیجه در رجیستر W ذخیره می شود در غیر این صورت اگر مقدار برابر با 1 (یا W) بود، نتیجه در آدرس داده شده ذخیره میشود.
دستور دارای دو مقدار f برای آدرس و d برای فاصله (destination) می باشد.
وظیفه این دستور این است که بین مقدار آدرس داده شده و رجیستر W عملیات OR (|) را اجرا کند.
اگر مقدار d برابر با 0 (یا F) بود نتیجه در رجیستر W در غیر این صورت اگر مقدار d برابر با 1 (یا W) بود نتیجه در آدرس داده شده ذخیره میشود.
وظیفه این دستور به این صورت می باشد که تمامی بیت های آدرس داده شده را یکی به سمت چپ حرکت می دهد و مقدار اولین بیت از سمت چپ به Carry داده می شود و مقدار قبلی مربوط به Carry در اولین بیت از سمت راست قرار میگیرد.
عملکرد این دستور شبیه به دستور shift در زبان C می باشد (>>).
اگر مقدار d برابر با 0 (یا F) بود نتیجه در رجیستر W در غیر این صورت اگر مقدار d برابر با 1 (یا W) بود نتیجه در آدرس داده شده ذخیره میشود.
کد دستوری مربوط به این دستور به صورت زیر می باشد:
این دستور همانند دستور قبلی یعنی RLF می باشد، با این تفاوت که در این دستور حرکت به سمت راست می باشد.
تمامی بیت های آدرس داده شده یکی به سمت راست حرکت می کنند و اولین بیت از چپ بر روی مقدار Carry قرار داده می شود و مقدار قبلی مربوط به Carry در اولین بیت از سمت راست قرار میگیرد.
این دستور عملکردی مشابه با (<<) در زبان C دارد.
اگر مقدار d برابر با 0 (یا F) بود نتیجه در رجیستر W در غیر این صورت اگر مقدار d برابر با 1 (یا W) بود نتیجه در آدرس داده شده ذخیره میشود.
کد دستوری مربوط به این دستور به صورت زیر می باشد:
حالا که دستور های مربوطه را توضیح دادیم زمان آپدیت کردن کد های مربوط به CPU می باشد.
کدهای جدید مربوط به تابع decode_inst به صورت زیر می باشد:
بعد از تشخیص کد با تابع decode_inst حالا بخش های مربوط به اجرای دستور ها را به تابع execute اضافه می کنیم:
در این بخش توابع rotate_right_carry و rotate_left_carry مربوط به shift و دو دستور RRF و RLF می باشند و به صورت زیر تعریف می شوند:
توابع set_carry و get_carry که مربوط به آپدیت کردن بیت carry در رجیستر STATUS هستند.
و دو تابع clear_sfr_bit و set_sfr_bit مربوط به SFR هستند.
وظیفه این توابع روشن/خاموش کردن (صفر و یک کردن) بیت های مشخص شده در رجیستر های داده شده هستند.
و کار تابع set_z_bit مربوط به بیت شماره دوم (شروع از صفر) رجیستر STATUS است که زمانی برابر با 1 می شود که حاصل محاسبه ای (انجام شده در رجیستر W) برابر با 0 باشد، در غیر این صورت مقدار این بیت برابر با 0 می شود.
در کد زیر به نوشتن حلقه for در assembly می پردازیم:
نویسنده شو !
سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.