OpenCores
URL https://opencores.org/ocsvn/ag_6502/ag_6502/trunk

Subversion Repositories ag_6502

[/] [ag_6502/] [trunk/] [digger/] [chip1.v] - Blame information for rev 5

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 5 olegodints
`timescale 1ns / 1ps
2
//////////////////////////////////////////////////////////////////////////////////
3
// Company:   BMSTU
4
// Engineer:  Oleg Odintsov
5
// 
6
// Create Date:    18:21:00 01/17/2012 
7
// Design Name: 
8
// Project Name:    Agat Hardware Project
9
// Project Name: 
10
// Target Devices: 
11
// Tool versions: 
12
// Description: 
13
//
14
// Dependencies: 
15
//
16
// Revision: 
17
// Revision 0.01 - File Created
18
// Additional Comments: 
19
//
20
//////////////////////////////////////////////////////////////////////////////////
21
 
22
 
23
 
24
module rot_driver(input clk,
25
                                input rot_a, input rot_b,
26
                                output wire rot_dir, output wire rot_event_out);
27
 
28
        reg rot_a_latch = 0, rot_b_latch = 0;
29
        assign rot_dir = rot_b_latch, rot_event_out = rot_a_latch;
30
        always @(posedge clk) begin
31
                case ({rot_a, rot_b})
32
                2'b00: rot_a_latch <= 1;
33
                2'b11: rot_a_latch <= 0;
34
                2'b10: rot_b_latch <= 1;
35
                2'b01: rot_b_latch <= 0;
36
                endcase
37
        end
38
endmodule
39
 
40
module btn_driver(input clk, input btn, output reg sig = 0);
41
        parameter nskip = 'hfff;
42
        integer counter = 0;
43
        wire lock = counter?1:0;
44
 
45
        always @(posedge clk) begin
46
                if (counter) counter <= counter - 1;
47
                if (!lock && sig != btn) begin
48
                        sig <= btn;
49
                        counter <= nskip;
50
                end
51
        end
52
endmodule
53
 
54
 
55
module chip1(
56
         input clk,
57
    input b1,
58
    input b2,
59
    input b3,
60
    input b4,
61
         input[3:0] SW,
62
         input rot_a, rot_b, rot_center,
63
    output[7:0] led,
64
    output vga_red,
65
    output vga_green,
66
    output vga_blue,
67
    output vga_hsync,
68
    output vga_vsync,
69
         output [3:0]j4,
70
         input spi_miso, output spi_mosi, output spi_sck, output dac_cs, output dac_clr,
71
         output spi_rom_cs,
72
         output spi_amp_cs,
73
         output spi_adc_conv,
74
         output strataflash_oe,
75
         output strataflash_ce,
76
    output strataflash_we,
77
         output platformflash_oe,
78
         input  ps2_clk,
79
         input  ps2_data
80
    );
81
 
82
 
83
 
84
         // access to DAC
85
         assign spi_mosi = 0, spi_sck = 0, dac_cs = 0, dac_clr = 0;
86
         // block other devices to access to DAC
87
         assign spi_rom_cs = 1, spi_amp_cs = 1, spi_adc_conv = 0;
88
         assign strataflash_oe = 1, strataflash_ce = 1, strataflash_we = 1;
89
         assign platformflash_oe = 0;
90
 
91
         wire[4:0] vga_bus;
92
         assign {vga_red, vga_green, vga_blue, vga_hsync, vga_vsync} = vga_bus;
93
         wire[1:0] ps2_bus = {ps2_clk, ps2_data};
94
 
95
         wire rot_dir, rot_event;
96
 
97
         wire clk_cpu;
98
         wire b1v, b2v, b3v, b4v, brc;
99
         rot_driver rot(clk_cpu, rot_a, rot_b, rot_dir, rot_event);
100
         btn_driver b1d(clk_cpu, b1, b1v);
101
         btn_driver b2d(clk_cpu, b2, b2v);
102
         btn_driver b3d(clk_cpu, b3, b3v);
103
         btn_driver b4d(clk_cpu, b4, b4v);
104
         btn_driver rrd(clk_cpu, rot_center, brc);
105
         reg rot_v = 0;
106
 
107
         always @(posedge rot_event) begin
108
                rot_v <= rot_dir;
109
         end
110
 
111
 
112
//       assign j4 = 0, vga_bus = 0;
113
 
114
         wire[4:0] btns = {brc, b4v | (rot_event & ~rot_v), b3v, b2v, b1v | (rot_event & rot_v)};
115
         ag_main agate(clk, btns, SW, led, j4, vga_bus, ps2_bus, clk_cpu);
116
 
117
endmodule

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.