| module ram0( | 
 |     // Write port | 
 |     input wrclk, | 
 |     input [15:0] di, | 
 |     input wren, | 
 |     input [9:0] wraddr, | 
 |     // Read port | 
 |     input rdclk, | 
 |     input rden, | 
 |     input [9:0] rdaddr, | 
 |     output reg [15:0] do); | 
 |  | 
 |     (* ram_style = "block" *) reg [15:0] ram[0:1023]; | 
 |  | 
 |     initial begin | 
 |         ram[0] = 16'b00000000_00000001; | 
 |         ram[1] = 16'b10101010_10101010; | 
 |         ram[2] = 16'b01010101_01010101; | 
 |         ram[3] = 16'b11111111_11111111; | 
 |         ram[4] = 16'b11110000_11110000; | 
 |         ram[5] = 16'b00001111_00001111; | 
 |         ram[6] = 16'b11001100_11001100; | 
 |         ram[7] = 16'b00110011_00110011; | 
 |         ram[8] = 16'b00000000_00000010; | 
 |         ram[9] = 16'b00000000_00000100; | 
 |     end | 
 |  | 
 |     always @ (posedge wrclk) begin | 
 |         if(wren == 1) begin | 
 |             ram[wraddr] <= di; | 
 |         end | 
 |     end | 
 |  | 
 |     always @ (posedge rdclk) begin | 
 |         if(rden == 1) begin | 
 |             do <= ram[rdaddr]; | 
 |         end | 
 |     end | 
 |  | 
 | endmodule | 
 |  | 
 | module top ( | 
 |     input  wire clk, | 
 |  | 
 |     input  wire rx, | 
 |     output wire tx, | 
 |  | 
 |     input  wire [15:0] sw, | 
 |     output wire [15:0] led | 
 | ); | 
 |     wire rden; | 
 |     reg wren; | 
 |     wire [9:0] rdaddr; | 
 |     wire [9:0] wraddr; | 
 |     wire [15:0] di; | 
 |     wire [15:0] do; | 
 |     ram0 ram( | 
 |         .wrclk(clk), | 
 |         .di(di), | 
 |         .wren(wren), | 
 |         .wraddr(wraddr), | 
 |         .rdclk(clk), | 
 |         .rden(rden), | 
 |         .rdaddr(rdaddr), | 
 |         .do(do) | 
 |     ); | 
 |  | 
 |     reg [9:0] address_reg; | 
 |     reg [15:0] data_reg; | 
 |     reg [15:0] out_reg; | 
 |  | 
 |     assign rdaddr = address_reg; | 
 |     assign wraddr = address_reg; | 
 |  | 
 |     // display_mode == 00 -> ram[address_reg] | 
 |     // display_mode == 01 -> address_reg | 
 |     // display_mode == 10 -> data_reg | 
 |     wire [1:0] display_mode; | 
 |  | 
 |     // input_mode == 00 -> in[9:0] -> address_reg | 
 |     // input_mode == 01 -> in[7:0] -> data_reg[7:0] | 
 |     // input_mode == 10 -> in[7:0] -> data_reg[15:8] | 
 |     // input_mode == 11 -> data_reg -> ram[address_reg] | 
 |     wire [1:0] input_mode; | 
 |  | 
 |     // WE == 0 -> address_reg and data_reg unchanged. | 
 |     // WE == 1 -> address_reg or data_reg is updated because on input_mode. | 
 |     wire we; | 
 |  | 
 |     assign display_mode[0] = sw[14]; | 
 |     assign display_mode[1] = sw[15]; | 
 |  | 
 |     assign input_mode[0] = sw[12]; | 
 |     assign input_mode[1] = sw[13]; | 
 |  | 
 |     assign we = sw[11]; | 
 |     assign led = out_reg; | 
 |     assign di = data_reg; | 
 |     assign rden = 1; | 
 |  | 
 |     initial begin | 
 |         address_reg = 10'b0; | 
 |         data_reg = 16'b0; | 
 |         out_reg = 16'b0; | 
 |     end | 
 |  | 
 |     always @ (posedge clk) begin | 
 |         if(display_mode == 0) begin | 
 |             out_reg <= do; | 
 |         end else if(display_mode == 1) begin | 
 |             out_reg <= address_reg; | 
 |         end else if(display_mode == 2) begin | 
 |             out_reg <= data_reg; | 
 |         end | 
 |  | 
 |         if(we == 1) begin | 
 |             if(input_mode == 0) begin | 
 |                 address_reg <= sw[9:0]; | 
 |                 wren <= 0; | 
 |             end else if(input_mode == 1) begin | 
 |                 data_reg[7:0] <= sw[7:0]; | 
 |                 wren <= 0; | 
 |             end else if(input_mode == 2) begin | 
 |                 data_reg[15:8] <= sw[7:0]; | 
 |                 wren <= 0; | 
 |             end else if(input_mode == 3) begin | 
 |                 wren <= 1; | 
 |             end | 
 |         end | 
 |     end | 
 |  | 
 |     // Uart loopback | 
 |     assign tx = rx; | 
 | endmodule |