

# **Pentium Pro ISS Modeling in C++**

## **Using SystemC Library**

Amirhossein Yousefvand

September 2023

Electrical and Computer Engineering Faculty

University of Tehran



## Table of contents

|                                      |    |
|--------------------------------------|----|
| Introduction -----                   | 3  |
| CPU Architecture -----               | 4  |
| Instruction Set Description-----     | 7  |
| SystemC Modeling of Pentium Pro----- | 12 |

## 1- Introduction



The Sixth-Generation Pentium Pro (P6) Processor is an x86 series microprocessor developed by Intel and introduced in November 1995. This single-core processor featured a higher transistor count and a newer microarchitecture compared to its predecessors. Improvements included enhanced pipelining and the utilization of techniques like register renaming. The Pentium Pro was primarily used in servers and high-performance computing systems, notably in the ASCI Red supercomputer.

The objective of this project is to create a system-level model of this processor using the SystemC library within the C++ programming language. This approach involves developing a high-level, software-based description of the hardware to facilitate a deeper understanding of its operation. By creating a software model, potential challenges for the hardware design team can be identified, offering new perspectives on problem-solving. Ultimately, the modeled processor will be capable of interfacing with a PCH unit, and its software modeling will allow for extensive testing and improved coordination between the design teams of these two components.

Given the sequential nature of programming languages, a platform capable of supporting the capabilities of Hardware Description Languages (HDLs) is required. The SystemC library provides the necessary framework for parallel and concurrent code execution. This report details the various stages of the system-level processor design and the associated C++ code.

## 2- CPU Architecture



To model a processor, one must first have a precise understanding of its structure. This structure includes system registers, processor-bus interactions, and more. *Note: This report assumes that the processor is operating in 32-bit mode.*

## 2-1- Registers

In the 32-bit architecture of Intel processors (IA-32), there are 16 registers used for executing programs and system activities. These registers are divided into four types.



Figure 2-1-registers Pentium Pro

## 2-2- General-Purpose Registers



Eight 32-bit registers store operands and pointers. As shown in Figure 2-2, in different processor modes, the slices of each register will have new names. However, as mentioned earlier, we will focus on the 32-bit mode.

| General-Purpose Registers |    |    |    |    |   |        |        |
|---------------------------|----|----|----|----|---|--------|--------|
| 31                        | 16 | 15 | 8  | 7  | 0 | 16-bit | 32-bit |
|                           |    |    | AH | AL |   | AX     | EAX    |
|                           |    |    | BH | BL |   | BX     | EBX    |
|                           |    |    | CH | CL |   | CX     | ECX    |
|                           |    |    | DH | DL |   | DX     | EDX    |
|                           |    |    |    | BP |   |        | EBP    |
|                           |    |    |    | SI |   |        | ESI    |
|                           |    |    |    | DI |   |        | EDI    |
|                           |    |    |    | SP |   |        | ESP    |

Figure 2-2 General-Purpose Registers

## 2-3- Segment Registers

Six 16-bit registers store segment selectors. These registers are used for addressing different memory segments.



Figure 2-3- Segment Register

## 2-4- EFLAGS Register



One 32-bit register in which the necessary system flags are stored. This register initially has the value 00000002H. Bits 1, 3, 5, 15, and 22 to 31 are pre-allocated and should not be modified by software.



Figure 2-4- EFLAGS Register

## 2-5- EIP Register

A 32-bit register that stores the pointer to the next instruction. This register is not directly controlled by software; instead, it is implicitly controlled by control transfer instructions, interrupts, and exceptions.

## 3- Instruction Set Description



Given that the Pentium Pro processor is a type of CISC processor, its instruction lengths can vary from 1 to 15 bytes. Each instruction can include 1 to 6 main sections, with the presence of the Opcode section being mandatory for all instructions.



Figure 3-1- Instruction format

## 3-1- Instruction Prefixes

The first part of an instruction can be a prefix. Prefixes include four groups, which we will not implement at this stage of the project.

## 3-2- Opcode

The Opcode section exists in all instructions and can range from 1 to 3 bytes. As shown in Figure 3-2-1, bits 5 to 3 of the ModR/M section can be used as auxiliary bits of the Opcode section. In Figure 3-2-1, one-byte OpCodes are presented, with 4 bits representing the high-value Opcode of the row in the table and 4 bits representing the low-value Opcode of the column in the table. The red square in the table indicates the Opcode, which, when observed, indicates that the length of the Opcode will be more than one byte.



Opcode[3:0]



Opcode[7:4]

| One-byte Opcode Map: (00H – F7H) * |                                                                 |                                             |                               |                              |                               |                           |                           | One-byte Opcode Map: (08H – FFH) * |                                                               |                              |               |                                |                               |                |                             |                                                                 |         |
|------------------------------------|-----------------------------------------------------------------|---------------------------------------------|-------------------------------|------------------------------|-------------------------------|---------------------------|---------------------------|------------------------------------|---------------------------------------------------------------|------------------------------|---------------|--------------------------------|-------------------------------|----------------|-----------------------------|-----------------------------------------------------------------|---------|
|                                    | 0                                                               | 1                                           | 2                             | 3                            | 4                             | 5                         | 6                         | 7                                  | 8                                                             | 9                            | A             | B                              | C                             | D              | E                           | F                                                               |         |
| 0                                  | Eb, Gb                                                          | Ev, Gv                                      | Gb, Eb                        | Gv, Ev                       | AL, Ib                        | rAX, Iz                   | PUSH ES <sup>64</sup>     | POP ES <sup>64</sup>               | Eb, Gb                                                        | Ev, Gv                       | Gb, Eb        | Gv, Ev                         | AL, Ib                        | rAX, Iz        | PUSH CS <sup>64</sup>       | 2-byte escape (Table A-3)                                       |         |
| 1                                  | Eb, Gb                                                          | Ev, Gv                                      | Gb, Eb                        | Gv, Ev                       | AL, Ib                        | rAX, Iz                   | PUSH SS <sup>64</sup>     | POP SS <sup>64</sup>               | Eb, Gb                                                        | Ev, Gv                       | Gb, Eb        | Gv, Ev                         | AL, Ib                        | rAX, Iz        | PUSH DS <sup>64</sup>       | DS <sup>64</sup>                                                |         |
| 2                                  | Eb, Gb                                                          | Ev, Gv                                      | Gb, Eb                        | Gv, Ev                       | AL, Ib                        | rAX, Iz                   | SEG=ES (Prefix)           | DAA <sup>64</sup>                  | Eb, Gb                                                        | Ev, Gv                       | Gb, Eb        | Gv, Ev                         | AL, Ib                        | rAX, Iz        | SEG=CS (Prefix)             | DAS <sup>64</sup>                                               |         |
| 3                                  | Eb, Gb                                                          | Ev, Gv                                      | Gb, Eb                        | Gv, Ev                       | AL, Ib                        | rAX, Iz                   | SEG=SS (Prefix)           | AAA <sup>64</sup>                  | Eb, Gb                                                        | Ev, Gv                       | Gb, Eb        | Gv, Ev                         | AL, Ib                        | rAX, Iz        | SEG=DS (Prefix)             | AAS <sup>64</sup>                                               |         |
| 4                                  | eAX<br>REX                                                      | eCX<br>REXB                                 | eDX<br>REXX                   | eBX<br>REXXB                 | eSP<br>REXR                   | eBP<br>REXR               | eSI<br>REXR               | eDI<br>REXR                        | eAX<br>REX.W                                                  | eCX<br>REX.WB                | eDX<br>REX.WX | eSP<br>REX.WR                  | eBP<br>REX.WRB                | eSI<br>REX.WRX | eDI<br>REX.WRXB             | DEC <sup>64</sup> general register / REX <sup>64</sup> Prefixes |         |
| 5                                  | INC <sup>64</sup> general register / REX <sup>64</sup> Prefixes |                                             |                               |                              |                               |                           |                           |                                    | POP <sup>64</sup> into general register                       |                              |               |                                |                               |                |                             |                                                                 |         |
| 6                                  | PUSHA <sup>64</sup> /<br>PUSHAD <sup>64</sup>                   | POPA <sup>64</sup> /<br>POPAD <sup>64</sup> | BOUND <sup>64</sup><br>Gv, Ma | ARPL <sup>64</sup><br>Ew, Gw | MOVSD <sup>64</sup><br>Gv, Ev | SEG=FS (Prefix)           | SEG=GS (Prefix)           | Operand Size (Prefix)              | Address Size (Prefix)                                         | rAX/r8                       | rCX/r9        | rDX/r10                        | rSP/r11                       | rSI/r12        | rDI/r13                     | rSI/r14                                                         | rDI/r15 |
| 7                                  | Jcc <sup>64</sup> , Jb - Short-displacement jump on condition   |                                             |                               |                              |                               |                           |                           |                                    | Jcc <sup>64</sup> , Jb - Short displacement jump on condition |                              |               |                                |                               |                |                             |                                                                 |         |
| 8                                  | O                                                               | NO                                          | B/NA/E/C                      | NB/AE/NC                     | Z/E                           | NZ/NE                     | BE/NA                     | NBE/A                              | S                                                             | NS                           | P/PE          | NP/PO                          | LNGE                          | NU/GE          | LE/NG                       | NLE/G                                                           |         |
| 9                                  | Immediate Grp 1 <sup>1A</sup>                                   |                                             |                               |                              |                               |                           |                           |                                    | MOV                                                           |                              |               |                                |                               |                |                             |                                                                 |         |
| A                                  | Eb, Ib                                                          | Ev, IZ                                      | Eb, Ib <sup>64</sup>          | Ev, Ib                       | Eb, Gb                        | Ev, Gv                    | Eb, Gb                    | Ev, Gv                             | Eb, Gb                                                        | Ev, Gv                       | Gb, Eb        | Gv, Ev                         | MOV                           | LEA            | MOV                         | Grp 1 <sup>1A</sup> POP <sup>64</sup> Ev                        |         |
| B                                  | PAUSE <sup>64</sup> /<br>XCHG r8, rAX                           |                                             |                               |                              |                               |                           |                           |                                    | CBW/<br>CWD/<br>CDQ/<br>CDQE                                  |                              |               |                                |                               |                |                             |                                                                 |         |
| C                                  | Shift Grp 2 <sup>1A</sup>                                       | near RET <sup>64</sup><br>lw                | near RET <sup>64</sup>        | LES <sup>64</sup><br>Gx, Mp  | LDS <sup>64</sup><br>Gx, Mp   | Grp 1 <sup>1A</sup> - MOV | Eb, Ib                    | TEST                               | far CALL <sup>64</sup><br>Ap                                  | far CALL <sup>64</sup><br>Ap | FWAIT/WAIT    | PUSHF/DQ <sup>64</sup> /<br>Fv | POPF/DQ <sup>64</sup> /<br>Fv | SAHF           | LAHF                        |                                                                 |         |
| D                                  | Shift Grp 2 <sup>1A</sup>                                       |                                             |                               |                              |                               |                           |                           |                                    | TEST                                                          |                              |               |                                |                               |                |                             |                                                                 |         |
| E                                  | LOCK <sup>64</sup> /<br>Jb                                      | LOOPNZ <sup>64</sup> /<br>Jb                | LOOP <sup>64</sup> /<br>Jb    | JCXZ <sup>64</sup> /<br>Jb   | IN                            | eAX, Ib                   | OUT                       | rAX/r8, Iv                         | rCX/r9, Iv                                                    | rDX/r10, Iv                  | rBX/r11, Iv   | rSP/r12, Iv                    | rBP/r13, Iv                   | rSI/r14, Iv    | rDI/r15, Iv                 |                                                                 |         |
| F                                  | LOCK (Prefix)                                                   | INT1                                        | XACQUIRE (Prefix)             | REP/REPE XRELEASE (Prefix)   | HLT                           | CMC                       | Unary Grp 3 <sup>1A</sup> | Eb                                 | CLC                                                           | STC                          | CLI           | STI                            | CLD                           | STD            | INC/DEC Grp 4 <sup>1A</sup> | INC/DEC Grp 5 <sup>1A</sup>                                     |         |

Figure3-2-1 1-byte opcodes

Figure 3-2-2 shows a portion of the 2-byte Opcode table, where, like in Figure 3-2-1, the red squares indicate a transition to a table with OpCodes of greater byte size.



Table 3

|   | pfx                                               | 8                        | 9                          | A                                 | B                                              | C                         | D                      | E                        | F              |       |
|---|---------------------------------------------------|--------------------------|----------------------------|-----------------------------------|------------------------------------------------|---------------------------|------------------------|--------------------------|----------------|-------|
| 0 |                                                   | INVD                     | WBINVD                     |                                   | 2-byte illegal<br>Opcodes<br>UD2 <sup>18</sup> |                           | prefetchw(/1)<br>Ev    |                          |                |       |
| 1 | Prefetch <sup>IC</sup><br>(Grp 16 <sup>1A</sup> ) | Reserved-NOP             | bndidx                     | bndstx                            | Reserved-NOP                                   |                           |                        |                          | NOP /0 Ev      |       |
|   |                                                   |                          | bndmov                     | bndmov                            |                                                |                           |                        |                          |                |       |
|   |                                                   |                          | bndcl                      | bndmk                             |                                                |                           |                        |                          |                |       |
|   |                                                   |                          | bndcu                      | bndcn                             |                                                |                           |                        |                          |                |       |
| 2 | vmovaps<br>Vps, Wps                               | vmovaps<br>Wps, Vps      | cvtpl2ps<br>Vps, Qpi       | vmovntps<br>Mps, Vps              | cvtpp2pl<br>Ppi, Wps                           | cvtpp2pi<br>Ppi, Wps      | vcuomiss<br>Vss, Wss   | vcuomiss<br>Vss, Wss     |                |       |
|   |                                                   |                          | cvtpl2pd<br>Vpd, Wpd       | cvtpl2pd<br>Wpd, Vpd              | cvtppd2pi<br>Ppi, Wpd                          | cvtppd2pi<br>Qpi, Wpd     | vcuomisd<br>Vsd, Wsd   | vcuomisd<br>Vsd, Wsd     |                |       |
|   |                                                   |                          |                            | vcvtsi2ss<br>Vss, Hss, Ey         |                                                | vcvtsi2si<br>Gy, Wss      | vcvtsi2si<br>Gy, Wss   |                          |                |       |
|   |                                                   |                          |                            | vcvtsi2sd<br>Vsd, Hsd, Ev         |                                                | vcvtsd2si<br>Gy, Wsd      | vcvtsd2si<br>Gy, Wsd   |                          |                |       |
| 3 | 3-byte escape<br>(Table A-4)                      |                          |                            | 3-byte escape<br>(Table A-5)      |                                                |                           |                        |                          |                |       |
| 4 | S                                                 | NS                       | P/PE                       | CMOVcc(Gv, Ev) - Conditional Move |                                                | NP/PO                     | L/NGE                  | NL/GE                    | LE/NG          | NLE/G |
| 5 | vaddps<br>Vps, Hps, Wps                           | vmulpss<br>Vps, Hps, Wps | vovtpe2pd<br>Vpd, Wps      | vovtqa2ps<br>Vps, Wdq             | vsubps<br>Vps, Hps, Wps                        | vmimps<br>Vps, Hps, Wps   | vdvps<br>Vps, Hps, Wps | vmmaxps<br>Vps, Hps, Wps |                |       |
|   | vaddpd<br>Vpd, Hpd, Wpd                           | vmulpd<br>Vpd, Hpd, Wpd  | vcvtpl2ps<br>Vps, Wpd      | vcvtpd2dq<br>Vdq, Wps             | vsupbd<br>Vpd, Hpd, Wpd                        | vmimpd<br>Vpd, Hpd, Wpd   | vdvpd<br>Vpd, Hpd, Wpd | vmmaxpd<br>Vpd, Hpd, Wpd |                |       |
|   | vaddss<br>Vss, Hss, Wss                           | vmulss<br>Vss, Hss, Wss  | vcvtsi2sd<br>Vsd, Hss, Wss | vcvtsi2dq<br>Vdq, Wps             | vsuss<br>Vss, Hss, Wss                         | vmimss<br>Vss, Hss, Wss   | vdvss<br>Vss, Hss, Wss | vmmaxss<br>Vss, Hss, Wss |                |       |
|   | vaddsd<br>Vsd, Hsd, Wsd                           | vmulsd<br>Vsd, Hsd, Wsd  | vovted2ss<br>Vss, Hx, Wsd  | vovted2dq<br>Vss, Hx, Wsd         | vsubsd<br>Vsd, Hsd, Wsd                        | vmimsd<br>Vsd, Hsd, Wsd   | vdvsd<br>Vsd, Hsd, Wsd | vmmaxsd<br>Vsd, Hsd, Wsd |                |       |
| 6 | punpckhbw<br>Pq, Qd                               | punpckhwd<br>Pq, Qd      | punpckhdq<br>Pq, Qd        | packssdw<br>Pq, Qd                |                                                |                           |                        | movd/q<br>Pd, Ey         | movq<br>Pq, Qq |       |
|   | vpunpckhbw<br>Vx, Hx, Wx                          | vpunpckhwd<br>Vx, Hx, Wx | vpunpckhdq<br>Vx, Hx, Wx   | vpackssdw<br>Vx, Hx, Wx           | vpunpcklqdq<br>Vx, Hx, Wx                      | vpunpckhqdq<br>Vx, Hx, Wx | vmovd/q<br>Vy, Ey      | vmovdqa<br>Vx, Wx        |                |       |
|   |                                                   |                          |                            |                                   |                                                |                           |                        | vmovdqu<br>Vx, Wx        |                |       |
| 7 | VMREAD<br>Ey, Gy                                  | VMWRITE<br>Gy, Ey        |                            |                                   |                                                |                           |                        | movd/q<br>Ey, Pd         | movq<br>Qq, Pq |       |
|   |                                                   |                          |                            |                                   | vhaddpd<br>Vpd, Hpd, Wpd                       | vhsuppd<br>Vpd, Hpd, Wpd  | vmovd/q<br>Ey, Vy      | vmovdqa<br>Wx, Vx        |                |       |
|   |                                                   |                          |                            |                                   | vhaddps<br>Vps, Hps, Wps                       | vhsupps<br>Vps, Hps, Wps  | vmovq<br>Vq, Wq        | vmovdqu<br>Wx, Vx        |                |       |
|   |                                                   |                          |                            |                                   |                                                |                           |                        |                          |                |       |

Table 4

Figure 3-2-2 2-byte opcodes

### 3-3- SIB and ModR/M

The third part of an instruction can be the ModR/M section, which itself consists of three parts, as shown in Figure 3-3-1. We extract the operands of an instruction from this section (if necessary, we will also use the parts explained later). As mentioned in the Opcode section, bits 5 to 3 can either determine the register or be part of the Opcode.



Figure 3-3-1 ModR/M placement



Figure 3-3-2 shows the method of determining the first and second operands of instruction operations. In this way, based on the values of the Mod, Reg, and R/M sections, the first operand is identified in the Effective Address column, and the second operand is specified in the r32 (/r) row.

| r8(/r)<br>r16(/r)<br>r32(/r)<br>mm(/r)<br>xmm(/r)<br>(In decimal) /digit (Opcode)<br>(In binary) REG =                                                                      |     |     | AL<br>AX<br>EAX<br>MM0<br>XMM0<br>0<br>000 | CL<br>CX<br>ECX<br>MM1<br>XMM1<br>1<br>001 | DL<br>DX<br>EDX<br>MM2<br>XMM2<br>2<br>010 | BL<br>BX<br>EBX<br>MM3<br>XMM3<br>3<br>011 | AH<br>SP<br>ESP<br>MM4<br>XMM4<br>4<br>100 | CH<br>BP<br>EBP<br>MM5<br>XMM5<br>5<br>101 | DH<br>SI<br>ESI<br>MM6<br>XMM6<br>6<br>110 | BH<br>DI<br>EDI<br>MM7<br>XMM7<br>7<br>111 |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--|
| Effective Address                                                                                                                                                           | Mod | R/M | Value of ModR/M Byte (in Hexadecimal)      |                                            |                                            |                                            |                                            |                                            |                                            |                                            |  |
| [EAX]                                                                                                                                                                       | 00  | 000 | 00                                         | 08                                         | 10                                         | 18                                         | 20                                         | 28                                         | 30                                         | 38                                         |  |
| [ECX]                                                                                                                                                                       |     | 001 | 01                                         | 09                                         | 11                                         | 19                                         | 21                                         | 29                                         | 31                                         | 39                                         |  |
| [EDX]                                                                                                                                                                       |     | 010 | 02                                         | 0A                                         | 12                                         | 1A                                         | 22                                         | 2A                                         | 32                                         | 3A                                         |  |
| [EBX]                                                                                                                                                                       |     | 011 | 03                                         | 0B                                         | 13                                         | 1B                                         | 23                                         | 2B                                         | 33                                         | 3B                                         |  |
| [--][--] <sup>1</sup><br>disp32 <sup>2</sup>                                                                                                                                |     | 100 | 04                                         | 0C                                         | 14                                         | 1C                                         | 24                                         | 2C                                         | 34                                         | 3C                                         |  |
| [ESI]                                                                                                                                                                       |     | 101 | 05                                         | 0D                                         | 15                                         | 1D                                         | 25                                         | 2D                                         | 35                                         | 3D                                         |  |
| [EDI]                                                                                                                                                                       |     | 110 | 06                                         | 0E                                         | 16                                         | 1E                                         | 26                                         | 2E                                         | 36                                         | 3E                                         |  |
|                                                                                                                                                                             |     | 111 | 07                                         | 0F                                         | 17                                         | 1F                                         | 27                                         | 2F                                         | 37                                         | 3F                                         |  |
| [EAX]+disp8 <sup>3</sup>                                                                                                                                                    | 01  | 000 | 40                                         | 48                                         | 50                                         | 58                                         | 60                                         | 68                                         | 70                                         | 78                                         |  |
| [ECX]+disp8                                                                                                                                                                 |     | 001 | 41                                         | 49                                         | 51                                         | 59                                         | 61                                         | 69                                         | 71                                         | 79                                         |  |
| [EDX]+disp8                                                                                                                                                                 |     | 010 | 42                                         | 4A                                         | 52                                         | 5A                                         | 62                                         | 6A                                         | 72                                         | 7A                                         |  |
| [EBX]+disp8                                                                                                                                                                 |     | 011 | 43                                         | 4B                                         | 53                                         | 5B                                         | 63                                         | 6B                                         | 73                                         | 7B                                         |  |
| [--][--]+disp8                                                                                                                                                              |     | 100 | 44                                         | 4C                                         | 54                                         | 5C                                         | 64                                         | 6C                                         | 74                                         | 7C                                         |  |
| [EBP]+disp8                                                                                                                                                                 |     | 101 | 45                                         | 4D                                         | 55                                         | 5D                                         | 65                                         | 6D                                         | 75                                         | 7D                                         |  |
| [ESI]+disp8                                                                                                                                                                 |     | 110 | 46                                         | 4E                                         | 56                                         | 5E                                         | 66                                         | 6E                                         | 76                                         | 7E                                         |  |
| [EDI]+disp8                                                                                                                                                                 |     | 111 | 47                                         | 4F                                         | 57                                         | 5F                                         | 67                                         | 6F                                         | 77                                         | 7F                                         |  |
| [EAX]+disp32                                                                                                                                                                | 10  | 000 | 80                                         | 88                                         | 90                                         | 98                                         | A0                                         | A8                                         | B0                                         | B8                                         |  |
| [ECX]+disp32                                                                                                                                                                |     | 001 | 81                                         | 89                                         | 91                                         | 99                                         | A1                                         | A9                                         | B1                                         | B9                                         |  |
| [EDX]+disp32                                                                                                                                                                |     | 010 | 82                                         | 8A                                         | 92                                         | 9A                                         | A2                                         | AA                                         | B2                                         | BA                                         |  |
| [EBX]+disp32                                                                                                                                                                |     | 011 | 83                                         | 8B                                         | 93                                         | 9B                                         | A3                                         | AB                                         | B3                                         | BB                                         |  |
| [--][--]+disp32                                                                                                                                                             |     | 100 | 84                                         | 8C                                         | 94                                         | 9C                                         | A4                                         | AC                                         | B4                                         | BC                                         |  |
| [EBP]+disp32                                                                                                                                                                |     | 101 | 85                                         | 8D                                         | 95                                         | 9D                                         | A5                                         | AD                                         | B5                                         | BD                                         |  |
| [ESI]+disp32                                                                                                                                                                |     | 110 | 86                                         | 8E                                         | 96                                         | 9E                                         | A6                                         | AE                                         | B6                                         | BE                                         |  |
| [EDI]+disp32                                                                                                                                                                |     | 111 | 87                                         | 8F                                         | 97                                         | 9F                                         | A7                                         | AF                                         | B7                                         | BF                                         |  |
| EAX/AX/AL/MM0/XMM0<br>ECX/CX/CL/MM/XMM1<br>EDX/DX/DL/MM2/XMM2<br>EBX/BX/BL/MM3/XMM3<br>ESP/SP/AH/MM4/XMM4<br>EBP/BP/CH/MM5/XMM5<br>ESI/SI/DH/MM6/XMM6<br>EDI/DI/BH/MM7/XMM7 | 11  | 000 | C0                                         | C8                                         | D0                                         | D8                                         | E0                                         | E8                                         | F0                                         | F8                                         |  |
|                                                                                                                                                                             |     | 001 | C1                                         | C9                                         | D1                                         | D9                                         | E1                                         | E9                                         | F1                                         | F9                                         |  |
|                                                                                                                                                                             |     | 010 | C2                                         | CA                                         | D2                                         | DA                                         | E2                                         | EA                                         | F2                                         | FA                                         |  |
|                                                                                                                                                                             |     | 011 | C3                                         | CB                                         | D3                                         | DB                                         | E3                                         | EB                                         | F3                                         | FB                                         |  |
|                                                                                                                                                                             |     | 100 | C4                                         | CC                                         | D4                                         | DC                                         | E4                                         | EC                                         | F4                                         | FC                                         |  |
|                                                                                                                                                                             |     | 101 | C5                                         | CD                                         | D5                                         | DD                                         | E5                                         | ED                                         | F5                                         | FD                                         |  |
|                                                                                                                                                                             |     | 110 | C6                                         | CE                                         | D6                                         | DE                                         | E6                                         | EE                                         | F6                                         | FE                                         |  |
|                                                                                                                                                                             |     | 111 | C7                                         | CF                                         | D7                                         | DF                                         | E7                                         | EF                                         | F7                                         | FF                                         |  |

Figure 3-3-2 finding effective address based on Mod R/M

Some rows in the table in Figure 3-5 refer to a new table, which is actually the SIB byte that specifies the corresponding column and row in the second table (Figure 3-3-3).



| r8/r                                                                                                                                                                         |     | AL   | CL                                    | DL   | BL   | AH   | CH   | DH   | BH   |    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|---------------------------------------|------|------|------|------|------|------|----|
| r16/r                                                                                                                                                                        |     | AX   | CX                                    | DX   | BX   | SP   | BP   | SI   | DI   |    |
| r32/r                                                                                                                                                                        |     | EAX  | ECX                                   | EDX  | EBX  | ESP  | EBP  | ESI  | EDI  |    |
| mm/r                                                                                                                                                                         |     | MM0  | MM1                                   | MM2  | MM3  | MM4  | MM5  | MM6  | MM7  |    |
| xmm/r                                                                                                                                                                        |     | XMM0 | XMM1                                  | XMM2 | XMM3 | XMM4 | XMM5 | XMM6 | XMM7 |    |
| (In decimal) / digit (Opcode)                                                                                                                                                |     | 0    | 1                                     | 2    | 3    | 4    | 5    | 6    | 7    |    |
| (In binary) REG =                                                                                                                                                            |     | 000  | 001                                   | 010  | 011  | 100  | 101  | 110  | 111  |    |
| Effective Address                                                                                                                                                            | Mod | R/M  | Value of ModR/M Byte (in Hexadecimal) |      |      |      |      |      |      |    |
| [EAX]                                                                                                                                                                        | 00  | 000  | 00                                    | 08   | 10   | 18   | 20   | 28   | 30   | 38 |
| [ECX]                                                                                                                                                                        |     | 001  | 01                                    | 09   | 11   | 19   | 21   | 29   | 31   | 39 |
| [EDX]                                                                                                                                                                        |     | 010  | 02                                    | 0A   | 12   | 1A   | 22   | 32   | 3A   | 3B |
| [EBX]                                                                                                                                                                        |     | 011  | 03                                    | 0B   | 13   | 1B   | 23   | 33   | 3B   | 3B |
| <b>[SI]-1</b>                                                                                                                                                                |     | 100  | 04                                    | 0C   | 14   | 1C   | 24   | 2C   | 34   | 3C |
| disp32 <sup>2</sup>                                                                                                                                                          |     | 101  | 05                                    | 0D   | 15   | 1D   | 25   | 2D   | 35   | 3D |
| [ESI]                                                                                                                                                                        |     | 110  | 06                                    | 0E   | 16   | 1E   | 26   | 2E   | 36   | 3E |
| [EDI]                                                                                                                                                                        |     | 111  | 07                                    | 0F   | 17   | 1F   | 27   | 2F   | 37   | 3F |
| [EAX]+disp8 <sup>3</sup>                                                                                                                                                     | 01  | 000  | 40                                    | 48   | 50   | 58   | 60   | 68   | 70   | 78 |
| [ECX]+disp8                                                                                                                                                                  |     | 001  | 41                                    | 49   | 51   | 59   | 61   | 69   | 71   | 79 |
| [EDX]+disp8                                                                                                                                                                  |     | 010  | 42                                    | 4A   | 52   | 5A   | 62   | 6A   | 72   | 7A |
| [EBX]+disp8                                                                                                                                                                  |     | 011  | 43                                    | 4B   | 53   | 5B   | 63   | 6B   | 73   | 7B |
| <b>[SI]-1+disp8</b>                                                                                                                                                          |     | 100  | 44                                    | 4C   | 54   | 5C   | 64   | 6C   | 74   | 7C |
| [EBP]+disp8                                                                                                                                                                  |     | 101  | 45                                    | 4D   | 55   | 5D   | 65   | 6D   | 75   | 7D |
| [ESI]+disp8                                                                                                                                                                  |     | 110  | 46                                    | 4E   | 56   | 5E   | 66   | 6E   | 76   | 7E |
| [EDI]+disp8                                                                                                                                                                  |     | 111  | 47                                    | 4F   | 57   | 5F   | 67   | 6F   | 77   | 7F |
| [EAX]+disp32                                                                                                                                                                 | 10  | 000  | 80                                    | 88   | 90   | 98   | A0   | A8   | B0   | B8 |
| [ECX]+disp32                                                                                                                                                                 |     | 001  | 81                                    | 89   | 91   | 99   | A1   | A9   | B1   | B9 |
| [EDX]+disp32                                                                                                                                                                 |     | 010  | 82                                    | 8A   | 92   | 9A   | A2   | A8   | B2   | B8 |
| [EBX]+disp32                                                                                                                                                                 |     | 011  | 83                                    | 8B   | 93   | 9B   | A3   | A8   | B3   | B8 |
| <b>[SI]-1+disp32</b>                                                                                                                                                         |     | 100  | 84                                    | 8C   | 94   | 9C   | A4   | A8   | B4   | B8 |
| [EBP]+disp32                                                                                                                                                                 |     | 101  | 85                                    | 8D   | 95   | 9D   | A5   | A8   | B5   | B8 |
| [ESI]+disp32                                                                                                                                                                 |     | 110  | 86                                    | 8E   | 96   | 9E   | A6   | A8   | B6   | B8 |
| [EDI]+disp32                                                                                                                                                                 |     | 111  | 87                                    | 8F   | 97   | 9F   | A7   | A8   | B7   | B8 |
| EAX/AX/AL/MM0/XMM0<br>ECX/CX/CL/MM1/XMM1<br>EDX/DX/DL/MM2/XMM2<br>EBX/BX/BL/MM3/XMM3<br>ESP/SP/AH/MM4/XMM4<br>EBP/BP/CH/MM5/XMM5<br>ESI/SI/DH/MM6/XMM6<br>EDI/DI/BH/MM7/XMM7 | 11  | 000  | C0                                    | C8   | D0   | D8   | E0   | E8   | F0   | F8 |
|                                                                                                                                                                              |     | 001  | C1                                    | C9   | D1   | D9   | E1   | E9   | F1   | F9 |
|                                                                                                                                                                              |     | 010  | C2                                    | CA   | D2   | DA   | E2   | EA   | F2   | FA |
|                                                                                                                                                                              |     | 011  | C3                                    | CB   | D3   | DB   | E3   | EB   | F3   | FB |
|                                                                                                                                                                              |     | 100  | C4                                    | CC   | D4   | DC   | E4   | EC   | F4   | FC |
|                                                                                                                                                                              |     | 101  | C5                                    | CD   | D5   | DD   | E5   | ED   | F5   | FD |
|                                                                                                                                                                              |     | 110  | C6                                    | CE   | D6   | DE   | E6   | EE   | F6   | FE |
|                                                                                                                                                                              |     | 111  | C7                                    | CF   | D7   | DF   | E7   | EF   | F7   | FF |

SIB

| r32<br>(In decimal) Base =<br>(In binary) Base = |    |       | EAX                                | ECX | EDX | EBX | ESP | [*] | ESI | EDI |
|--------------------------------------------------|----|-------|------------------------------------|-----|-----|-----|-----|-----|-----|-----|
| Scaled Index                                     | SS | Index | Value of SIB Byte (in Hexadecimal) |     |     |     |     |     |     |     |
| [EAX]                                            | 00 | 000   | 00                                 | 01  | 02  | 03  | 04  | 05  | 06  | 07  |
| [ECX]                                            |    | 001   | 08                                 | 09  | 0A  | 0B  | 0C  | 0D  | 0E  | 0F  |
| [EDX]                                            |    | 010   | 10                                 | 11  | 12  | 13  | 14  | 15  | 16  | 17  |
| [EBX]                                            |    | 011   | 18                                 | 19  | 1A  | 1B  | 1C  | 1D  | 1E  | 1F  |
| none                                             |    | 100   | 20                                 | 21  | 22  | 23  | 24  | 25  | 26  | 27  |
| [EBP]                                            |    | 101   | 28                                 | 29  | 2A  | 2B  | 2C  | 2D  | 2E  | 2F  |
| [ESI]                                            |    | 110   | 30                                 | 31  | 32  | 33  | 34  | 35  | 36  | 37  |
| [EDI]                                            |    | 111   | 38                                 | 39  | 3A  | 3B  | 3C  | 3D  | 3E  | 3F  |
| [EAX*2]                                          | 01 | 000   | 40                                 | 41  | 42  | 43  | 44  | 45  | 46  | 47  |
| [ECX*2]                                          |    | 001   | 48                                 | 49  | 4A  | 4B  | 4C  | 4D  | 4E  | 4F  |
| [EDX*2]                                          |    | 010   | 50                                 | 51  | 52  | 53  | 54  | 55  | 56  | 57  |
| [EBX*2]                                          |    | 011   | 58                                 | 59  | 5A  | 5B  | 5C  | 5D  | 5E  | 5F  |
| none                                             |    | 100   | 60                                 | 61  | 62  | 63  | 64  | 65  | 66  | 67  |
| [EBP*2]                                          |    | 101   | 68                                 | 69  | 6A  | 6B  | 6C  | 6D  | 6E  | 6F  |
| [ESI*2]                                          |    | 110   | 70                                 | 71  | 72  | 73  | 74  | 75  | 76  | 77  |
| [EDI*2]                                          |    | 111   | 78                                 | 79  | 7A  | 7B  | 7C  | 7D  | 7E  | 7F  |
| [EAX*4]                                          | 10 | 000   | 80                                 | 81  | 82  | 83  | 84  | 85  | 86  | 87  |
| [ECX*4]                                          |    | 001   | 88                                 | 89  | 8A  | 8B  | 8C  | 8D  | 8E  | 8F  |
| [EDX*4]                                          |    | 010   | 90                                 | 91  | 92  | 93  | 94  | 95  | 96  | 97  |
| [EBX*4]                                          |    | 011   | 98                                 | 99  | 9A  | 9B  | 9C  | 9D  | 9E  | 9F  |
| none                                             |    | 100   | A0                                 | A1  | A2  | A3  | A4  | A5  | A6  | A7  |
| [EBP*4]                                          |    | 101   | A8                                 | A9  | AA  | AB  | AC  | AD  | AE  | AF  |
| [ESI*4]                                          |    | 110   | B0                                 | B1  | B2  | B3  | B4  | B5  | B6  | B7  |
| [EDI*4]                                          |    | 111   | B8                                 | B9  | BA  | BB  | BC  | BD  | BE  | BF  |
| [EAX*8]                                          | 11 | 000   | C0                                 | C1  | C2  | C3  | C4  | C5  | C6  | C7  |
| [ECX*8]                                          |    | 001   | C8                                 | C9  | CA  | CB  | CC  | CD  | CE  | CF  |
| [EDX*8]                                          |    | 010   | D0                                 | D1  | D2  | D3  | D4  | D5  | D6  | D7  |
| [EBX*8]                                          |    | 011   | D8                                 | D9  | DA  | DB  | DC  | DD  | DE  | DF  |
| none                                             |    | 100   | E0                                 | E1  | E2  | E3  | E4  | E5  | E6  | E7  |
| [EBP*8]                                          |    | 101   | E8                                 | E9  | EA  | EB  | EC  | ED  | EE  | EF  |
| [ESI*8]                                          |    | 110   | F0                                 | F1  | F2  | F3  | F4  | F5  | F6  | F7  |
| [EDI*8]                                          |    | 111   | F8                                 | F9  | FA  | FB  | FC  | FD  | FE  | FF  |

Figure 3-3-3 Mod R/M table

The SIB section also consists of three parts, which are shown in Figure 3-3-4. Based on the values of Scale, Index, and Base, a cell from the right table in Figure 3-6 is selected, which provides the necessary values for memory access.



Figure 3-3-4 SIB placement



### 3-4- Immediate Placement

As seen in the table in Figure 3-5, the Displacement section is used in some memory addresses, and its value is used directly. Additionally, sometimes one of the operands of the instruction is located in the Immediate section, and we execute the instruction by reading it directly.

## 4- SystemC Modeling of Pentium Pro

In this section, the structure discussed in Section 2, along with other items, must be implemented.

### 4-1- Code Architecture

Since there are multiple files in this project, explaining the code hierarchy is essential. The processor is intended to operate alongside a memory unit. Therefore, the processor and the memory unit together form the entire system (File: *FullSystem.h*). The memory unit is simply an array of 2000 32-bit cells. Since, in a real system, the processor must ensure that the memory is ready for communication, a ready signal has been assigned for the memory, which is simply set manually to always be 1, meaning the memory is always ready to communicate with the processor. In the file *main.cpp*, the simulation duration, the creation of the *vcd* file, and monitoring the communication signals between the processor and memory are configured. The code hierarchy from the highest level to the lowest is as follows:

1. Test bench execution file and its settings (*Main.cpp*)
2. Overall system file comprising the processor and memory (*FullSystem.h*)
3. Main processor file (*ISS.h*) and main memory file (*Memory.h*)
4. Instruction execution file (*BaseFunctions.h*)
5. Library file and some general functions common between components (*Requirements.h*)



In the header files, only the function names are mentioned, while the function descriptions are included in the .cpp files. In addition to the above files, there is a separate file for testing memory named *MemoryTB*. To compile the files, the *makefile* provided in the folder is used.

### 4-1-1 Modeling the Processor Structure

In the first phase, we will model the required ports, registers, and input/output signals. The mentioned registers include the main system registers (as shown in Figure 2-1) and the registers needed for temporarily storing variables (in the file *ISS.h*).

```
11 //-----PORTS-----
12 sc_in<sc_logic> clk;
13 sc_out<sc_lv<ADDRESS_SIZE>> AddressBus;
14 sc_in<sc_lv<DATA_SIZE>> DataBus_in;
15 sc_out<sc_lv<DATA_SIZE>> DataBus_out;
16 sc_out<sc_logic> read_request, write_request, input_valid;
17 sc_in<sc_logic> mem_ready;
18 //-----INTERNAL REGISTERS-----
19 sc_lv<REGISTER_WIDTH> EAX, EBX, ECX, EDX, EBP, ESI, EDI, ESP; // General-Purpose Register
20 sc_lv<SEGMENT_REGISTER_WIDTH> CS, DS, SS, ES, FS, GS; // Segment Registers
21 sc_lv<EFLAG_WIDTH> EFLAGS; // EFLAGS Register
22 sc_lv<EFLAG_WIDTH> *EFLAGS_ptr;
23 sc_lv<EIP_WIDTH> EIP; //EIP Register
24 sc_lv<MAX_INST_WIDHT> Instruction;
25 sc_lv<8> disp8;
26 sc_lv<32> disp32;
27 sc_lv<8> SIB;
28 sc_lv<ADDRESS_SIZE> effective_address;
29 sc_lv<32> memory_write_data;
30 sc_lv<32> memory_read_data;
```

Figure 4-1-1 Register Modeling

### 4-1-2 Execution Unit Modeling

In this stage, we need to model the Opcode table, specifically the table shown in Figure 3-2-1. For each cell in the table, we will write a function with the format:

“void T#table number #row number#column number\_instruction name”



Within each function, we will implement the specific actions that the corresponding instruction performs. For example, the function *T1\_8B\_MOV\_DATA* indicates that in the table shown in Figure 4-1-2, at row 8 and column 11, the instruction *MOV\_DATA* exists, and its function has been defined accordingly.

```
185      //-----MOVE-----
186      void T1_89_MOV_DATA(vector<sc_lv<8>> Instruction_Bytes);
187      void T1_8B_MOV_DATA(vector<sc_lv<8>> Instruction_Bytes);
188      void T1_C7_MOV_DATA(vector<sc_lv<8>> Instruction_Bytes);
189      void T1_A1_MOV_DATA(vector<sc_lv<8>> Instruction_Bytes);
190      void T1_A3_MOV_DATA(vector<sc_lv<8>> Instruction_Bytes);
```

Figure 4-1-2 functions MOV\_DATA

```
1746 template <int ADDRESS_SIZE, int DATA_SIZE, int REGISTER_WIDTH, int SEGMENT_REGISTER_WIDTH, int EFLAG_WIDTH, int EIP_WID:
1747 void CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>:
1748     T1_A3_MOV_DATA(vector<sc_lv<8>> Instruction_Bytes)
1749 {
1750     int mod_location = 1;
1751     sc_lv<8> ModRM_Byt = Instruction_Bytes[mod_location];
1752     sc_lv<REGISTER_WIDTH> *EAX_;
1753     EAX_ = &EAX;
1754     load_disp32(Instruction_Bytes, 1);
1755     effective_address = disp32;
1756     memory_write_data = EAX;
1757     cout << "address is: " << endl;
1758     write_request = SC_LOGIC_1;
1759     wait(write_done);
1760     Instruction_done.notify();
1761 }
```

Figure 4-1-3function T1\_A3\_MOV\_DATA

All of these functions, defined as *\*FunctionPtr*, will be placed in a two-dimensional array named *opcode\_1B[16][16]* under the *table1* function (Figure 4-1-4). (File: *ISS.h*)



```
568 template <int ADDRESS_SIZE, int DATA_SIZE, int REGISTER_WIDTH, int SEGMENT_REGISTER_WIDTH, int EFLAG_WIDTH, int EIP_WIDTH, int MAX_INST_WIDTH>
569 void CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::table1()
570 {
571     opcode_1B[0][0] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_00_ADD;
572     opcode_1B[0][1] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_01_ADD;
573     opcode_1B[0][2] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_02_ADD;
574     opcode_1B[0][3] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_03_ADD;
575     opcode_1B[0][4] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_04_ADD;
576     opcode_1B[0][5] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_05_ADD;
577
578     opcode_1B[2][9] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_29_SUB;
579     opcode_1B[2][11] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_2B_SUB;
580     opcode_1B[2][13] = &CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::T1_2D_SUB;
```

Figure 4-1-4 function table1

We will write the corresponding functions for the remaining instructions in the same way and add them to the opcode\_1B table. The implemented instructions are listed below:

ADD – Add

AND – Logical AND

CMP – Compare Two Operands

DEC – Decrement By 1

DIV – Unsigned Divide

IDIV – Signed Divide

INC – Increment By 1

MOV – Move Data

MUL – Unsigned Multiply

OR – Logical Inclusive OR

SUB – Integer Subtraction



## 4-2- Steps for Executing Instructions in Code

To execute an instruction, several steps are followed. First, instructions must be read from memory in a way that 32 bytes are retrieved. Since each memory location is considered to be 32 bits, reading 32 bytes requires accessing 8 memory locations (equivalent to 256 bits). After reading the instructions from memory, the retrieved data is divided into two 16-byte segments, and each of these 16 bytes is examined separately. Then, it must be determined how many instructions are contained within each 16-byte segment, and these instructions need to be separated. After this stage, the instructions are executed in the order they were read.

The constructor for the main processor module in the code (*CPU\_ISS*) is as follows.

```
131 //-----CONSTRUCTOR-----
132 SC_CTOR(CPU_ISS)
133 {
134     IP = 1799;
135     initialize();
136     EFLAGS_ptr = &EFLAGS;
137     table1();
138     table1_length();
139     Address_init();
140     SC_THREAD(decoding);
141     sensitive << clk.pos();
142     SC_THREAD(read_mem);
143     sensitive << clk.pos();
144     SC_THREAD(write_mem);
145     sensitive << clk.pos();
146     SC_THREAD(read_Instruction);
147     sensitive << clk.pos();
148     SC_THREAD(pre_decode);
149     sensitive << clk.pos();
150     // SC_METHOD(set_default);
151     // sensitive << clk.pos();
152 }
```

Figure 4-2-1 constructor

As observed, the functions *initialize()*, *table1()*, *table1\_length()*, and *Address\_init()* are executed first for initialization. Next, the decoding function (Figure 4-2-2) is called. When this function is executed, two scenarios can occur at the beginning: if the instruction buffer is empty, the *read\_Inst* event is triggered (notified), and the instruction buffer is filled by executing the *read\_Instruction()* function. After that, we proceed to the *pre\_decode* stage. If



the instruction buffer is not empty from the start, we directly execute the *pre\_decode()* function.

```
806 void CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::decoding()
807 {
808     int inst = 0;
809     while (true)
810     {
811         if (PC == 1811)
812         {
813             if (inst == 4)
814                 break;
815             else
816                 inst++;
817         }
818         wait(clk.posedge_event());
819         if (Instruction_Buffer.size() == 0)
820         {
821             read_Inst.notify();
822             wait(fetch_done);
823             pre_dec.notify();
824             wait(pre_dec_done);
825         }
826
827         Instruction = Instruction_Buffer[0];
828         int inst_len;
829         for (int i = MAX_INST_WIDTH; i >= 0; i--)
830         {
831             if (Instruction[i] == 'X')
832             {
833                 inst_len = (MAX_INST_WIDTH - i) / 8;
834                 break;
835             }
836             inst_len = (MAX_INST_WIDTH - i) / 8;
837         }
838         cout << "-----" << endl;
839         cout << "Instruction is :" << Instruction << endl;
840         vector<sc_lv<8>> Instruction_Bytess;
841         for (int i = 0; i < inst_len; i++)
842         {
843             Instruction_Bytess.push_back(Instruction.range(119 - 8 * i, 112 - 8 * i));
844         }
845
846         int opcode_location;
847         // will be completed later
848         opcode_location = 0;
849         int row = Instruction_Bytess[opcode_location].range(7, 4).to_uint();
850         int column = Instruction_Bytess[opcode_location].range(3, 0).to_uint();
851         (this->>opcode_IB[row][column])(Instruction_Bytess);
852         Instruction_Buffer = erase_front(Instruction_Buffer);
853         print_register_values();
854         wait(clk.posedge_event());
855     }
856 }
```

Figure 4-2-2 function decoding

Within the *pre\_decode()* function (Figure 4-2-3), the 16 bytes retrieved are examined, and the length of each instruction is determined using functions that end with "\_Len" (as shown in Figure 4-2-4). All instructions present in the 16-byte buffer are separated (different instructions are stored in a vector called *Instruction\_Buffer*). The storage method is such that the mentioned vector contains elements of type *sc\_lv<120>*, with each instruction placed at



the beginning of each *sc\_lv*, followed by an 'X' until it reaches 120 characters. After that, based on the extracted opcode, the corresponding instruction is executed. In the next section, we will see an example of instruction execution and the process of calling functions.



```
726 void CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::pre_decode()
727 {
728     while (true)
729     {
730         wait(pre_dec);
731         string Inst_buffer;
732         vector<sc_lv<8>> opcode_bytes;
733         if (second_pre_dec)
734         {
735             for (int i = 4; i < 8; i++)
736             {
737                 Inst_buffer += Instruction_parts[i].to_string();
738             }
739         }
740         else
741         {
742             for (int i = 0; i < 4; i++)
743             {
744                 Inst_buffer += Instruction_parts[i].to_string();
745             }
746         }
747         while (Inst_buffer.length() != 0) // main pre-decode
748         {
749             opcode_bytes.clear();
750             int inst_length = 0;
751             int opcode_location = 0; // location as byte
752             // byte count is from left (MSB)
753             sc_lv<8> first_byte = Inst_buffer.substr(0, 8).c_str();
754             if ((first_byte == 0x66) || (first_byte == 0x67) || (64 < first_byte.to_uint() < 79)) ...
755             // detecting opcode
756             sc_lv<8> opcode_first_byte = Inst_buffer.substr(opcode_location * 8, 8).c_str();
757             inst_length++;
758             opcode_bytes.push_back(opcode_first_byte);
759             if (opcode_first_byte == 0x0F)
760             {
761                 inst_length++;
762                 sc_lv<8> opcode_second_byte = Inst_buffer.substr(8 * (opcode_location + 1), 8).c_str();
763                 opcode_bytes.push_back(opcode_second_byte);
764                 if (opcode_second_byte == 0x38 || opcode_second_byte == 0x3A)
765                 {
766                     sc_lv<8> opcode_third_byte = Inst_buffer.substr(8 * (opcode_location + 2), 8).c_str();
767                     opcode_bytes.push_back(opcode_third_byte);
768                     inst_length++;
769                 }
770             }
771             switch (opcode_bytes.size())
772             {
773                 case 1:
774                 {
775                     int row = opcode_bytes[0].range(7, 4).to_uint();
776                     int column = opcode_bytes[0].range(3, 0).to_uint();
777                     inst_length += (this->*opcode_1B_length[row][column])(opcode_bytes, Inst_buffer, inst_length);
778                     break;
779                 }
780                 case 2:
781                 {
782                     ...
783                 }
784                 case 3:
785                 {
786                     ...
787                 }
788                 default:
789                 {
790                     break;
791                 }
792             }
793             string effective_instruction = Inst_buffer.substr(0, inst_length * 8);
794             int len = 120 - effective_instruction.length();
795             for (int i = 0; i < len; i++) ...
796             sc_lv<120> temp = effective_instruction.c_str();
797             cout << "effective inst: " << temp << endl;
798             Instruction_Buffer.push_back(temp);
799             Inst_buffer.erase(0, inst_length * 8);
800         }
801         pre_dec_done.notify();
802         wait(clk.posedge_event());
803     }
804 }
```

Figure 4-2-3 pre\_decoding



```
2101 int CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, E
2102 | T1_05_ADD_Len(vector<sc_lv<8>> opcode_bytes, string Inst_Buffer, int location)
2103 {
2104     // Immediate to AL,AX or EAX. Since we are doing 32 bit operation, we use EAX.
2105     // Since this instruction doesn't need ModR/M byte, the next Bytes are Immediate data.
2106     sc_lv<8> opcode = opcode_bytes[0];
2107     if (opcode[0] == SC_LOGIC_0)
2108         return 1; // immediate 8 bit
2109     else if (opcode[1] == SC_LOGIC_1)
2110         return 4; // immediate 32 bit
2111 }
```

Figure 4-2-4 instruction length finder

Assume that the "ADD: memory to register" instruction is detected in the decode function, represented as "0000 0000: mod reg r/m." Of course, if necessary, SIB and displacement bits can be added to this instruction (Figure 4-2-5).



Figure 4-2-5 ADD: memory to register

Based on the second byte of the instruction, which is the ModRM, the operands of the instruction must be determined. By placing the values of the Mod, Reg, and R/M sections in the table (Figure 3-3-2), it is determined that the first operand is the EAC register. To find the second operand, attention must be paid to the SIB byte and also to the table in Figure 3-3-3. The entry pointed to by the SIB byte is identified in the figure, and using formula 4-1, the memory address from which the content should be read is determined.

$$\text{memory address} = \text{scale} * \text{index} + \text{base} + \text{displacement}$$

Formula 4-1 physical address generation formula



For example, suppose the following values are stored in the processor registers and memory:

ECX = 420

EDI = 30

EBX = 20

Mem [773] = 5043

The process for calculating the memory location from which we need to read the value is as follows:

scale = 2

index = EBX = 20

base = EDI = 30

displacement = 703

Mem [2\*20 + 30 + 703] = Mem [773] = 5043

Now, the addition operation between the two operands is performed:

ECX + Mem [773] = 420 + 5043 = 5463

Finally, the result of the addition is stored in the ECX register, and the addition operation is completed.

Now let's examine the same instruction and its execution process in the code. We previously covered up to the decode section. We know that the Opcode "0000 0011" in hexadecimal becomes 03h. Therefore, the function "T1\_03\_ADD" should be executed here. (Figure 4-2-6).



```
1084 void CPU_ISS<ADDRESS_SIZE, DATA_SIZE, REGISTER_WIDTH, SEGMENT_REGISTER_WIDTH, EFLAG_WIDTH, EIP_WIDTH, MAX_INST_WIDTH>::  
1085     T1_03_ADD(vector<sc_lv<8>> Instruction_Byt  
1086 {  
1087     int mod_location = 1; // needs completion  
1088     sc_lv<8> ModRM_Byte = Instruction_Byt[mod_location];  
1089     int table_index = ModRM_BYTE.to_uint();  
1090     if (table_index > 192) // Mod = 11 : simple register to register Instruction  
1091     {  
1092         sc_lv<REGISTER_WIDTH> *operand1 = convert_to_reg(Operand_32b_MODRM[table_index][0]);  
1093         sc_lv<REGISTER_WIDTH> *operand2 = convert_to_reg(Operand_32b_MODRM[table_index][1]);  
1094         D0_Addition(operand1, operand2, operand1, EFLAGS);  
1095  
1096         Instruction_done.notify();  
1097     }  
1098     else if ((ModRM_BYTE.range(7, 6) == "00" || ModRM_BYTE.range(7, 6) == "01" || ModRM_BYTE.range(7, 6) == "10" && ModRM_BYTE.range(2, 0) == "100") // SIB needed  
1099     {  
1100         effective_address = convert_to_SIB_address(Instruction_Byt, mod_location);  
1101         cout << "address is : " << effective_address << endl;  
1102         AddressBus = effective_address;  
1103         wait(clk.posedge_event());  
1104         read_data.notify();  
1105         wait(read_done);  
1106  
1107         sc_lv<REGISTER_WIDTH> *operand = convert_to_reg(Operand_32b_MODRM[table_index][1]);  
1108         D0_Addition(operand, &memory_read_data, operand, EFLAGS);  
1109  
1110         Instruction_done.notify();  
1111     }  
1112     else // simple memory to register without SIB byte  
1113     {  
1114         find_disp(Instruction_Byt, mod_location);  
1115         effective_address;  
1116         int addr;  
1117         addr = convert_to_address(Operand_32b_MODRM[table_index][0]);  
1118         cout << "address is : " << addr << endl;  
1119         effective_address = addr;  
1120         sc_lv<REGISTER_WIDTH> *operand = convert_to_reg(Operand_32b_MODRM[table_index][1]);  
1121         AddressBus = effective_address;  
1122         wait(clk.posedge_event());  
1123         read_data.notify();  
1124         wait(read_done);  
1125         D0_Addition(operand, &memory_read_data, operand, EFLAGS);  
1126         wait(clk.posedge_event());  
1127         Instruction_done.notify();  
1128     }  
1129 }
```

Figure 4-2-6 function T1\_03\_ADD

Here, since our operation is "memory to register," the second part of the conditions in the function *T1\_03\_ADD*, specifically line 1098, is executed. Upon closer inspection of this section, we see that the address of the memory location to be read is obtained using the *convert\_to\_SIB\_address* function. Then, the memory read operation is performed. After



that, the second operand is identified using the *convert\_to\_reg* function. In the next step, the *Do\_Addition* function is called. (Figure 4-2-7 and *BaseFunctions.cpp* file).

```
66 void Do_Addition(sc_lv<32> *op1, sc_lv<32> *op2, sc_lv<32> *result, sc_lv<32> &EFLAGS)
67 {
68     cout << "Addition Called" << endl;
69     cout << "operand 1 is : " << op1->to_int() << endl;
70     cout << "operand 2 is : " << op2->to_int() << endl;
71     *result = op1->to_int() + op2->to_int();
72     cout << "result is : " << result->to_int() << endl;
73     set_Eflags(*op1, *op2, *result, EFLAGS, 1, "11111100000");
74 }
```

Figure 4-2-7 function Do\_Addition

Further explanation of the code in Figure 4-2-7:

This function, specific to row 0 and column 3 of Figure 3-2, performs the addition operation. In the initial lines of code, the position of the ModR/M bits among other bits is determined, and a variable named *table\_index* is used to store the integer value of the ModR/M bits. Then, by analyzing the different parts of the ModR/M bits, we identify which section of the table in Figure 3-5 the operation falls under.

If the *table\_index* value is greater than 192, it indicates that the two operands of the instruction are stored in the processor's registers, meaning we just need to read the register values and perform the operation. Otherwise, if memory access is required to reach the necessary operands, and the condition in line 1098 is true, the SIB bits will be needed for memory access. If the condition in line 1098 is not met, memory access is done without SIB bits.

Within the condition of line 1098, the address referenced by the SIB bits is first determined. The address is then placed on the bus, and memory is read. Once the memory data is read, the other operand is fetched from the processor's registers, and the addition operation is performed.



If the condition in line 1112 is met, the *find\_disp* function is called to find the location of the displacement bits. These bits are used to determine the memory address that should be read. After that, the remaining steps are executed in the same way as in the previous condition.

As can be seen, in this function, the addition between the two operands is performed, and after that, the *set\_Eflags* function is called to change the necessary flags based on the instruction and its result. (Figure 4-2-8 and the *BaseFunctions.cpp* file)

```
15 void set_Eflags(sc_lv<32> operand1, sc_lv<32> operand2, sc_lv<32> result, sc_lv<32> &EFLAGS, int mode, string flags_status) //--> flags: false: 0, true: 1, clear: 2
16 {
17     int OF = flags_status[0], SF = flags_status[1], ZF = flags_status[2], AF = flags_status[3], PF = flags_status[4],
18     CF = flags_status[5], TF = flags_status[6], IF = flags_status[7], DF = flags_status[8], NT = flags_status[9], RF = flags_status[10];
19     // ZF (Zero Flag)
20     if (ZF)
21     {
22         if (result.to_int() == 0)
23             EFLAGS[6] = 1;
24         else
25             EFLAGS[6] = 0;
26     }
27     // SF (Sign Flag)
28     if (SF)
29     {
30         if (result[31] == 1)
31             EFLAGS[7] = 1;
32         else
33             EFLAGS[7] = 0;
34     }
35     if (CF)
36     {
37         // CF (Carry Flag)
38     }
39     if (PF)
40     {
41         EFLAGS[2] = check_parity(result);
42     }
43     // OF (Overflow Flag)
44     if (OF)
45     {
46         if (mode == 1) // Add
47         {
48             if ((operand1[31] == 0) && (operand2[31] == 0) && (result[31] == 1))
49                 EFLAGS[11] = 1;
50             else if ((operand1[31] == 1) && (operand2[31] == 1) && (result[31] == 0))
51                 EFLAGS[11] = 1;
52             else
53                 EFLAGS[11] = 0;
54         }
55         else if (mode == 2) // Subtract
56         {
57             if (((operand1[31] ^ operand2[31]) == 1) && ((result[31] ^ operand1[31]) == 1))
58                 EFLAGS[11] = 1;
59             else
60                 EFLAGS[11] = 0;
61         }
62     }
63     cout << "EFLAGS UPDATE : " << EFLAGS << endl;
64 }
```

Figure 4-2-8 function set\_Eflags



Note: If we look at line 1108 in Figure 4-2-6, we see that the result is written to the location of the "operand," which is the pointer to the register. The reason for this is that the sum is supposed to be stored in the register. Once this instruction is completed, the *Instruction\_done* event is triggered to allow the processor to move on to execute the next instructions.

## 4-5- Testbench

To test this system, we first read 8 consecutive memory locations, starting from address 1799. Then we pre-decode 4 of them and execute the instructions in order.

**The first instruction:** Add the content of memory to the register and store the result in the destination register ESP. The memory address is calculated based on the instruction as follows:

$$[\text{EBX}] + \text{disp32} = 20 + 60 = 80$$

Figure 4-5-1 Test result

**The second instruction:** Add the content of the register to memory and store the result in memory. The source register is EBX. The memory address is obtained through the SIB byte and displacement (disp).



```
25 Instruction is :0000000101011100110011101100000XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
26 disp8 is :206
27 scale : 8
28 index is : 30
29 disp8 is :192
30 Addition Called
31 operand 1 is : 20
32 operand 2 is : -1401842134
33 result is : -1401842114
34 EFLAGS UPDATE : XXXXXXXXXXXXXXXXXXXX0XXX10XXX0XX
35 data[-1401842114] written in address[492] at 550 ns
36 EAX Register value: 1
37 EBX Register value: 20
38 ECX Register value: 30
39 EDX Register value: 40
40 EBP Register value: 50
41 ESI Register value: 60
42 EDI Register value: 70
43 ESP Register value: 390880274
```

Figure 4-5-2 Test result

**The third instruction:** Add the content of the immediate value to memory and store the result in memory. The memory address is obtained from the instruction as follows:

[ESI] + disp8

```
Instruction is :100000110100010100010101110000XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
disp8 is :139
imm is: 112
AND Called
operand 1 is memory data : 011100010100000001111001101001
operand 2 is Immediate : 000000000000000000000000000000001100000
result is : 000000000000000000000000000000001100000
EFLAGS UPDATE : XXXXXXXXXXXXXXXX0XXX0XXX1XX
data[-1401842114] written in address[199] at 670 ns
data[96] written in address[199] at 690 ns
EAX Register value: 1
EBX Register value: 20
ECX Register value: 30
EDX Register value: 40
EBP Register value: 50
ESI Register value: 60
EDI Register value: 70
ESP Register value: 390880274
```

Figure 4-5-3 Test result

**The fourth instruction:** The contents of two registers are ANDed together, and the result is stored in the second register. The first register is ESI, and the second register is ECX.



```
64 Instruction is : 001000011111001xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
65 AND Called
66 operand 1 is : 0000000000000000000000000000000011110
67 operand 2 is : 00000000000000000000000000000000111100
68 result is : 00000000000000000000000000000000111100
69 EFLAGS UPDATE : XXXXXXXXXXXXXXXXXXXXXXXX0XXX0XXXX0XX
70 EAX Register value: 1
71 EBX Register value: 20
72 ECX Register value: 30
73 EDX Register value: 40
74 EBP Register value: 50
75 ESI Register value: 28
76 EDI Register value: 70
77 ESP Register value: 390880274
```

Figure 4-5-4 Test result

Now that the internal instruction buffer is emptied, since there are still 4 unprocessed locations in the processor's memory, we will pre-decode them.

Figure 4-5-5 Test result

**Fifth instruction:** The content of memory is going through OR gate with a register and stored in memory. The source register is EDI, and the memory address is calculated from the instruction as follows: [disp32] = 1792

Figure 4-5-6 Test result

**Sixth instruction:** The content of memory is subtracted from the content of a register, and the result is stored in memory. The source register is EAX, and the memory address is calculated from the instruction as follows:

$$[ECX]*2 + [EBP] + disp32 = 1149$$



Figure 4-5-7 Test result

**Seventh instruction:** One is added to the content of memory. The memory address is calculated from the instruction as follows:

$$[\text{ECX}] + [\text{EDX}] = 70$$

```
118 Instruction is :11111111000010000001010xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx  
119 scale : 1  
120 index is : 30  
121 address is : 00000000000000000000000000001000110  
122 Increment Called  
123 operand is memory data : -1784701158  
124 result is : -1784701157  
125 EFLAGS UPDATE : XXXXXXXXXXXXXXXXX0XXX10XXX1XX  
126 data[-1784701157] written in address[70] at 1390 ns  
127 EAX Register value: 290361456  
128 EBX Register value: 20  
129 ECX Register value: 30  
130 EDX Register value: 40  
131 EBP Register value: 50  
132 ESI Register value: 28  
133 EDI Register value: -167043969  
134 ESP Register value: 390880274
```

Figure 4-5-8 Test result

The instructions have been cleared from the buffer, so we read eight consecutive memory locations and pre-decode four of them.

```
135 effective inst: 1111111111001011XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX  
136 effective inst: 11110111011001000110011000100011XXXXXX  
137 effective inst: 1111011111111001XXXXXX  
138 effective inst: 110001111100100000000000000000111111110000000XXXXXX  
139 effective inst: 100010010001001XXXXXXXXXXXX  
140 -----
```

Figure 4-5-9 Test result

**Eighth instruction:** One is subtracted from the content of the register. The register in question is EBX.



```
140
141 Instruction is :111111111001011xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
142 Decrement Called
143 operand is : 20
144 result is : 19
145 EFLAGS UPDATE : xxxxxxxxxxxxxxxxxxxxxxxxxx0xxx0xxx0xx
146 EAX Register value: 290361456
147 EBX Register value: 19
148 ECX Register value: 30
149 EDX Register value: 40
150 EBP Register value: 50
151 ESI Register value: 28
152 EDI Register value: -167043969
153 ESP Register value: 390880274
```

Figure 4-5-10 Test result

**Ninth instruction:** The content of the register is multiplied by the memory and stored in memory. The register in question is EAX, and the memory address is calculated from the instruction as follows:

$$[ESI] + \text{disp8} = 35 + 28 = 63$$

```
155 Instruction is :11110111011001000110011000100011xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
156 scale : 2
157 index is : 0
158 disp8 is :35
159 Multiplication Called
160 operand 1 is : 290361456
161 operand 2 is memory data : 1843654154
162 result is : 2057946208
163 EFLAGS UPDATE : xxxxxxxxxxxxxxxxxxxxxxxxxx0xxx0xxx1xx
164 data[2057946208] written in address[63] at 1890 ns
165 EAX Register value: 290361456
166 EBX Register value: 19
167 ECX Register value: 30
168 EDX Register value: 40
169 EBP Register value: 50
170 ESI Register value: 28
171 EDI Register value: -167043969
172 ESP Register value: 390880274
173 --
```

Figure 4-5-11 Test result

**Tenth instruction:** The contents of the two registers are divided. The first register is EAX, and the second register is ECX. This division is performed as signed.

```
174 Instruction is :11110111111001xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
175 Signed Division Called
176 operand 1 is : 290361456
177 operand 2 is : 30
178 result is : 9678715
179 EAX Register value: 290361456
180 EBX Register value: 19
181 ECX Register value: 9678715
182 EDX Register value: 40
183 EBP Register value: 50
184 ESI Register value: 28
185 EDI Register value: -167043969
186 ESP Register value: 390880274
```

Figure 4-5-12 Test result



**Eleventh instruction:** This is an immediate transfer instruction to the register. The target register is ESP.

```
Instruction is :110001111100010000000000000000001111111100000000XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX  
imm is: 65280  
Move Called  
Source value : 65280  
Destination previous value: 390880274  
Destination current value: 65280  
EAX Register value: 290361456  
EBX Register value: 19  
ECX Register value: 9678715  
EDX Register value: 40  
EBP Register value: 50  
ESI Register value: 28  
EDI Register value: -167043969  
ESP Register value: 65280
```

Figure 4-5-13 Test result

**Twelfth instruction:** The content of the register is written to memory. The register in question is EDX, and the memory address is also the content of EDX.

```
203 Instruction is :1000100100010010XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX  
204 data[40] written in address[40] at 2050 ns  
205 EAX Register value: 290361456  
206 EBX Register value: 19  
207 ECX Register value: 9678715  
208 EDX Register value: 40  
209 EBP Register value: 50  
210 ESI Register value: 28  
211 EDI Register value: -167043969  
212 ESP Register value: 65280  
213
```

Figure 4-5-14 Test result

The instruction buffer is empty again. We will pre-decode the next 4 cells that have been previously fetched.

**Thirteenth instruction:** A comparison between the register and memory that changes the EFLAGS. The memory address is obtained as follows:

$$[\text{ESI}] + \text{disp} \ 32 = 28 + 1280 = 1308$$

The content of memory cell 1308: 10001001110011001010100110000011, which is signed and equal to -1983075965.



Figure 4-5-15 Test result

**Fourteenth instruction:** This instruction is a transfer from memory to register. The destination register is EAX. The memory address is obtained as follows:

Scale \* index + base + disp32 = 1 \* none + [EBX] + 1024 = 1043

The content of this memory cell: 000100111011010011010110110010, which is signed and equal to 333081458.

Figure 4-5-16 Test result

**Fifteenth instruction:** This instruction is the subtraction of a register from memory and storing the result in memory. The register in question is EAX, and the memory address is obtained as follows:  $[ESI] + \text{disp8} = 28 + 200 = 228$



```
249 Instruction is :001010010100011011001000XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
250 disp8 is :200
251 Subtraction Called
252 operand 1 is : 333081458
253 operand 2 is : 440197849
254 result is : -107116391
255 EFLAGS UPDATE : XXXXXXXXXXXXXXXXXXXXXXX0XXX10XXX0XX
256 Addition Called
257 operand 1 is : 333081458
258 operand 2 is : 440197849
259 result is : 773279307
260 EFLAGS UPDATE : XXXXXXXXXXXXXXXXXXXXXXX0XXX00XXX1XX
261 data[773279307] written in address[228] at 2710 ns
262 EAX Register value: 333081458
263 EBX Register value: 19
264 ECX Register value: 9678715
265 EDX Register value: 40
266 EBP Register value: 50
267 ESI Register value: 28
268 EDI Register value: -167043969
269 ESP Register value: 65280
270
```

Figure 4-5-17 Test result

## Reference

- Intel® 64 and IA-32 Architectures Software Developer’s Manual
- Pentium Pro Family Developer’s Manual