HW7-memory_concepts

docx

School

Idaho State University *

*We aren’t endorsed by this school

Course

0025

Subject

Electrical Engineering

Date

Jan 9, 2024

Type

docx

Pages

13

Report

Uploaded by CoachBadgerPerson360

ECEN 340 Homework 7 – Memories (84 points, 4 points each) Name: _____Morgan Yang__________________________ Memory with bi-directional data busses present new challenges to the engineer. It is also important to be able to understand the code written by another engineer. The Verilog modules at the end of this assignment are to be used to answer the following questions: 1) How many multi-dimentional memory arrays are instantiated in this design as a module? T wo . The input memory array and the output memory array. 2) What type of memory arrays are used in this design? a) Static Random Access Memory (SRAM) with a single 3-state data bus b) Dynamic Random Access Memory (DRAM) with dedicated input and output data busses c) Read Only Memory (ROM) d) Static Random Access Memory (SRAM) with dedicated input and output data busses 3a) When using memory with bi-directional (3-state) data buses, how is contention avoided? The output buffers of the memory need to be set to a high impedence when data is written to the array. The write path needs to be set to high impedence when reading from the memory. 3b) How many bi-directional (3-state) busses exist in this design? Two 3c) Which signals are used to control the 3-state busses in this design?
4) Besides using memory arrays, this design uses discrete memory elements (flip-flops) to complete specialized tasks. How are flip flops used to: a) Debounce a push-button switch. A push button switch can create multiple signals, so flip-flops and latches can be used to ensure that only one of those signals is acted on to store a given value to the memory arrays. b) Remember the last button press (left and right pushbuttons). In thw program, there is a conditional statement within the always block. The flip-flops can remember button presses in congruence with the clock signals. When a button is pressed, that signal is sent and won’t change again until the next input comes with a new clock cycle c) Increment/decrement a memory address. The inc_addr and dec_addr signals are fed into flip flops to generate a depayed version of these signals called inc_addr_tm1 and dec_addr_tm1. 5) What happens when you: a) Press and release the left button by itself? To select the input memory banks b) Press and hold the left button by itself? Always select the input memory banks c) Press and release the right button by itself? To select the output memory banks d) Press and hold the right button by itself? Always select the output memory banks
e) Press the top button by itself? To increment memory addresses d) Press the bottom button by itself? To decrement memory addresses e) Simultaneously press the left and center buttons? To execute an “inc_addr_all” operation d) Simultaneously press the right and center buttons? To increment address pointer at 100MHz starting from the current location, perform a math function on the input memory data, and then store the result into the second memory bank. e) Simultaneously press the top and bottom buttons? To clear the memory address to zero 6) What is written to the output memory? The output data is the sum of the first 8 bits and the last 8 bits of the addressed input memory. 7) What math operation is performed when writing to the output memory? Addition 8) What is the execution rate of the math operation? 100 MHz 9) Why do you think the output memory address (OM_addr) must be delayed by one clock cycle relative to the input memory address (IM_addr)? The output memory address is delayed by one clock cycle because the clock needs to get through an additional full cycle in order for the input to be acted upon. This ensures there are no contention conflicts
Your preview ends here
Eager to read complete document? Join bartleby learn and gain access to the full version
  • Access to all documents
  • Unlimited textbook solutions
  • 24/7 expert homework help
module memory_top( input clk, //100MHz clk. input [15:0] sw, //Data for input memory. input btnC, //Used with other buttons to select an operation input btnU, //Increment the memory address by one. input btnD, //Decrement the memory address by one. input btnL, //Select the input memory bank. input btnR, //Select the output memory bank. output [3:0] an, //The anode drivers for the 7-seg display. output [6:0] seg, //The 7-segments. It is used to display the data in memory. output dp, //The decimal place on the 7-seg display. output [15:0] led //The 16 leds are used to display the address information and the mode information. ); wire [15:0] Ibus_data; // Data for the input memory bank. wire [15:0] Obus_data; // Data for the output memory bank. wire [15:0] op_data; // The results of a math operation on the two halves of the input memory bank. wire disp_ID_ODb; // Ibus_data will be displayed when this signal is true, Obus_data when it is false. reg [15:0] disp_data; // data to be displayed (Ibus or Obus). wire left, center, right, up, down; // debounced buttons wire [3:0] IM_addr; // address for the input memory
reg [3:0] OM_addr; // address for the output memory sseg_x4_top disp (.clk(clk), .btnC(1'b0), .sw(disp_data), .seg(seg), .an(an), .dp(dp)); memory IM (.we(WE_IM), .oe(OE_IM), .clk(clk), .data(Ibus_data), .addr(IM_addr)); memory OM (.we(WE_OM), .oe(OE_IM), .clk(clk), .data(Obus_data), .addr(OM_addr)); debounce_buttons bdb (.clk(clk), .btnL(btnL), .btnC(btnC), .btnR(btnR), .btnU(btnU), .btnD(btnD), .left(left), .center(center), .right(right), .up(up), .down(down)); IO_control IOcont (.clk(clk), .left(left), .center(center), .right(right), .disp_ID_ODb(disp_ID_ODb), .WE_IM(WE_IM), .WE_OM(WE_OM), .OE_sw(OE_sw), .OE_IM(OE_IM), .OE_op(OE_op), .OE_OM(OE_OM)); addr_control addrcont(.clk(clk), .center(center), .right(right), .up(up), .down(down), .addr(IM_addr)); assign Ibus_data = OE_sw?sw:16'hZZZZ; assign Obus_data = OE_op?op_data:16'hZZZZ; assign op_data = Ibus_data[15:8] + Ibus_data[7:0]; assign led[7:0] = {4'b0000, IM_addr}; // show the address on the four, least significant LEDs. // debug using the following LEDs assign led[15:8] = {1'b0, disp_ID_ODb, WE_IM, WE_OM, OE_IM, OE_OM, OE_op, OE_sw}; always @ (posedge clk) //Delay the input memory address for the output memory address so that the input OM_addr <= IM_addr; //and output memory blocks align (the result is written one clock cycle after
Your preview ends here
Eager to read complete document? Join bartleby learn and gain access to the full version
  • Access to all documents
  • Unlimited textbook solutions
  • 24/7 expert homework help
//the input memory block is read). always @ (*) //Implements a multiplexer to select the data to be displayed begin if (disp_ID_ODb) //disp_ID_ODb state is stored in a register disp_data = Ibus_data; else disp_data = Obus_data; end endmodule module debounce_buttons ( input clk, input btnL, btnC, btnR, btnU, btnD, output left, center, right, up, down ); wire clk_deb; debounce_div div1 (.clk(clk), .clk_deb(clk_deb)); btn_debounce u_btn (.clk(clk_deb), .btn_in(btnU), .btn_status(up));
btn_debounce d_btn (.clk(clk_deb), .btn_in(btnD), .btn_status(down)); btn_debounce l_btn (.clk(clk_deb), .btn_in(btnL), .btn_status(left)); btn_debounce r_btn (.clk(clk_deb), .btn_in(btnR), .btn_status(right)); btn_debounce c_btn (.clk(clk_deb), .btn_in(btnC), .btn_status(center)); endmodule module IO_control ( input clk, left, center, right, output reg disp_ID_ODb, WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM); always @ (*) //Input and output memory mode configuration case ({left, center, right}) 3'b000: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b00_01_01; 3'b001: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b00_01_10; 3'b010: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b00_01_01; 3'b011: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b01_01_10; 3'b100: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b00_10_01; 3'b101: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b01_10_10; 3'b110: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b10_10_01; 3'b111: {WE_IM, WE_OM, OE_sw, OE_IM, OE_op, OE_OM} = 6'b00_10_10; endcase
always @ (posedge clk, posedge right, posedge left) //Saving the input/output memory bank button presses if (right) disp_ID_ODb <= 1'b0; else if (left) disp_ID_ODb <= 1'b1; else disp_ID_ODb <= disp_ID_ODb; endmodule module addr_control ( input clk, center, right, up, down, output reg [3:0] addr); wire auto_inc_addr, inc_addr_pulse, dec_addr_pulse, rst_addr; create_pulse_from_step inc (.clk(clk), .step(up), .pulse(inc_addr_pulse)); create_pulse_from_step dec (.clk(clk), .step(down), .pulse(dec_addr_pulse)); assign auto_inc_addr = center && right; assign rst_addr = up && down;
Your preview ends here
Eager to read complete document? Join bartleby learn and gain access to the full version
  • Access to all documents
  • Unlimited textbook solutions
  • 24/7 expert homework help
initial addr = 4'h0; //Address generator implementation always @ (posedge clk) begin if (rst_addr) addr <= 4'h0; else if (dec_addr_pulse && (addr > 4'h0)) addr <= addr - 1; else if ((inc_addr_pulse || auto_inc_addr) && (addr < 4'hF)) addr <= addr + 1; else addr <= addr; end endmodule // the following module transforms a single step into a pulse lasting exactly one clock cycle module create_pulse_from_step ( input clk, input step, output pulse //pulse lasting exactly one clock cycle for each input step ); reg step_tm1, step_tm2; initial step_tm1 = 1'b0; initial step_tm2 = 1'b0; always @ (posedge clk)
begin step_tm1 <= step; step_tm2 <= step_tm1; end assign pulse = step_tm1 && !step_tm2; endmodule module btn_debounce( input clk, input btn_in, output wire btn_status ); reg [19:0] btn_shift; always @ (posedge clk) btn_shift <= {btn_shift[18:0], btn_in}; assign btn_status = &btn_shift; endmodule
module debounce_div( input clk, output clk_deb ); reg [15:0] cnt; assign clk_deb = cnt[15]; initial cnt = 0; always @(posedge clk) cnt <= cnt + 1; endmodule module memory( input wire oe, we, clk, input wire [3:0] addr, inout wire [15:0] data ); reg [15:0] mem[15:0]; reg [15:0] data_temp; assign data = (oe && !we) ? data_temp:16'hzzzz; always @(posedge clk)
Your preview ends here
Eager to read complete document? Join bartleby learn and gain access to the full version
  • Access to all documents
  • Unlimited textbook solutions
  • 24/7 expert homework help
begin if (we) mem[addr] <= data; else if (oe) data_temp <= mem[addr]; end endmodule