

دانشکده مهندسی کامپیوتر دانشگاه صنعتی امیرکبیر

هسته پردازنده مرکزی

در میکروکنترلر ATmega16

#### فهرست مطالب

- هسته پردازنده مرکزی میکروکنترلر ATmega16
  - حافظه پشته و ثبات اشاره گر به پشته
    - ثبات وضعیت
    - فایل ثبات همه منظوره
      - واحد ALU
    - و زمانبندی اجرای دستورالعمل ها
      - بازنشانی و کنترل وقفه ها

• وظیفه اصلی هسته واحد پردازشگر مرکزی در این میکروکنترلر <mark>تضمین اجرای صحیح برنامه ا</mark>ست.

• بنابراین واحد پردازشگر مرکزی میبایست قادر باشد که به حافظهها دسترسی داشته، محاسبات را انجام دهد، اجزاء مختلف میکروکنترلر را کنترل کند و قفهها را مدیریت کند.



دیاگرام بلوکی معماری میکروکنترلر ATmegal6

- میکروکنترلر ATmega16 از معماری <mark>هاروارد</mark> با <mark>حافظههای جداگانه و گذرگاه های متفاوت برای برنامه و داده ا</mark>ستفاده میکند.
- هنگامی که یک دستورالعمل اجراء میشود، دستورالعمل بعدی از حافظه برنامه پیشواکشی میشود.
- این مفهوم موجب میشود که بتوان هر دستورالعمل را در یک پالس ساعت اجراء نمود. حافظه برنامه از نوع حافظه فلش با قابلیت برنامهریزی درون سیستمی است.

- فایل ثبات با امکان دسترسی سریع، شامل <mark>۳۲ ثبات ۸ بیتی همه منظوره</mark> با امکان دسترسی در یک چرخه ساعت است.
  - این مهم امکان <mark>اجرای عملیات ALU در تنها یک چرخه ساعت را فراهم می سازد.</mark>
- در یک عملیات ALU نمونه، در یک چرخه ساعت، دو عملوند از فایل ثبات خارج شده، عملیات روی آنها اجرا و نتیجه در فایل ثبات ذخیره می شود.

- جریان اجرای برنامه توسط پرشهای شرطی و غیرشرطی و دستورالعملهای صدازدن زیرروالها برقرار میشود. این مهم باعث میشود که مستقیما بتوان به تمام فضای حافظه دسترسی داشت.
  - اغلب دستورالعملهای ATmega16 دارای یک قالب کلمه ۱۶بیتی هستند.
  - هر آدرس مربوط به حافظه برنامه شامل یک دستورالعمل ۱۶ و یا ۳۲ بیتی است.

• فضای حافظه برنامه فِلَش به دو قسمت شامل قسمت <mark>برنامه راهانداز و قسمت برنامه کاربردی</mark> تقسیم میشود.

- هر دو قسمت دارای <mark>بیتهای قفل </mark>برای محافظت نسبت به نوشتن و خواندن هستند.
- دستورالمل SPM که امکان نوشتن در قسمت برنامه کاربردی حافظه فِلَش را فراهم می کند<mark>، باید در قسمت برنامه راهانداز قرار داشته باشد.</mark>

- ثبات وضعیت اطلاعاتی در خصوص نتیجه آخرین عملیات محاسباتی اجرا شده را در خود نگه میدارد.
  - این اطلاعات می توانند در جریان برنامه در دستورات شرطی استفاده شوند.
- لازم بذکر است که ثبات وضعیت هنگام ورود به روال وقفه ذخیره و یا هنگام خروج از آن بطور اتوماتیک بازیابی نمی شود و اینکار باید توسط نرمافزار انجام شود.

ثبات وضعیت

| Bit           | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---------------|-----|-----|-----|-----|-----|-----|-----|-----|
|               |     | T   | Н   | S   | V   | N   | Z   | С   |
| Read/Write    | R/W |
| Initial ∀alue | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

SREG

# بیت ۷<mark>،بیت I</mark> (بیت <mark>فعالسازی وقفه):</mark>

- برای فراهم ساختن <mark>امکان پذیرش وقفهها </mark>میبایست این بیت را فعال نمود.
  - اگر این بیت غیر فعال شود هیچ وقفهای پذیرفته نخواهد شد.
- بعد از وقوع هر وقفه، این بیت بطور خودکار صفر میشود و پس از اجرای دستورالعمل RETI، دوباره فعال میشود تا امکان پذیرش وقفههای بعدی فراهم گردد.
  - این بیت می تواند مستقیما توسط دستورالعملهای SEI و CLI فعال و غیرفعال شود.

#### بیت ۶، بیت 🏗

- دستورالعملهای (Bit LoaD) (BST) (Bit Store) و (BST) (Bit Store) این بیت را به عنوان مقصد و مبداء برای بیتی که عملیات روی آن انجام گرفته بکار میبرند.
- یک بیت از یک ثبات در مجموعه ثباتهای عمومی همه منظوره میتواند توسط دستورالعمل BST به درون بیت T کپی شود.

BST Rd, b T ← Rr(b) Bit Store from Register to T

•یک بیت در T میتواند توسط دستورالعمل BLD در یک بیت در یک ثبات در مجموعه ثباتهای عمومی کپی شود.

#### بیت ۵، بیت Hیا بیت نیمه نقلی (Half Carry):

• این بیت نشاندهنده رخداد یک نیمه توازن (۲ بر یک ایجاد شده بعد از بیت چهارم) در بعضی از عملیاتهای محاسباتی است.

• این بیت برای عملیاتهای بیسیدی مفید است.

### بیت ۴، بیت <mark>S</mark>یا بیت <mark>علامت:</mark>

این بیت بیانگر <mark>یاء مانع جمع بین پرچمهای N و V</mark> میباشد.

#### بیت ۳، بیت <mark>۷</mark> یا <mark>سرریز:</mark>

این بیت، سرریز را در عملیات محاسباتی <mark>مکمل ۲</mark> پشتیبانی می کند.

# 

این بیت منفی بودن نتیجه عملیات محاسباتی یا منطقی را نشان میدهد.

#### 

•این بیت نشاندهنده صفر شدن نتیجه یک عملیات محاسباتی و یا منطقی است.

#### بیت ۰، بیت <mark>C</mark> یا بیت <mark>نقلی:</mark>

•این بیت نشان دهنده رخداد بیت نقلی (۲ بر یک بعد از بیت هشتم) در عملیاتهای محاسباتی و یا منطقی است.

# فایل ثبات همه منظوره

• مجموعه ثباتهای عمومی برای اجرای دستورالعملهای RISC تقویتشده میکروکنترلرهای AVR بهینه شده است.

• واحد محاسباتی-منطقی عملیات منطقی و محاسباتی را بین ثباتهای عمومی و یا بین ثبات و یک مقدار ثابت پشتیبانی مینماید.

• عملیات سادهی تکثباتی نیز در ALU انجام می گیرد.

### فایل ثبات همه منظوره

این ثباتها با شمارههای <mark>R1 الی R32</mark> در شکل زیر دیده میشوند:

ساختار مجموعه ثباتهای عمومی همه منظوره

General Purpose Working Registers

| 7   | 0   | Addr. |                      |
|-----|-----|-------|----------------------|
| F   | 10  | \$00  |                      |
| F   | 11  | \$01  |                      |
| F   | 12  | \$02  |                      |
|     |     |       |                      |
| R   | 13  | \$0D  |                      |
| R   | 14  | \$0E  |                      |
| R   | 15  | \$0F  |                      |
| R   | 16  | \$10  |                      |
| R   | 17  | \$11  |                      |
|     |     |       |                      |
| R   | 26  | \$1A  | X-register Low Byte  |
| R   | 27  | \$1B  | X-register High Byte |
| R28 |     | \$1C  | Y-register Low Byte  |
| R   | R29 |       | Y-register High Byte |
| R   | 30  | \$1E  | Z-register Low Byte  |
| R   | 31  | \$1F  | Z-register High Byte |
|     |     | •     |                      |

### فایل ثبات همه منظوره

- اغلب دستورالعملهایی که روی ثباتهای عمومی انجام میشوند، به تمام ثباتها دسترسی مستقیم داشته و اغلب آنها دستورالعملهایی هستند که در یک چرخه ساعت انجام میشوند.
- به هر ثبات یک آدرس در فضای حافظه داده اختصاص داده شده است که موجب می شود این ثباتها مستقیما به اولین ۳۲ محل در فضای حافظه داده کاربر تصویر شوند.
- •چون این ثباتها در درون واحد پردازشگر مرکزی قرار دارند و بطور فیزیکی در فضای SRAM پیادهسازی نشدهاند، این ساختار حافظه انعطاف و سرعت بالایی را در دسترسی به ثباتها فراهم میکند.
- •واحد محاسبات و منطق ALU، بطور مستقیم با تمام ۳۲ ثبات مجموعه ثباتهای عمومی همه منظوره در ارتباط است.

# فایل ثبات همه منظوره، ثبات های Y ،X و Z

- ۶ ثبات از بین ۳۲ ثبات مجموعه ثباتهای عمومی یعنی ثبات های R26 تا R31 به عنوان ۳ جفت ثبات ۱۶بیتی هستند که به صورت اشاره گر برای آدرسدهی غیرمستقیم فضای داده استفاده میشوند.
  - این ثباتها موجب کارایی بیشتر در محاسبات آدرس میشوند.
- یکی از این ۳ اشاره گر به منظور اشاره گر آدرس برای مراجعه به جداول جستجو استفاده میشود.
  - این ثباتهای عملیاتی ۱۶ بیتی به نام X و Y و Z نام گذاری شدهاند.

### فایل ثبات همه منظوره، ثبات های Y ،X و Z

شکلهای زیر این ثباتها و موقعیت آنها را در مجموعه ثباتهای عمومی همهمنظوره نشان میدهند



Zو Y، Xو و X

#### واحد ALU

• عملیاتهای واحد ALU به سه دسته اصلی شامل عملیات <mark>ریاضی، منطقی</mark> و عملیات روی <mark>بیته</mark>ا تقسیم میشوند.

• بعضی از انواع میکروکنترلرهای ATmega16، یک ضربکننده با امکان انجام ضرب علامتدار و بدون علامت را پشتیبانی میکنند.

#### واحد ALU

• دسترسی تمامی دستورالعملهای مربوط به <mark>عملیات بین ثباتها </mark>به صورت <mark>مستقیم و</mark> در تنها یک چرخه دستورالعمل انجام میشود.

در این بین ۵ دستورالعمل محاسباتی- منطقی استثنا میباشند. این دستورالعملها ORI هستند که عملیات را بین مقادیر ثابت و ثباتها انجام SBCI، CPI ،SUBI ،SBCI مىدھند.

• استثناء دیگر دستورالعمل LDI است که به منظو<mark>ر بارکردن بیدرنگ مقادیر ثابت </mark>بهکار

این دستور العمل ها برروی نیمه دوم ثباتها (R16...R31) در مجموعه ثباتهای عمومی اجرا میشوند.

•دستورالعملهای AND ،CP ،SUB ،SBC و تمامی دیگر <mark>دستوالعملها که مابین</mark> <mark>دو ثبات و یا یک ثبات</mark> انجام می شوند، برروی <mark>تمام ثباتهای عمومی (R0...R31)</mark> اجرا می گردند.

- چند اسلاید بعد مفاهیم زمانبندی دسترسی عمومی را برای اجرای دستورالعمل ها ارائه مینماید.
  - میکروکنترلر ATmega16 توسط مولد ساعت راهاندازی میشود.
- این ساعت مستقیما از منبع ساعت تراشه تامین میشود. هیچگونه تقسیم در ساعت داخلی صورت نمی گیرد.

 شکل زیر چگونگی انجام واکشی و اجرای موازی دستورالعملها را منطبق بر معماری هاروارد و مفهوم فایل ثبات با دسترسی سریع نشان میدهد.

• این مفهوم اساسی معماری خط لوله برای دستیابی به سرعت ۱ میلیون دستورالعمل در ثانیه بازاء سیگنال ساعت ۱ مگاهرتز است.



• شکل زیر مفهوم زمانبندی داخلی برای فایل ثبات را نشان میدهد.



واكشى موازى دستورالعملها و اجراى دستورالعملها

• یک عملیات ALU با استفاده از دو عملوند ثباتی در یک چرخه ساعت اجراء و نتایج در ثبات مقصد ذخیره میشود.

• این بدین معنی است که در طول یک چرخه ساعت واحد، یک عملیات توسط ALU انجام می گیرد که شامل خارج شدن دو عملوند از مجموعه ثباتهای عمومی، انجام عملیات در درون ALU بر روی عملوندها و نهایتا ذخیره نتیجه در درون مجموعه ثباتهای عمومی می باشد.

# فضای حافظه I/O

• فضای حافظه I/O، شامل ۶۴ آدرس برای عملیاتهای مرتبط با ماژولهای داخلی میکروکنترلر و ثباتهای کنترلی آنهاست.

• حافظه I/O می تواند مستقیما مورد دسترسی قرار گیرد و یا به عنوان محلهای داده که بعد از فایل ثبات قرار دارند محسوب شود (محدوده 5F - 20) .

#### حافظه داده SRAM، فایل ثبات و حافظه I/O

| Register File | Data Address Space |
|---------------|--------------------|
| R0            | \$0000             |
| R1            | \$0001             |
| R2            | \$0002             |
|               |                    |
| R29           | \$001D             |
| R30           | \$001E             |
| R31           | \$001F             |
| I/O Registers |                    |
| \$00          | \$0020             |
| \$01          | \$0021             |
| \$02          | \$0022             |
|               |                    |
| \$3D          | \$005D             |
| \$3E          | \$005E             |
| \$3F          | \$005F             |
|               | Internal SRAM      |

• شکل مقابل نشان دهنده سازمان حافظه SRAM میکروکنترلر ATmega16 می باشد.

• فایل ثبات، حافظه I/O و حافظه داده SRAM داره I/O داخلی همگی در ۱۱۲۰ مکان پائین حافظه داده قرار دارند.

• اولین ۹۶ محل در حافظه داده فایل ثبات و حافظه I/O را آدرسدهی می کنند.

• ۱۰۲۴ مکان بعدی حافظه داده SRAMرا آدرس دهی می کنند.

فضای حافظه داده و ثباتهای عمومی همه منظوره

\$0061

# پشته و اشاره گر پشته

- اشاره گر پشته قابل دسترسی بصورت نوشتنی *اخ*واندنی در فضای I/O هستند.
- پشته در حافظه SRAM قرار دارد و در نتیجه اندازه پشته به اندازه SRAM و مقداری از آن که به عنوان پشته در نظر گرفته شده است، بستگی دارد.
- حافظه پشته برای <mark>ذخیره داده های موقتی، آدرس بازگشت از زیرروال</mark> و بازگشت از سرویس وقفه استفاده می شود.
- حافظه پشته میتواند از بزرگترین آدرس حافظه داده SRAM شروع شده و به آدرس های کوچکتر ادامه یابد.

- هنگامی که وقفهای اتفاق میافتد و یا فراخوانی یک زیرروال صورت میگیرد، مقدار آدرس بازگشت موجود در شمارنده برنامه (PC) در پشته ذخیره میشود.
- پشته عملا در حافظه داده عمومی SRAM قرار دارد و در نتیجه اندازه پشته به اندازه کل SRAM و سایر کاربردهای آن محدود می شود.
- کلیه برنامه های کاربر باید اشاره گر پشته را در روال بازنشانی و قبل از اجرای هر زیر روال یا وقفه مقداردهی اولیه کنند.

# حافظه پشته و ثبات اشاره گر به پشته

• اشاره گر ۱۶ بیتی پشته که همیشه به بالای پشته اشاره می کند، قابل خواندن و نوشتن است و در فضای ورودی/خروجی قرار دارد.

• در میکروکنترلر ATmega16، اشاره گر پشته باید <mark>بالای آدرس \$60 (بعد از فضای I/O)</mark> باشد.

•شکل زیر اشاره گر پشته را نشان میدهد:

| Bit           | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   |     |
|---------------|------|------|------|------|------|------|-----|-----|-----|
|               | SP15 | SP14 | SP13 | SP12 | SP11 | SP10 | SP9 | SP8 | SPH |
|               | SP7  | SP6  | SP5  | SP4  | SP3  | SP2  | SP1 | SP0 | SPL |
|               | 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |     |
| Read/Write    | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W | R/W |     |
|               | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W | R/W |     |
| Initial Value | 0    | 0    | 0    | 0    | 0    | 0    | 0   | 0   |     |
|               | 0    | 0    | 0    | 0    | 0    | 0    | 0   | 0   |     |

#### حافظه داده SRAM، فایل ثبات و حافظه

| Register File | Data Address Space |
|---------------|--------------------|
| R0            | \$0000             |
| R1            | \$0001             |
| R2            | \$0002             |
|               |                    |
| R29           | \$001D             |
| R30           | \$001E             |
| R31           | \$001F             |
| I/O Registers |                    |
| \$00          | \$0020             |
| \$01          | \$0021             |
| \$02          | \$0022             |
|               |                    |
| \$3D          | \$005D             |
| \$3E          | \$005E             |
| \$3F          | \$005F             |
|               | Internal SRAM      |

• شكل مقابل نشان دهنده سازمان حافظه SRAM ميكروكنترلر ATmega16 مي باشد.

• اشاره گر پشته باید بالای آدرس 560 (بعد از فضای I/O) در بخشی در ۱۰۲۴ آخر حافظه داده واقع شود.

فضای حافظه داده و ثباتهای عمومی همه منظوره

\$0060 \$0061

\$045E \$045F