# Supplementary B1: Full Vivado Xilinx Block Diagram of Cortex-M0 Microprocessor

\*\*Parent Project\*\*: Innovative Hardware Accelerator Architecture for FPGA-Based General-Purpose RISC Microprocessors (Article)

\*\*Author\*\*: Dr. Ehsan Ali

\*\*Email\*\*: <ehssan.aali@gmail.com>

\*\*Last update\*\*: 26th October, 2024.

\*\*URL: https://github.com/ehsan-ali-th/cortex\_m0\_MA/tree/master/Supplementaries

bus\_matrix\_0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAAMCAYAAABvEu28AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAkUlEQVQokc3QvQnDMBQE4HviEaJ5NIBH0CbeIJX28AKpMog3ceXChOjnUiUYkQQJXORAIF3xwQnLlrlsmcM4cRin93295ytJtB6DzpAUAHA+0PnAGOMZQD8kIty/SymmGyJpUkqnCtJuSESKqj72nbV2BQBtRZwP/NU3Q/PtIp+AV9/92d9yGNQ8rU499f+mPQHJ/V0OdjRGqAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAACjUlEQVRYhcWXT1baUBTGfzdiizOWQIc4koOtx1HjDhI3oK7A4wp4uAF1BdINlOzAzNSWHhiVYekOMpP6590OIJiAREmhfOdkkJub+325ufe9+4ScaF333Embv1sJ540jcxCWnTU5VsUF3coI2RUhtE964e9W+v8soHXdK4tQRzh8q9gxlKYqjSwhmQJatz0jUJ+beEoHDX+nYt4soNXplORP8SzXV89W0dT3gxO/Wo2S5sKLqh6KLQR3YeQAwqE8FMvAXtLsTPoFN71LdMHkMRQ3uOldpnUl0Lr96QnSWgp5Sof6/s5mkBLQ6nRKcr/xC7S0bAEgkb67++BXq9FzDQyKJXX0YvnkAAqDYgmIXnVdNlI1sOWZcsGRw6TNIpG1NugGph/btvcbZmZEq2E7MCHAtmdcHHEB2l/rL75TmLgpq6YXHkFZE6l/9Mze98B0ASZ9Uv6OAIQAOOImfF8XkI6kTQBUDoGSdZw64AOI0BgKkc+gbtKG1XBmzHkEiOVLOzBhzT8tg7oo4+6I07m93zA6WjNmpTi3AHU4qO2bA3T4hYjt5yHILWCU+hjRkx2leMGYWorHGNbAqE+lm+yCRSKzBnD4PaxidWue8X4EJshLVPNPr8ax1XbbgTmBrAwAj1bPibMgcpaXfAh140vFGU9UqQw8Qr8waqdHpd8NTFTzzJE4sgXDhSr1K6yGo75/GTOeW0t/2nlFeN4Nr3tlnAVOQK/B0vR3K/3nX1AcRHK/cfzftuPi3TkkitCvViPFHi2fHBR7FM+GqS7wdzYDlOaS2ZvxNAQzpuLgW+9qKXOhEHqfKtlDKYCuD/yFZ0Jp6vrAn9aUgZUdTFIiVnk0mxSyksNphiB30pbneP4X8RMbfPKhPqUAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAACjUlEQVRYhcWXT1baUBTGfzdiizOWQIc4koOtx1HjDhI3oK7A4wp4uAF1BdINlOzAzNSWHhiVYekOMpP6590OIJiAREmhfOdkkJub+325ufe9+4ScaF333Embv1sJ540jcxCWnTU5VsUF3coI2RUhtE964e9W+v8soHXdK4tQRzh8q9gxlKYqjSwhmQJatz0jUJ+beEoHDX+nYt4soNXplORP8SzXV89W0dT3gxO/Wo2S5sKLqh6KLQR3YeQAwqE8FMvAXtLsTPoFN71LdMHkMRQ3uOldpnUl0Lr96QnSWgp5Sof6/s5mkBLQ6nRKcr/xC7S0bAEgkb67++BXq9FzDQyKJXX0YvnkAAqDYgmIXnVdNlI1sOWZcsGRw6TNIpG1NugGph/btvcbZmZEq2E7MCHAtmdcHHEB2l/rL75TmLgpq6YXHkFZE6l/9Mze98B0ASZ9Uv6OAIQAOOImfF8XkI6kTQBUDoGSdZw64AOI0BgKkc+gbtKG1XBmzHkEiOVLOzBhzT8tg7oo4+6I07m93zA6WjNmpTi3AHU4qO2bA3T4hYjt5yHILWCU+hjRkx2leMGYWorHGNbAqE+lm+yCRSKzBnD4PaxidWue8X4EJshLVPNPr8ax1XbbgTmBrAwAj1bPibMgcpaXfAh140vFGU9UqQw8Qr8waqdHpd8NTFTzzJE4sgXDhSr1K6yGo75/GTOeW0t/2nlFeN4Nr3tlnAVOQK/B0vR3K/3nX1AcRHK/cfzftuPi3TkkitCvViPFHi2fHBR7FM+GqS7wdzYDlOaS2ZvxNAQzpuLgW+9qKXOhEHqfKtlDKYCuD/yFZ0Jp6vrAn9aUgZUdTFIiVnk0mxSyksNphiB30pbneP4X8RMbfPKhPqUAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAAATCAYAAABsmQZ/AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAs0lEQVRIiWP8//8/Aww45M//z8DAwHBgYiIjNj61ABM1DRvUlrJQ0zAvLy92WVnZf1JSUn8ZGBgY6uvr/9HUUkZGRsb/////RBdPTEzkmD9//g9kMaoF73/kFIkE3r59i2EHzeOUg4OD+pY2NjYyOTo6soSFhbFhk2djY8Owg+I4ra+v/4crwTAwMDAsWbLkE1UtNfZvxhqP+MDZjbWMQy+fnt1YS1bxOHKKwVFLRy2lCgAAO2QxPubRAYwAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAAATCAYAAABsmQZ/AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAs0lEQVRIiWP8//8/Aww45M//z8DAwHBgYiIjNj61ABM1DRvUlrJQ0zAvLy92WVnZf1JSUn8ZGBgY6uvr/9HUUkZGRsb/////RBdPTEzkmD9//g9kMaoF73/kFIkE3r59i2EHzeOUg4OD+pY2NjYyOTo6soSFhbFhk2djY8Owg+I4ra+v/4crwTAwMDAsWbLkE1UtNfZvxhqP+MDZjbWMQy+fnt1YS1bxOHKKwVFLRy2lCgAAO2QxPubRAYwAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAAATCAYAAABsmQZ/AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAs0lEQVRIiWP8//8/Aww45M//z8DAwHBgYiIjNj61ABM1DRvUlrJQ0zAvLy92WVnZf1JSUn8ZGBgY6uvr/9HUUkZGRsb/////RBdPTEzkmD9//g9kMaoF73/kFIkE3r59i2EHzeOUg4OD+pY2NjYyOTo6soSFhbFhk2djY8Owg+I4ra+v/4crwTAwMDAsWbLkE1UtNfZvxhqP+MDZjbWMQy+fnt1YS1bxOHKKwVFLRy2lCgAAO2QxPubRAYwAAAAASUVORK5CYII=)

clk\_wiz\_0

cortex\_m0\_HRDATA[31:0]

CLK\_IN1\_D

reset

CLK

locked

Clocking Wizard

clk reset

cortex\_m0\_HADDR[31:0] cortex\_m0\_HWDATA[31:0] cortex\_m0\_HWRITE cortex\_m0\_HSIZE[2:0] code\_bram\_DOUTA[31:0]

data\_bram\_DOUTA[31:0]

code\_bram\_ADDRA[17:0] code\_bram\_DINA[31:0] code\_bram\_ENA code\_bram\_WEA[3:0] data\_bram\_ADDRA[14:0] data\_bram\_DINA[31:0] data\_bram\_ENA

data\_bram\_WEA[3:0]

BRAM\_32KB\_DATA

BRAM\_PORTA

addra[14:0] clka dina[31:0] douta[31:0] ena wea[3:0]

bus\_matrix\_v1\_0

Block Memory Generator

cortex\_m0\_core\_0

BRAM\_256KB\_CODE

dout[0:0]

Constant

constant\_0\_16bit

HADDR[31:0] HBURST[2:0] HMASTLOCK HPROT[3:0] HSIZE[2:0] HTRANS[1:0] HWDATA[31:0] HWRITE LOCKUP SLEEPING SYSTESETREQ

TXEV

accel\_code\_bram\_DINB[31:0] accel\_code\_bram\_ADDRB[31:0] accel\_code\_bram\_ENB accel\_code\_bram\_WEB[3:0]

xlslice\_0

Din[31:0]

Dout[15:0]

HCLK

constant\_1

dout[0:0]

Constant

HRESETn HRDATA[31:0] HREADY HRESP

NMI IRQ[15:0] RXEV

accel\_code\_bram\_DOUTB[31:0]

Slice

xlconcat\_0

xlconstant\_0

In0[15:0]

In1[1:0]

dout[17:0]

dout[1:0]

constant\_0 Constant

Concat

BRAM\_PORTA

addra[17:0] clka dina[31:0] douta[31:0] ena wea[3:0]

BRAM\_PORTB

addrb[17:0] clkb dinb[31:0] doutb[31:0] enb web[3:0]

Block Memory Generator

dout[15:0]

cortex\_m0\_core\_v1\_0

Constant

clk\_300mhz reset

LED0

LED1