<var id="fnfpo"><source id="fnfpo"></source></var>
<rp id="fnfpo"></rp>

<em id="fnfpo"><object id="fnfpo"><input id="fnfpo"></input></object></em>
<em id="fnfpo"><acronym id="fnfpo"></acronym></em>
  • <th id="fnfpo"><track id="fnfpo"></track></th>
  • <progress id="fnfpo"><track id="fnfpo"></track></progress>
  • <tbody id="fnfpo"><pre id="fnfpo"></pre></tbody>

  • x
    x

    基于MSP430F449的數據存儲和USB串行通信實現

    發布時間:2010-7-31 19:58    發布者:lavida
    關鍵詞: MSP430F449 , USB , 串行通信 , 數據存儲
    在數據采集和測量儀器尤其是便攜式設備中,數據存儲和傳輸是不可避免的問題,近年來TI公司推出的低功耗微控制器MSP430,在儀器設計和制造領域引起巨大變革,新型控制器和大容量串行存儲器的應用大大提高產品了的性能。本文主要解決兩個問題  

    1 解決經過MSP430采集后的數據與EEPROM24C256的數據接口問題,也就是數據存儲問題;  

    2 解決EEPROM與上位機(普通微機)的數據通信問題,也就是存儲后的數據上傳問題。

    首先對主要的集成電路做簡單介紹

    MSP430F449簡介  

    MSP430F449是MSP430系列中的一種,MSP430系列是一種具有集成度高,功能豐富、功耗低等特點的16位單片機。它的集成調試環境Embedded Workbench 提供了良好的C語言開發平臺。設計中基于程序的復雜性和程序容量大的要求選擇了MSP430F449,這款芯片具有64K程序存儲器,可以滿足大部分復雜控制的需要;它的封裝100-PIN QFP具有良好的互換性,與MSP430F437 、MSP430F435等芯片具有完全一致的管腳可以在程序量上進行合理選擇。  

    24C256簡介  

    24C256是支持I2C協議的串行EEPROM,容量32768字節。
       
    以上是24C256的管腳圖,其中A0,A1,A2構成存儲器的物理地址,作為I2C總線上區分不同存儲器的控制地址,可以在I2C總線上同時連接8個設備。 WP是寫保護,高電平將禁止對器件的寫操作;SCL和SDA是數據傳輸的控制線,其中SCL是時鐘,SDA是雙向數據線,用來完成數據的寫入和讀出,數據的傳輸按照I2C協議的要求由時鐘端SCL配合共同完成。  

    CP2102簡介  

    CP2102是USB到UART的橋接電路,完成USB數據和UART數據的轉換,電路連接簡單,數據傳輸可靠,把下位機串行數據轉換成USB數據格式,方便實現數據通信,在上位機上通過運行該芯片的驅動程序把USB數據可以按照簡單的串口進行讀寫操作編程簡單,操作靈活。
      
    圖1 MSP430F449 接口原理圖  

    以上是MSP430F449與EEPROM以及CP2102的接口原理圖,本文重點在于介紹數據采集過程完成以后的數據存貯和數據傳輸。  

    數據的采集多種多樣,可以經過片內的ADC轉換器對模擬量進行采集,也可以通過獨立的端口控制線對特殊的傳感器比如溫度傳感器、壓力傳感器等進行數據轉換,這不作為本文介紹的內容。本文主要是針對不同的采集過程完成后數據的存儲和傳輸處理。

    數據自動存儲的客觀要求  

    在許多測量過程中,不僅要求讀取簡單的儀表值,而且還需要對一段時間的數據進行科學的分析和處理以取得預測和分析的目的。在這種情況下,可能要求測量時間長,采集要求自動進行,無需人工值守,所以數據必須自動存儲;另一個原因,采集數據的頻率比較高,人的觀察不能滿足實際需要,這就要求對采集的數據進行有效的存儲。

    集成電路合理選擇  

    有很多大容量的FLASH芯片已經得到廣泛應用,但是這類芯片口線較多,需要占用較多的控制器資源,在控制外圍器件多,接口復雜的情況下,特別是便攜式儀器功能全、體積小,為了精簡外圍電路,在不影響存儲量的情況下,具有I2C接口的串行EEPROM就成為了最佳選擇。

    24C256程序控制原理  

    24C256是具有I2C接口的512x64存儲器,在數據的存儲過程中除了遵循I2C協議必須的邏輯以外,一個最容易忽視并且最容易導致出錯的問題就是存儲地址問題。  

    24C256的數據容量是32768,即可以存儲的有效字節數。所以它的地址是16位整型數,有效范圍是0~32768,數據字節為單位存儲,在16位地址其中有效數據只有15位,低6(0~5)位地址表示的容量是0~63,然后連續的9(6~14)位地址表示頁碼的范圍是0~511,在數據連續存儲過程中,相同的頁面內,存儲地址自動完成累加過程;數據在不同頁面的存儲時,地址不能自動累加,如果不做正確處理,數據將從本頁開始的地址重新開始覆蓋已經存在的數據。例如,地址是63(二進制碼111111)表示的是第0頁的最后一個存儲空間,地址64(二進制碼1,000000)表示第1頁最開始的存儲空間。在當前存儲地址是63時如果該器件處于連續存儲模式下,數據將出錯。  

    原因是什么呢? 24C256支持數據的連續存儲,最大的存貯數量是64即一頁的內容,如果在地址選擇上超過了這個限制,數據將會覆蓋本頁開始的位置重新存儲,這就造成數據的錯誤,在使用上,雖然數據是分頁存儲的,但在形式上是連續數據,所以存儲中不需要特意區分頁地址和頁內地址。  

    在連續存儲中,盡管數據每次存儲的數量小于64,數據也可能出錯,例如每次存儲數量為11,地址的變化是0,11,22,33,44,55,66……,看上去沒有什么問題,地址是按照每次11遞增的,然而存儲的結果還是出錯了,原因是什么呢?在地址55開始的空間無法提供連續11個頁內存儲空間,當地址增加到63以后數據又從該頁0地址重新開始,從而導致數據儲存的錯誤。有效的解決辦法是如果使用連續存儲模式,地址的安排上要使存儲塊的大小為64,32,16,8,4,2此外都不能使用連續地址存儲。如果數據采集中的有效數據位小于64,比如每次采集的結果是30字節,在連續存儲模式下要按照32為單位存儲,不足的字節補零處理。  

    以下是24C256數據傳輸基本控制模塊  

    延時處理模塊  
    void IIC_Delay(void)   
    {  
    _NOP();  
    _NOP();  
    _NOP();  
    }  

    啟動I2C模塊   
    void start_IIC(void) // 啟動I2  
    {  
    P2OUT&=0xf9; //設置P2輸出  
    P2DIR&=0XFD; //SDA=1, 上拉電阻使得P2.1為H,FD=1111,1101  
    P2DIR&=0XFB; //SCL=1 FB=1111,1011  
    P2DIR|=0X02; // SDA=0  
    P2DIR|=0X04; // SCL=0  
    }  

    停止I2C模塊  
    void stop_IIC(void) //   
    {  
    P2DIR|=0X02;//SDA=0  
    IIC_Delay();  
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    P2DIR&=0XFD;//SDA=1, 上拉電阻使得P2.1為H,FD=1111,1101   
    IIC_Delay();  
    P2DIR|=0X04;// SCL=0   
    }  

    發送 “ 0”模塊  
    void send_zero(void) //   
    {  
    P2DIR|=0X02;// SDA=0  
    IIC_Delay();  
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    IIC_Delay();  
    P2DIR|=0X04;// SCL=0   
    }  

    發送 1模塊  
    void send_one(void) //   
    {  
    P2DIR&=0XFD;//SDA=1, 上拉電阻使得P2.1為H,FD=1111,1101   
    IIC_Delay();  
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    IIC_Delay();  
    P2DIR|=0X04;// SCL=0   
    }  

    發送單字符數據  
    void send _char(unsigned char data_out) //   
    {  
    unsigned char i,tmp=0x80;  
    for(i=0;i  
    {  
    if((data_out & tmp)>0)  
    send_one();  
    else  
    send_zero();  
    tmp/=2;  
    }  
    }  

    讀單字符數據  
    unsigned char read_char(void)   
    {  
    unsigned char i,tmp=0x80;  
    unsigned char data1=0;   
    for (i=0;i  
    {  
    P2DIR&=0XFD;//SDA=1, 11111101  
    IIC_Delay();//   
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    IIC_Delay();  
    if((P2IN&0x02)>0x00)  
    {  
    data1|=tmp;  
    }  
    P2DIR|=0X04;// SCL=0   
    IIC_Delay();  
    tmp/=2;  
    }  
    return data1;  
    }  

    檢查應答信號模塊  
    void iic_ACK(void)  
    {  
    ack_flag=0x00;  
    P2DIR&=0XFD;//SDA=1, FD=1111,1101  
    IIC_Delay();  
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    IIC_Delay();  
    while((P2IN&BIT1)==BIT1);   
    P2DIR|=0X04;// SCL=0   
    IIC_Delay();  
    }  

    拒絕應答模塊  
    void iic_NACK(void) {  
    P2DIR&=0XFD;//SDA=1,  
    IIC_Delay();  
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    IIC_Delay();  
    P2DIR|=0X04;// SCL=0   
    IIC_Delay();  
    P2DIR|=0X02;// SDA=0  
    IIC_Delay();//   
    }  

    寫連續數據模塊  
    void WriteNbyte(unsigned char *p,unsigned int addr,unsigned char number)   
    {  
    start_IIC();  
    send_char(0xa2);  
    iic_ACK();   
    send_char(addr/256); //high address byte  
    iic_ACK();  
    send_char(addr%256);  
    iic_ACK();   
    do  
    {  
    send_char(*p);  
    p++;  
    iic_ACK();   
    }  
    while(--number);  
       
    stop_IIC();  
    delay(10);  
    }  

    發送應答模塊:ACK (LOW)  
    void S_ACK(void)   
    {  
    P2DIR|=0X02;// SDA=0  
    IIC_Delay();  
    P2DIR&=0XFB;//SCL=1 FB=1111,1011  
    IIC_Delay();  
    P2DIR|=0X04;// SCL=0   
    IIC_Delay();  
    }  

    連續讀字符模塊  
    void ReadNbyte(unsigned char *p,unsigned int addr,unsigned char number)   
    {  
    start_IIC();  
    send_char(0xa2);  
    iic_ACK();  
    send_char(addr/256);  
    iic_ACK();   
    send_char(addr%256);  
    iic_ACK();   
    start_IIC();  
    send_char(0xa3);  
    iic_ACK();  
    do  
    {  
    *p=read_char();  
    p++;  
    if(number!=1)   
    S_ACK(); //send ACK  
    }  
    while(--number);  
    iic_NACK();  
    stop_IIC();  
    }  

    數據的傳輸  

    數據傳輸是存儲在EEPROM中的數據到達計算機的有效途徑,數據上傳到計算機最常用的是串行(RS232)接口,現在由于USB計數的不斷成熟,通過USB可以方便快捷實現數據傳輸,而且可以滿足速率和設備外觀的要求,但是USB的驅動程序設計是比較復雜的工作,本例中使用簡單的橋接電路,把UART接口的數據經過CP2102的橋接,直接實現數據的USB轉換,從430F449異步串口輸出的數據自動轉化為符合USB協議的數據直接連接到計算機的USB口,上位機應用程序通過CP2102的驅動程序可以象操作串口一樣直接讀寫端口數據。  

    結論  

    以上的硬件設計比較簡單可靠,可以照搬到同類型的控制芯片上,軟件代碼也同樣具有較好的移植性,只要把控制時鐘和數據端口和程序軟件設置相一致即可。
    本文地址:http://www.portaltwn.com/thread-18190-1-1.html     【打印本頁】

    本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
    您需要登錄后才可以發表評論 登錄 | 立即注冊

    廠商推薦

    • Microchip視頻專區
    • 深度體驗Microchip自動輔助駕駛應用方案——2025巡展開啟報名!
    • Cortex-M4外設 —— TC&TCC結合事件系統&DMA優化任務培訓教程
    • 你仿真過嗎?使用免費的MPLAB Mindi模擬仿真器降低設計風險
    • 利用模擬開發工具生態系統進行安全電路設計
    • 貿澤電子(Mouser)專區

    相關視頻

    關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
    電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
    快速回復 返回頂部 返回列表
    精品一区二区三区自拍图片区_国产成人亚洲精品_亚洲Va欧美va国产综合888_久久亚洲国产精品五月天婷