

# **EE533 Lab6**

**Quad HW-Threaded ARM ISA Compatible  
Processor Core in NetFPGA**

**Group19**

**Ya-Yi Lin**

**Pin-Chieh Yen**

**Yung-Chun Yang**

**Github Link:** [https://github.com/yungchun1007/EE533\\_Lab6](https://github.com/yungchun1007/EE533_Lab6)

- High-level Design of Datapath
  - Instruction Set Architecture
  - Bubble Sort in C and Assembly
  - Machine Code
  - NetFPGA

## High-level Design of Datapath



## Instruction Set Architecture

|        | 31    | 25 24 | 20 19 | 15 14 | 12 11 | 7 6    | 0 |
|--------|-------|-------|-------|-------|-------|--------|---|
| R-Type | func7 | rs2   | rs1   | func3 | rd    | opcode |   |

| I-Type | imm[11:0] | rs1 | func3 | rd | opcode |  |
|--------|-----------|-----|-------|----|--------|--|
|--------|-----------|-----|-------|----|--------|--|

| S-Type | imm[11:5] | rs2 | rs1 | func3 | imm[4:0] | opcode |  |
|--------|-----------|-----|-----|-------|----------|--------|--|
|--------|-----------|-----|-----|-------|----------|--------|--|

| U-Type | imm[31:12] | rd | opcode |  |  |  |
|--------|------------|----|--------|--|--|--|
|--------|------------|----|--------|--|--|--|

|              | 31        | 25 24      | 20 19 | 15 14 | 12 11 | 7 6     | 0 |        |
|--------------|-----------|------------|-------|-------|-------|---------|---|--------|
| <b>lui</b>   |           | imm[31:12] |       |       | rd    | 0110111 |   | U-Type |
| <b>auipc</b> |           | imm[31:12] |       |       | rd    | 0010111 |   | U-Type |
| <b>addi</b>  | imm[11:0] |            | rs1   | 000   | rd    | 0010011 |   | I-Type |
| <b>slti</b>  | imm[11:0] |            | rs1   | 010   | rd    | 0010011 |   | I-Type |
| <b>sltiu</b> | imm[11:0] |            | rs1   | 011   | rd    | 0010011 |   | I-Type |
| <b>xori</b>  | imm[11:0] |            | rs1   | 100   | rd    | 0010011 |   | I-Type |
| <b>ori</b>   | imm[11:0] |            | rs1   | 110   | rd    | 0010011 |   | I-Type |
| <b>andi</b>  | imm[11:0] |            | rs1   | 111   | rd    | 0010011 |   | I-Type |
| <b>slli</b>  | 0000000   | shamt      | rs1   | 001   | rd    | 0010011 |   | I-Type |
| <b>srl</b>   | 0000000   | shamt      | rs1   | 101   | rd    | 0010011 |   | I-Type |
| <b>srai</b>  | 0100000   | shamt      | rs1   | 101   | rd    | 0010011 |   | I-Type |
| <b>add</b>   | 0000000   | rs2        | rs1   | 000   | rd    | 0110011 |   | R-Type |
| <b>sub</b>   | 0100000   | rs2        | rs1   | 000   | rd    | 0110011 |   | R-Type |
| <b>sll</b>   | 0000000   | rs2        | rs1   | 001   | rd    | 0110011 |   | R-Type |
| <b>slt</b>   | 0000000   | rs2        | rs1   | 010   | rd    | 0110011 |   | R-Type |
| <b>stiu</b>  | 0000000   | rs2        | rs1   | 011   | rd    | 0110011 |   | R-Type |
| <b>xor</b>   | 0000000   | rs2        | rs1   | 100   | rd    | 0110011 |   | R-Type |
| <b>srl</b>   | 0000000   | rs2        | rs1   | 101   | rd    | 0110011 |   | R-Type |
| <b>sra</b>   | 0100000   | rs2        | rs1   | 101   | rd    | 0110011 |   | R-Type |
| <b>or</b>    | 0000000   | rs2        | rs1   | 110   | rd    | 0110011 |   | R-Type |
| <b>and</b>   | 0000000   | rs2        | rs1   | 111   | rd    | 0110011 |   | R-Type |

|             | 31           | 25 24                                   | 20 19 | 15 14 | 12 11       | 7 6     | 0 |        |
|-------------|--------------|-----------------------------------------|-------|-------|-------------|---------|---|--------|
| <b>jal</b>  |              | imm[20], imm[10:1], imm[11], imm[19:12] |       | rd    | 1101111     |         | 0 | J-Type |
| <b>jalr</b> |              | imm[11:0]                               | rs1   | 000   | rd          | 1100111 |   | I-Type |
| <b>beq</b>  | imm[12,10:5] | rs2                                     | rs1   | 000   | imm[4:1,11] | 1100011 |   | B-Type |
| <b>bne</b>  | imm[12,10:5] | rs2                                     | rs1   | 001   | imm[4:1,11] | 1100011 |   | B-Type |
| <b>blt</b>  | imm[12,10:5] | rs2                                     | rs1   | 100   | imm[4:1,11] | 1100011 |   | B-Type |
| <b>bge</b>  | imm[12,10:5] | rs2                                     | rs1   | 101   | imm[4:1,11] | 1100011 |   | B-Type |
| <b>bltu</b> | imm[12,10:5] | rs2                                     | rs1   | 110   | imm[4:1,11] | 1100011 |   | B-Type |
| <b>bgeu</b> | imm[12,10:5] | rs2                                     | rs1   | 111   | imm[4:1,11] | 1100011 |   | B-Type |

|            | 31        | 25 24     | 20 19 | 15 14 | 12 11    | 7 6     | 0 |        |
|------------|-----------|-----------|-------|-------|----------|---------|---|--------|
| <b>lb</b>  |           | imm[11:0] | rs1   | 000   | rd       | 0000011 |   | I-Type |
| <b>lh</b>  |           | imm[11:0] | rs1   | 001   | rd       | 0000011 |   | I-Type |
| <b>lw</b>  |           | imm[11:0] | rs1   | 010   | rd       | 0000011 |   | I-Type |
| <b>lbu</b> |           | imm[11:0] | rs1   | 100   | rd       | 0000011 |   | I-Type |
| <b>lhu</b> |           | imm[11:0] | rs1   | 101   | rd       | 0000011 |   | I-Type |
| <b>sb</b>  | imm[11:5] | rs2       | rs1   | 000   | imm[4:0] | 0100011 |   | S-Type |
| <b>sh</b>  | imm[11:5] | rs2       | rs1   | 001   | imm[4:0] | 0100011 |   | S-Type |
| <b>sw</b>  | imm[11:5] | rs2       | rs1   | 010   | imm[4:0] | 0100011 |   | S-Type |

## Bubble Sort in C

```
C: > EE533 > Lab6 > C sort.c > main()
1  int main() {
2      int array[10] = {323, 123, -455, 2, 98, 125, 10, 65, -56, 0};
3      int i, j, swap;
4      for (i = 0 ; i < 10; i++) {
5          for (j = i+1 ; j < 10 ; j++) {
6              if (array[j] < array[i]) {
7                  swap = array[j];
8                  array[j] = array[i];
9                  array[i] = swap;
10             }
11         }
12     }
13 }
```

## Bubble Sort in Assembly

```
C: > EE533 > Lab6 > ASM sort_rv32.s
 1 | .file    "sort.c"
 2 | .option  nopic
 3 | .attribute arch, "rv32i2p1_m2p0_zmmul1p0"
 4 | .attribute unaligned_access, 0
 5 | .attribute stack_align, 16
 6 | .text
 7 | .section   .rodata
 8 | .align    2
 9 | .LC0:
10 |     .word    323
11 |     .word    123
12 |     .word    -455
13 |     .word    2
14 |     .word    98
15 |     .word    125
16 |     .word    10
17 |     .word    65
18 |     .word    -56
19 |     .word    0
20 |     .text
21 |     .align   2
22 |     .globl   main
23 |     .type    main, @function
24 | main:
25 |     addi    sp,sp,-80
26 |     sw     ra,76(sp)
27 |     sw     s0,72(sp)
28 |     addi    s0,sp,80
29 |     lui    a5,%hi(.LC0)
30 |     addi    a5,a5,%lo(.LC0)
31 |     lw     t3,0(a5)
32 |     lw     t1,4(a5)
33 |     lw     a7,8(a5)
34 |     lw     a6,12(a5)
35 |     lw     a0,16(a5)
36 |     lw     a1,20(a5)
37 |     lw     a2,24(a5)
38 |     lw     a3,28(a5)
39 |     lw     a4,32(a5)
40 |     sw     t3,-68(s0)
41 |     sw     t1,-64(s0)
42 |     sw     a7,-60(s0)
43 |     sw     a6,-56(s0)
44 |     sw     a0,-52(s0)
45 |     sw     a1,-48(s0)
```

C: > EE533 > Lab6 > **asm** sort\_rv32.s

```
24    main:  
46        sw  a2,-44($0)  
47        sw  a3,-40($0)  
48        sw  a4,-36($0)  
49        lw   a5,36(a5)  
50        sw  a5,-32($0)  
51        sw  zero,-20($0)  
52        j   .L2  
53    .L6:  
54        lw   a5,-20($0)  
55        addi a5,a5,1  
56        sw  a5,-24($0)  
57        j   .L3  
58    .L5:  
59        lw   a4,-24($0)  
60        addi a5,$0,-68  
61        slli a4,a4,2  
62        add a5,a4,a5  
63        lw   a4,0(a5)  
64        lw   a3,-20($0)  
65        addi a5,$0,-68  
66        slli a3,a3,2  
67        add a5,a3,a5  
68        lw   a5,0(a5)  
69        bge a4,a5,.L4  
70        lw   a4,-24($0)  
71        addi a5,$0,-68  
72        slli a4,a4,2  
73        add a5,a4,a5  
74        lw   a5,0(a5)  
75        sw  a5,-28($0)  
76        lw   a4,-20($0)  
77        addi a5,$0,-68  
78        slli a4,a4,2  
79        add a5,a4,a5  
80        lw   a4,0(a5)  
81        lw   a3,-24($0)  
82        addi a5,$0,-68  
83        slli a3,a3,2  
84        add a5,a3,a5  
85        sw  a4,0(a5)  
86        lw   a4,-20($0)  
87        addi a5,$0,-68  
88        slli a4,a4,2  
89        add a5,a4,a5
```

```
90    lw  a4,-28(s0)
91    sw  a4,0(a5)
92    .L4:
93    lw  a5,-24(s0)
94    addi   a5,a5,1
95    sw  a5,-24(s0)
96    .L3:
97    lw  a4,-24(s0)
98    li  a5,9
99    ble a4,a5,.L5
100   lw  a5,-20(s0)
101   addi   a5,a5,1
102   sw  a5,-20(s0)
103   .L2:
104   lw  a4,-20(s0)
105   li  a5,9
106   ble a4,a5,.L6
107   li  a5,0
108   mv  a0,a5
109   lw  ra,76(sp)
110   lw  s0,72(sp)
111   addi   sp,sp,80
112   jr  ra
113   .size  main, .-main
114   .ident "GCC: (xPack GNU RISC-V Embedded GCC x86_64) 15.2.0"
115   .section  .note.GNU-stack,"",@progbits
116
```

## Bubble Sort in Machine Code

### 1. Compile C code to RV64I binary (ELF format)

```
riscv64-unknown-elf-gcc -march=rv64i -mabi=lp64 sort.c -o
sort.elf
```

### 2. Then use objdump to view the disassembled code

```
riscv64-unknown-elf-objdump -d sort.elf > sort.dump
```

```
C: > EE533 > Lab6 > └── machine_code.txt
1   |
2   sort.o:      file format elf32-littleriscv
3
4
5   Disassembly of section .text:
6
7   00000000 <main>:
8   | 0: fb010113          addi  sp,sp,-80
9   | 4: 04112623          sw    ra,76(sp)
10  | 8: 04812423          sw    s0,72(sp)
11  | c: 05010413          addi  s0,sp,80
12  | 10: 000007b7         lui   a5,0x0
13  | 14: 00078793         mv    a5,a5
14  | 18: 0007ae03         lw    t3,0(a5) # 0 <main>
15  | 1c: 0047a303         lw    t1,4(a5)
16  | 20: 0087a883         lw    a7,8(a5)
17  | 24: 00c7a803         lw    a6,12(a5)
18  | 28: 0107a503         lw    a0,16(a5)
19  | 2c: 0147a583         lw    a1,20(a5)
20  | 30: 0187a603         lw    a2,24(a5)
21  | 34: 01c7a683         lw    a3,28(a5)
22  | 38: 0207a703         lw    a4,32(a5)
23  | 3c: fbc42e23         sw    t3,-68(s0)
24  | 40: fc642023         sw    t1,-64(s0)
25  | 44: fd142223         sw    a7,-60(s0)
26  | 48: fd042423         sw    a6,-56(s0)
27  | 4c: fca42623         sw    a0,-52(s0)
28  | 50: fcb42823         sw    a1,-48(s0)
29  | 54: fcc42a23         sw    a2,-44(s0)
30  | 58: fcd42c23         sw    a3,-40(s0)
31  | 5c: fce42e23         sw    a4,-36(s0)
32  | 60: 0247a783         lw    a5,36(a5)
33  | 64: fef42023         sw    a5,-32(s0)
34  | 68: fe042623         sw    zero,-20(s0)
35  | 6c: 0bc0006f          j    128 <.L2>
36
37   00000070 <.L6>:
38   | 70: fec42783         lw    a5,-20(s0)
39   | 74: 00178793         addi a5,a5,1
40   | 78: fef42423         sw    a5,-24(s0)
41   | 7c: 0940006f          j    110 <.L3>
42
43   00000080 <.L5>:
44   | 80: fe842703         lw    a4,-24(s0)
45   | 84: fbc40793         addi a5,s0,-68
```

|    |                 |                     |
|----|-----------------|---------------------|
| 46 | 88: 00271713    | slli a4,a4,0x2      |
| 47 | 8c: 00f707b3    | add a5,a4,a5        |
| 48 | 90: 0007a703    | lw a4,0(a5)         |
| 49 | 94: fec42683    | lw a3,-20(s0)       |
| 50 | 98: fbc40793    | addi a5,s0,-68      |
| 51 | 9c: 00269693    | slli a3,a3,0x2      |
| 52 | a0: 00f687b3    | add a5,a3,a5        |
| 53 | a4: 0007a783    | lw a5,0(a5)         |
| 54 | a8: 04f75e63    | bge a4,a5,104 <.L4> |
| 55 | ac: fe842703    | lw a4,-24(s0)       |
| 56 | b0: fbc40793    | addi a5,s0,-68      |
| 57 | b4: 00271713    | slli a4,a4,0x2      |
| 58 | b8: 00f707b3    | add a5,a4,a5        |
| 59 | bc: 0007a783    | lw a5,0(a5)         |
| 60 | c0: fef42223    | sw a5,-28(s0)       |
| 61 | c4: fec42703    | lw a4,-20(s0)       |
| 62 | c8: fbc40793    | addi a5,s0,-68      |
| 63 | cc: 00271713    | slli a4,a4,0x2      |
| 64 | d0: 00f707b3    | add a5,a4,a5        |
| 65 | d4: 0007a703    | lw a4,0(a5)         |
| 66 | d8: fe842683    | lw a3,-24(s0)       |
| 67 | dc: fbc40793    | addi a5,s0,-68      |
| 68 | e0: 00269693    | slli a3,a3,0x2      |
| 69 | e4: 00f687b3    | add a5,a3,a5        |
| 70 | e8: 00e7a023    | sw a4,0(a5)         |
| 71 | ec: fec42703    | lw a4,-20(s0)       |
| 72 | f0: fbc40793    | addi a5,s0,-68      |
| 73 | f4: 00271713    | slli a4,a4,0x2      |
| 74 | f8: 00f707b3    | add a5,a4,a5        |
| 75 | fc: fe442703    | lw a4,-28(s0)       |
| 76 | 100: 00e7a023   | sw a4,0(a5)         |
| 77 |                 |                     |
| 78 | 00000104 <.L4>: |                     |
| 79 | 104: fe842783   | lw a5,-24(s0)       |
| 80 | 108: 00178793   | addi a5,a5,1        |
| 81 | 10c: fef42423   | sw a5,-24(s0)       |
| 82 |                 |                     |
| 83 | 00000110 <.L3>: |                     |
| 84 | 110: fe842703   | lw a4,-24(s0)       |
| 85 | 114: 00900793   | li a5,9             |
| 86 | 118: f6e7d4e3   | bge a5,a4,80 <.L5>  |
| 87 | 11c: fec42783   | lw a5,-20(s0)       |
| 88 | 120: 00178793   | addi a5,a5,1        |
| 89 | 124: fef42623   | sw a5,-20(s0)       |

```

90
91    00000128 <.L2>:
92        128: fec42703           lw    a4,-20($0)
93        12c: 00900793          li    a5,9
94        130: f4e7d0e3          bge   a5,a4,70 <.L6>
95        134: 00000793          li    a5,0
96        138: 00078513          mv    a0,a5
97        13c: 04c12083          lw    ra,76(sp)
98        140: 04812403          lw    $0,72(sp)
99        144: 05010113          addi  sp,sp,80
100       148: 00008067          ret
101

```

## Use python script to extract the machine code generated

```

C: > EE533 > Lab6 > code > script.py
1  import re
2
3  def generate_verilog(mem_file, asm_file):
4      with open(asm_file, 'r') as asm_f, open(mem_file, 'w') as mem_f:
5          lines = asm_f.readlines()
6
7          index = 0
8
9          for line in lines:
10             line = line.strip()
11             if not line or line.startswith('file format'):
12                 continue
13
14             match = re.match(r'^([0-9a-fA-F]+):\s+([0-9a-fA-F]{8})\s+(.+)$', line)
15             if match:
16                 instruction = match.group(2)
17                 comment = match.group(3) if match.group(3) else ''
18                 mem_f.write(f"inst_mem[{index}] = 32'h{instruction};           // {comment}\n")
19                 index += 1
20             else:
21                 print(f"Invalid instruction format || {line}")
22
23
24     asm_file = 'sort_machine.s'
25     mem_file = 'instruction.text'
26
27
28     generate_verilog(mem_file, asm_file)
29

```

## The transcript of a sequence of commands typed to the interface

- SW/HW interface in pipeline module

```
// pipeline_netfpga.v

// Software registers
wire [7:0] mem_raddr_ver;

// Hardware registers
wire [63:0] mem_rdata_ver;
wire [31:0] mem_rdata_ver_high;
wire [31:0] mem_rdata_ver_low;

// Verification(D-MEM)
assign mem_rdata_ver = dmem_rdata;
assign mem_rdata_ver_low = mem_rdata_ver[63:32];
assign mem_rdata_ver_high = mem_rdata_ver[31:0];

// ......

generic_regs
#(
    .UDP_REG_SRC_WIDTH  (UDP_REG_SRC_WIDTH),
    .TAG                (`PIPELINE_BLOCK_ADDR),           // Tag -- eg. MODULE_TAG
    .REG_ADDR_WIDTH     (`PIPELINE_REG_ADDR_WIDTH),        // Width of block addresses -- eg. MODULE_REG_ADDR_WIDTH
    .NUM_COUNTERS       (0),                                // Number of counters
    .NUM_SOFTWARE_REGS  (1),                                // Number of sw regs
    .NUM_HARDWARE_REGS  (2)                                // Number of hw regs
) module_regs (
    .reg_req_in         (reg_req_in),
    .reg_ack_in         (reg_ack_in),
    .reg_rd_wr_L_in    (reg_rd_wr_L_in),
    .reg_addr_in        (reg_addr_in),
    .reg_data_in        (reg_data_in),
    .reg_src_in         (reg_src_in),

    .reg_req_out        (reg_req_out),
    .reg_ack_out        (reg_ack_out),
    .reg_rd_wr_L_out   (reg_rd_wr_L_out),
    .reg_addr_out       (reg_addr_out),
    .reg_data_out       (reg_data_out),
    .reg_src_out         (reg_src_out),

    // --- counters interface
    .counter_updates   (),
    .counter_decrement(),

    // --- SW regs interface
    .software_regs     (mem_raddr_ver),

    // --- HW regs interface
    .hardware_regs     ({mem_rdata_ver_high, mem_rdata_ver_low}),
    .clk               (clk),
    .reset             (reset)
);
```

## ● Registers in pipeline.xml

```
<?xml version="1.0" encoding="UTF-8"?>
<nf:module xmlns:nf="http://www.NetFPGA.org/NF2_register_system" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:
  <nf:name>pipeline</nf:name>
  <nf:prefix>pipeline</nf:prefix>
  <nf:location>udp</nf:location>
  <nf:description>Registers for PIPELINE</nf:description>
  <nf:blocksizes>64</nf:blocksizes>
  <nf:registers>
    <nf:register>
      <nf:name>mem_raddr_ver</nf:name>
      <nf:description>D-MEM Read Address</nf:description>
      <nf:type>generic_software32</nf:type>
    </nf:register>
    <nf:register>
      <nf:name>mem_rdata_ver_high</nf:name>
      <nf:description>Upper 32 bits of D-MEM Read Data</nf:description>
      <nf:type>generic_hardware32</nf:type>
    </nf:register>
    <nf:register>
      <nf:name>mem_rdata_ver_low</nf:name>
      <nf:description>Lower 32 bits of D-MEM Read Data</nf:description>
      <nf:type>generic_hardware32</nf:type>
    </nf:register>
  </nf:registers>
</nf:module>
```

**The internal memory dump that shows the array data before and after sort program execution**





The last line is swapped to -455:

## Commit log

```
PS C:\EE533\Lab6\code> git commit -m "Commit code"
[master (root-commit) a3c8c83] Commit code
 28 files changed, 1953 insertions(+)
 create mode 100644 add_4.v
 create mode 100644 add_pc.v
 create mode 100644 alu.v
 create mode 100644 bubble_sort_asm.txt
 create mode 100644 controller.v
 create mode 100644 cpu.v
 create mode 100644 data_mem.v
 create mode 100644 datapath.v
 create mode 100644 ex_me.v
 create mode 100644 forward_unit.v
 create mode 100644 hazard_detection_unit.v
 create mode 100644 id.v
 create mode 100644 id_ex.v
 create mode 100644 if_id.v
 create mode 100644 imem.v
 create mode 100644 imm.v
 create mode 100644 instruction1.text
 create mode 100644 instruction_mem.v
 create mode 100644 me_wb.v
 create mode 100644 mux_2.v
 create mode 100644 mux_3.v
 create mode 100644 next_pc.v
 create mode 100644 pc.v
 create mode 100644 reg_file.v
 create mode 100644 regfile.v
 create mode 100644 script.py
 create mode 100644 sort.c
 create mode 100644 sort_machine1.s
```

```
Windows PowerShell      X + ^

create mode 100644 id_ex.v
create mode 100644 if_id.v
create mode 100644 imem.v
create mode 100644 imm.v
create mode 100644 instruction1.text
create mode 100644 instruction_mem.v
create mode 100644 me_wb.v
create mode 100644 mux_2.v
create mode 100644 mux_3.v
create mode 100644 next_pc.v
create mode 100644 pc.v
create mode 100644 reg_file.v
create mode 100644 regfile.v
create mode 100644 script.py
create mode 100644 sort.c
create mode 100644 sort_machine1.s
PS C:\EE533\Lab6\code> git branch -M main
PS C:\EE533\Lab6\code> git pull origin main --allow-unrelated-histories
remote: Enumerating objects: 7, done.
remote: Counting objects: 100% (7/7), done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 7 (delta 0), reused 0 (delta 0), pack-reused 0 (from 0)
Unpacking objects: 100% (7/7), 2.51 KiB | 71.00 KiB/s, done.
From https://github.com/yungchun1007/EE533_Lab6
 * branch            main      -> FETCH_HEAD
 * [new branch]      main      -> origin/main
Merge made by the 'ort' strategy.
 README.md | 1 +
 1 file changed, 1 insertion(+)
 create mode 100644 README.md
PS C:\EE533\Lab6\code> |
```

```
Windows PowerShell      X + ^

create mode 100644 reg_file.v
create mode 100644 regfile.v
create mode 100644 script.py
create mode 100644 sort.c
create mode 100644 sort_machine1.s
PS C:\EE533\Lab6\code> git branch -M main
PS C:\EE533\Lab6\code> git pull origin main --allow-unrelated-histories
remote: Enumerating objects: 7, done.
remote: Counting objects: 100% (7/7), done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 7 (delta 0), reused 0 (delta 0), pack-reused 0 (from 0)
Unpacking objects: 100% (7/7), 2.51 KiB | 71.00 KiB/s, done.
From https://github.com/yungchun1007/EE533_Lab6
 * branch            main      -> FETCH_HEAD
 * [new branch]      main      -> origin/main
Merge made by the 'ort' strategy.
 README.md | 1 +
 1 file changed, 1 insertion(+)
 create mode 100644 README.md
PS C:\EE533\Lab6\code> git push -u origin main
Enumerating objects: 33, done.
Counting objects: 100% (33/33), done.
Delta compression using up to 20 threads
Compressing objects: 100% (32/32), done.
Writing objects: 100% (32/32), 14.49 KiB | 2.42 MiB/s, done.
Total 32 (delta 2), reused 0 (delta 0), pack-reused 0 (from 0)
remote: Resolving deltas: 100% (2/2), done.
To https://github.com/yungchun1007/EE533_Lab6.git
 095bf3a..ec9d4d4  main -> main
branch 'main' set up to track 'origin/main'.
PS C:\EE533\Lab6\code> |
```