数字IC笔试题 ——Nvidia前端设计2018

数字IC笔试题 ——Nvidia前端设计2018_第1张图片

数字IC笔试题 ——Nvidia前端设计2018_第2张图片 

数字IC笔试题 ——Nvidia前端设计2018_第3张图片

数字IC笔试题 ——Nvidia前端设计2018_第4张图片

4、 Asyncfifo design using Verilog

module  asyn_fifo(
  input wclk ,
  input rst_n ,
  input wr_en ,
  input [7 : 0] data_in ,
  output full ,
  
  input rclk ,
  input rd_en ,
  output reg [7:0]  data_out ,
  output empty
);


reg [7 : 0 ] mem[7 : 0] ;
wire [2:0]   r_addr , w_addr ;
reg [3:0]   binary_r_addr , binary_w_addr ;
wire [3:0]   gray_r_addr , gray_w_addr ;
reg [3:0]   gray_r_addr_reg , gray_w_addr_reg ;


assign gray_r_addr =   ( binary_r_addr >> 1 ) ^ binary_r_addr;
assign gray_w_addr =   ( binary_w_addr >> 1 ) ^ binary_w_addr;
assign r_addr = gray_r_addr[2:0] ;
assign w_addr = gray_w_addr[2:0] ;


always@(posedge rclk or negedge rst_n ) begin
  if(~rst_n) begin
    binary_r_addr <= 4'b0 ;
    gray_w_addr_reg <= 4'b0 ;
    data_out <= 8'b0 ;
  end
  
  
  else begin
    gray_w_addr_reg <=   gray_w_addr ;
    if(rd_en == 1'b1 && empty == 1'b0) begin
      data_out <= mem[r_addr] ;
      binary_r_addr <= binary_r_addr + 1'b1 ;
    end
  end
end


always@(posedge wclk or negedge rst_n) begin
  if(~rst_n) begin
    binary_w_addr <= 4'b0 ;
    gray_r_addr_reg <= 4'b0 ;
  end
  else begin
    gray_r_addr_reg <= gray_r_addr ;
    if(wr_en == 1'b1 && full == 1'b0 )begin
      mem[w_addr] <= data_in ;
      binary_w_addr <= binary_w_addr + 1'b1 ;
    end
  end
end


assign empty = (gray_r_addr == gray_w_addr_reg) ? 1:0 ;
assign full = ( (gray_w_addr[3] !== gray_r_addr_reg[3]) && (gray_w_addr[2] !== gray_r_addr_reg[2]) &&(gray_w_addr[1:0] == gray_r_addr_reg[1:0]) ) ? 1:0 ;


endmodule

数字IC笔试题 ——Nvidia前端设计2018_第5张图片 

 数字IC笔试题 ——Nvidia前端设计2018_第6张图片

数字IC笔试题 ——Nvidia前端设计2018_第7张图片 

module sequence_detect(
input              clk,
input              rst_n,
input       [7:0]  stringB_in,
input              stringB_en ,
input              stringB_over ,
output reg  [4:0]  location,
output reg           out_valid
);




reg [4:0] location_reg_count;
always @ (posedge clk or negedge rst_n) begin
  if(!rst_n)
    location_reg_count <= 5'd0;
  else if(stringB_en == 1'b1 && stringB_over == 1'b0) begin
    location_reg_count <= location_reg_count+1;
  end
end



reg [4:0] location_reg;
always @ (posedge clk or negedge rst_n) begin
  if(!rst_n)
    location_reg <= 0;
  else if (stringB_en == 1'b1 && stringB_over == 1'b0 ) begin
    if(stringB_in == "n" || stringB_in == "v" || stringB_in == "i"  ||stringB_in == "d"  || stringB_in == "a") begin
      location_reg <= location_reg_count ;
    end
    else begin
      location_reg <= location_reg ;
    end
  end
end


always @ (posedge clk or negedge rst_n) begin
  if(!rst_n)
    out_valid <= 0;
  else if (stringB_over == 1'b1 ) begin
    location <= location_reg ;
    out_valid <= 1'b1;
  end
  else begin
    location <= 0 ;
    out_valid <= 1'b0;
  end
end
      

endmodule

数字IC笔试题 ——Nvidia前端设计2018_第8张图片 

#include 
#include "malloc.h"
void NumSort(int *number, int numbersize);


int *intersection_numbers(int *number1, int numbersize1, int *number2, int numbersize2,int *intersection_size);
int *union_numbers(int *number1, int numbersize1, int *number2, int numbersize2, int *union_size);




void NumSort(int *number, int numbersize) {
    int min, temp;
    int i;
    int j;
    for (i = 0; inumber[j]) {
                min = j;
            }
        }
        if (min != i) {
            temp = number[min];
            number[min] = number[i];
            number[i] = temp;
        }
    }
}



int *intersection_numbers(int *number1, int numbersize1, int *number2, int numbersize2,int *intersection_size) {
    int temp, i, j;
    int *result = (int *)malloc(numbersize1 * sizeof(int));


    *intersection_size =  0;
    NumSort(number1, numbersize1);
    NumSort(number2, numbersize2);


    temp = number1[numbersize1 - 1] + number2[numbersize2 - 1];
        for (i = 0, j = 0; inumber2[j]) {
                j++;
            }
            else if (number1[i]number2[j]) {
                result[(*union_size)++] = number2[j];
                j++;
            }
            else if (i != numbersize1 && number1[i]number2[j]) {
                result[(*union_size)++] = number1[i];
                i++;
            }
            else if (i == numbersize1 && number1[i]

 

你可能感兴趣的:(IC设计相关)