1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
module ex15(CLOCK_50, DAC_CS, DAC_SDI, DAC_LD, DAC_SCK, ADC_SDI, ADC_SCK, ADC_CS, ADC_SDO, PWM_OUT, HEX0, HEX1, HEX2, HEX3, HEX4);
input CLOCK_50;
output DAC_CS, DAC_SDI, DAC_LD, DAC_SCK, PWM_OUT;
output [6:0] HEX0, HEX1, HEX2, HEX3, HEX4;
output ADC_SDI; //Serial data out to SDI of the ADC
output ADC_SCK; // ADC Clock signal
output ADC_CS; //Chip select to the ADC, low active
input ADC_SDO; //Converted serial data from ADC
wire load;
wire [9:0] address, data;
wire [23:0] freq_tmp;
wire [19:0] freq_fin;
tick_5000 tick(CLOCK_50, load);
wire [9:0] data_in;
spi2adc SPI_ADC (
.sysclk (CLOCK_50),
.channel (1'b0),
.start (load),
.data_from_adc (data_in),
.data_valid (),
.sdata_to_adc (ADC_SDI),
.adc_cs (ADC_CS),
.adc_sck (ADC_SCK),
.sdata_from_adc (ADC_SDO));
add_offset fin_address(data_in, load, address);
ROM rom(address, CLOCK_50, data);
spi2dac dac(CLOCK_50, data, load, DAC_SDI, DAC_CS, DAC_SCK, DAC_LD);
pwm p(CLOCK_50, data, load, PWM_OUT);
const_mult mult(data_in, freq_tmp);
bin2bcd_16 bcd(freq_tmp[23:10], freq_fin[3:0], freq_fin[7:4], freq_fin[11:8], freq_fin[15:12], freq_fin[19:16]);
hex_to_7seg h0(HEX0, freq_fin[3:0]);
hex_to_7seg h1(HEX1, freq_fin[7:4]);
hex_to_7seg h2(HEX2, freq_fin[11:8]);
hex_to_7seg h3(HEX3, freq_fin[15:12]);
hex_to_7seg h4(HEX4, freq_fin[19:16]);
endmodule
|