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

Subversion Repositories alternascope

[/] [alternascope/] [branches/] [Alpha/] [SegDriver/] [d_SegDriver.v] - Rev 2

Go to most recent revision | Compare with Previous | Blame | View Log

//==================================================================
// File:    d_MouseDriver.v
// Version: 0.01
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
// Copyright Stephen Pickett, Clarke Ellis
//   April 28, 2005
//------------------------------------------------------------------
// Revisions:
// Ver 0.01     Apr 28, 2005    Initial Release
//
//==================================================================
 
module sub_SegDriver(
    CLK_50MHZ, MASTER_RST,
    DATA_IN,
    SEG_OUT, SEG_SEL
    );
 
//==================================================================//
// VARIABLE DEFINITIONS                                             //
//==================================================================//
//----------------------//
// INPUTS               //
//----------------------//
input CLK_50MHZ;    // System wide clock
input MASTER_RST;   // System wide reset
input[15:0] DATA_IN;
//----------------------//
// OUTPUTS              //
//----------------------//
output[6:0] SEG_OUT;
output[3:0] SEG_SEL;
 
//----------------------//
// WIRES / NODES        //
//----------------------//
wire CLK_50MHZ, MASTER_RST;
wire[15:0] DATA_IN;
reg [6:0]  SEG_OUT;
reg [3:0]  SEG_SEL;
 
//----------------------//
// REGISTERS            //
//----------------------//
wire[6:0]  seg0, seg1, seg2, seg3;
reg[7:0] clk_390kHz;
 
//==================================================================//
// FUNCTIONAL DEFINITIONS                                           //
//==================================================================//
always @ (posedge CLK_50MHZ or posedge MASTER_RST) begin
    if(MASTER_RST == 1'b1)
        clk_390kHz <= 8'b0;
    else
        clk_390kHz <= clk_390kHz + 1;
end
 
always @ (posedge clk_390kHz[7] or posedge MASTER_RST) begin
    if(MASTER_RST == 1'b1)
        SEG_SEL <= 4'b1110;
    else begin
        SEG_SEL[3:1] <= SEG_SEL[2:0];
        SEG_SEL[0] <= SEG_SEL[3];
    end
end
 
always @ (SEG_SEL or seg0 or seg1 or seg2 or seg3) begin
    if(SEG_SEL == 4'b1110)
        SEG_OUT = seg0;
    else if(SEG_SEL == 4'b1101)
        SEG_OUT = seg1;
    else if(SEG_SEL == 4'b1011)
        SEG_OUT = seg2;
    else if(SEG_SEL == 4'b0111)
        SEG_OUT = seg3;
    else
        SEG_OUT = 7'b1111111;
end
 
sub_HexSeg sub_seg3( .DATA_IN(DATA_IN[15:12]),
                     .SEG_OUT(seg3)
                    );
sub_HexSeg sub_seg2( .DATA_IN(DATA_IN[11:8]),
                     .SEG_OUT(seg2)
                   );
sub_HexSeg sub_seg1( .DATA_IN(DATA_IN[7:4]),
                     .SEG_OUT(seg1)
                   );
sub_HexSeg sub_seg0( .DATA_IN(DATA_IN[3:0]),
                     .SEG_OUT(seg0)
                   );
 
endmodule
 
 
 
 
 
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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