欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3101|回復: 0
收起左側

MCU SPI如何片選操作兩個AD9833

[復制鏈接]
ID:743654 發表于 2020-12-3 17:12 | 顯示全部樓層 |閱讀模式
20黑幣
如圖,我有兩個AD9833,SPI通訊。通過不同的片選使能信號-CS20和-CS21操作兩器件,單個輸出如何選擇片選信號,兩個輸出如何選擇,程序要怎么修改呢? 111400srqahehj8in2iyqi.jpg
程序如下:
sbit f_sync = P2^2;//片選信號
sbit s_clk    = P2^1;
sbit s_data = P2^0;


#define DDS_SCLK_UP         s_clk=1
#define DDS_SCLK_DOWN         s_clk=0

#define DDS_SDATA_UP         s_data=1
#define DDS_SDATA_DOWN         s_data=0

#define DDS_FSYNC_UP         f_sync=1
#define DDS_FSYNC_DOWN         f_sync=0

//#define BITB 0x0800


//AD9833輸入時鐘值
unsigned long int MCLK=25000000;      
double p=3.141592653589793;
//寄存器配置數組
unsigned int Config_Data[8];

//頻率
unsigned long int code freq[5]={30000,60000,120000,480000,960000};

//函數聲明
static void delay2us(unsigned char i);
static void changeFreq(unsigned char key);
static unsigned char getKeyValue();
void writeDDS2Byte(unsigned int config);
void waveGenerate(unsigned long int frequency,double phase,unsigned char signal_type);


//void main(void)
//{
//        waveGenerate(freq[4],2*p,0); //
//}

/***********************************************************************************************
*
*        軟件模擬SPI
*
*        向AD9833寫入數據或控制信息時0,FSYNC應處于低電平并保持低電平,直到數據的16個位均已寫入AD9833為止,FSYNC信號以幀方式傳輸要載入AD9833的16位信息
*
*        向AD9833發送數據時,FSYNC被拉低,單片機以8位字節傳輸數據,因此每個周期中只有8個SCLK下降沿,要向AD9833中載入剩余的8個位,FSYNC應在第一批8個位傳輸完成后保持低電平,同時啟動第二次寫操作來傳輸數
*        據的第二個字節,第二次寫操作結束后FSYNC被拉高,SCLK應在兩次寫操作之間處于高電平空閑狀態
*
************************************************************************************************/
void writeDDS2Byte(unsigned int config)

{
        unsigned char i;
        DDS_SCLK_DOWN;//拉低SCLK
        _nop_();//延時
        DDS_FSYNC_UP;//拉高FSYNC
        _nop_();//延時
        DDS_SCLK_UP;//拉高SCLK
        delay2us(1);//延時1us
        DDS_FSYNC_DOWN;//發送數據時,FSYNC拉低
        _nop_();
        for (i=0; i<16; i++)
        {
                if (config & 0x8000)
                DDS_SDATA_UP;//SDATA拉高
                else
                DDS_SDATA_DOWN;//SDATA拉低
                delay2us(1);//延時1us
                DDS_SCLK_DOWN;//SCLK拉低
                delay2us(1);//延時1us
                DDS_SCLK_UP;//SCLK拉高
                config <<= 1;//config循環左移一位
        }
        DDS_FSYNC_UP;//FSYNC拉高
        _nop_();//延時
        DDS_SCLK_DOWN;//SCLK拉低
        delay2us(100);//延時100us
}


/*******************************************************************
*        功能:波形發生器
*
*        入口參數:         frequency: 期望得到的信號頻率 (frequency<MCLK)
*
*                          phase:期望得到的相位
*
*             signal_type:0正弦波1(三角波),2(方波)   
*
*        默認配置:         0相移,方波不分頻
*******************************************************************/
void waveGenerate(unsigned long int frequency,double phase,unsigned char signal_type)
{
        unsigned char k;
        unsigned long int freq_temp;
        unsigned int phase_temp;
        if(frequency>MCLK)
        frequency=MCLK;
        switch(signal_type)
        {
                case 0://正弦波
                        Config_Data[0]=0x2108;//控制寄存器配置值,復位片內其他寄存器,AD9833上電時,期間應復位,要使AD9833復位應將reset位置1,即bit8置1,要通過Vout引腳提供正弦波輸出,應將mode(D1)bit清0并將OPBITEN(D5)bit清0,當DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
                        Config_Data[7]=0x2008;//控制寄存器配置值,不復位片內其他寄存器,要使AD9833退出復位,應將該位清零,即bit8位清零,要通過Vout引腳提供正弦波輸出,應將mode(D1)bit清0并將OPBITEN(D5)bit清0,當DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
                break;
                case 1://三角波
                        Config_Data[0]=0x210A;//控制寄存器配置值,復位片內其他寄存器,AD9833上電時,期間應復位,要使AD9833復位應將reset位置1,即bit8置1,要通過Vout引腳提供三角波輸出,應將mode(D1)1,DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
                        Config_Data[7]=0x200A;//控制寄存器配置值,不復位片內其他寄存器,要使AD9833退出復位,應將該位清零,即bit8位清零,要通過Vout引腳提供三角波輸出,應將mode(D1)置1,DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
                break;
                case 2://方波,不分頻
                        Config_Data[0]=0x2128;//控制寄存器配置值,復位片內其他寄存器,AD9833上電時,期間應復位,要使AD9833復位應將reset位置1,即bit8置1,當OPBITEN(D5)置1,mode(D1)清0,DIV2=1時即bit3=1,Vout輸出DAC數據MSB
                        Config_Data[7]=0x2028;//控制寄存器配置值,不復位片內其他寄存器,要使AD9833退出復位,應將該位清零,即bit8位清零,當OPBITEN(D5)置1,mode(D1)清0,DIV2=1時即bit3=1,Vout輸出DAC數據MSB
                        break;
                default://正弦波
                        Config_Data[0]=0x2108;
                        Config_Data[7]=0x2008;
                break;
        }
        //freq_temp=frequency*(2^28/MCLK),MCLK=6Mhz?,2^28/MCLK約等于44.739242666666669
        //phase_temp=phase*(4096/2p),p=3.141592653589793
        freq_temp=frequency*10.73741824; //載入所選頻率寄存器的值,此信號會經過如下相位偏移處理,2?/4096*PHASEREG,PHASEREG是所選相位輸出頻率和參考時鐘頻率之間的關系,必須考慮所選輸出頻率和參考時鐘頻率之間的關系,以免產生不良的輸出異常
        phase_temp=phase*(4096/2*p);//651.898646904403295309
        Config_Data[1]=freq_temp&0x3fff;//先將bit15,bit14位清0,控制字寫入
        Config_Data[3]=Config_Data[1];//先將bit15,bit14位清0,控制字寫入
        Config_Data[2]=(freq_temp&0x0fffc000)>>14;//先將bit15,bit14位清0,控制字寫入
        Config_Data[4]=Config_Data[2];//先將bit15,bit14位清0,控制字寫入
        Config_Data[5]=phase_temp&0x1fff;
        Config_Data[5]=Config_Data[6];


        Config_Data[1]=Config_Data[1]|0x4000;//(頻率寄存器)FREQ0 14 LSBs,bit15=0,bit14=1,FREQ0寄存器寫入
        Config_Data[2]=Config_Data[2]|0x4000;//(頻率寄存器)FREQ0 14 MSBs,bit15=0,bit14=1,FREQ0寄存器寫入
        Config_Data[3]=Config_Data[3]|0x8000;//(頻率寄存器)FREQ1 14 LSBs,bit15=1,bit14=0,FREQ1寄存器寫入
        Config_Data[4]=Config_Data[4]|0x8000;//(頻率寄存器)FREQ1 14 MSBs,bit15=1,bit14=0,FREQ1寄存器寫入
//        Config_Data[5]=0xC000;//(相位寄存器)PHASE0
//        Config_Data[6]=0xE000;//(相位寄存器)PHASE1
        Config_Data[5]=Config_Data[5]|0xC000;//(相位寄存器)PHASE0,bit15=1,bit14=1,bit13=0,PHASE0寄存器寫入
        Config_Data[6]=Config_Data[6]|0xE000;//(相位寄存器)PHASE1,bit15=1,bit14=1,bit13=1,PHASE1寄存器寫入
        for(k=0;k<8;k++)
        {
                writeDDS2Byte(Config_Data[k]);
        }
}



static void delay2us(unsigned char i)
{
        while (--i);
}


回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表