www.pudn.com > SD_Card_Audio.rar > AUDIO_DAC_FIFO.v
module AUDIO_DAC_FIFO ( // FIFO Side iDATA,iWR,iWR_CLK, oWR_FULL, // Audio Side oAUD_BCK, oAUD_DATA, oAUD_LRCK, // Control Signals iCLK_18_4, iRST_N ); parameter REF_CLK = 18432000; // 18.432 MHz parameter SAMPLE_RATE = 48000; // 48 KHz parameter DATA_WIDTH = 16; // 16 Bits parameter CHANNEL_NUM = 2; // Dual Channel // FIFO Side input [DATA_WIDTH-1:0] iDATA; input iWR; input iWR_CLK; output oWR_FULL; wire [DATA_WIDTH-1:0] mDATA; reg mDATA_RD; // Audio Side output oAUD_DATA; output oAUD_LRCK; output oAUD_BCK; reg oAUD_BCK; // Control Signals input iCLK_18_4; input iRST_N; // Internal Registers and Wires reg [3:0] BCK_DIV; reg [8:0] LRCK_1X_DIV; reg [7:0] LRCK_2X_DIV; reg [3:0] SEL_Cont; //////////////////////////////////// reg [DATA_WIDTH-1:0] DATA_Out; reg [DATA_WIDTH-1:0] DATA_Out_Tmp; reg LRCK_1X; reg LRCK_2X; FIFO_16_256 u0 ( .data(iDATA),.wrreq(iWR), .rdreq(mDATA_RD),.rdclk(iCLK_18_4), .wrclk(iWR_CLK),.aclr(~iRST_N), .q(mDATA),.wrfull(oWR_FULL)); //////////// AUD_BCK Generator ////////////// always@(posedge iCLK_18_4 or negedge iRST_N) begin if(!iRST_N) begin BCK_DIV <= 0; oAUD_BCK <= 0; end else begin if(BCK_DIV >= REF_CLK/(SAMPLE_RATE*DATA_WIDTH*CHANNEL_NUM*2)-1 ) begin BCK_DIV <= 0; oAUD_BCK <= ~oAUD_BCK; end else BCK_DIV <= BCK_DIV+1; end end ////////////////////////////////////////////////// //////////// AUD_LRCK Generator ////////////// always@(posedge iCLK_18_4 or negedge iRST_N) begin if(!iRST_N) begin LRCK_1X_DIV <= 0; LRCK_2X_DIV <= 0; LRCK_1X <= 0; LRCK_2X <= 0; end else begin // LRCK 1X if(LRCK_1X_DIV >= REF_CLK/(SAMPLE_RATE*2)-1 ) begin LRCK_1X_DIV <= 0; LRCK_1X <= ~LRCK_1X; end else LRCK_1X_DIV <= LRCK_1X_DIV+1; // LRCK 2X if(LRCK_2X_DIV >= REF_CLK/(SAMPLE_RATE*4)-1 ) begin LRCK_2X_DIV <= 0; LRCK_2X <= ~LRCK_2X; end else LRCK_2X_DIV <= LRCK_2X_DIV+1; end end assign oAUD_LRCK = LRCK_1X; ////////////////////////////////////////////////// ////////// Read Signal Generator ////////////// always@(posedge iCLK_18_4 or negedge iRST_N) begin if(!iRST_N) begin mDATA_RD <= 0; end else begin if(LRCK_1X_DIV == REF_CLK/(SAMPLE_RATE*2)-1 ) mDATA_RD <= 1; else mDATA_RD <= 0; end end ////////////////////////////////////////////////// ////////////// DATA Latch ////////////////// always@(posedge iCLK_18_4 or negedge iRST_N) begin if(!iRST_N) DATA_Out_Tmp <= 0; else begin if(LRCK_2X_DIV == REF_CLK/(SAMPLE_RATE*4)-1 ) DATA_Out_Tmp <= mDATA; end end always@(posedge iCLK_18_4 or negedge iRST_N) begin if(!iRST_N) DATA_Out <= 0; else begin if(LRCK_2X_DIV == REF_CLK/(SAMPLE_RATE*4)-3 ) DATA_Out <= DATA_Out_Tmp; end end ////////////////////////////////////////////////// ////////// 16 Bits PISO MSB First ////////////// always@(negedge oAUD_BCK or negedge iRST_N) begin if(!iRST_N) SEL_Cont <= 0; else SEL_Cont <= SEL_Cont+1; end assign oAUD_DATA = DATA_Out[~SEL_Cont]; ////////////////////////////////////////////////// endmodule