新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 文件I/O編程之: 嵌入式Linux串口應用編程

        文件I/O編程之: 嵌入式Linux串口應用編程

        作者: 時間:2013-09-13 來源:網絡 收藏

        本文引用地址:http://www.104case.com/article/257136.htm

        6.4.3使用詳解

        在配置完的相關屬性后,就可以對進行打開和讀寫操作了。它所使用的函數和普通文件的讀寫函數一樣,都是open()、write()和read()。它們之間的區別的只是串口是一個終端設備,因此在選擇函數的具體參數時會有一些區別。另外,這里會用到一些附加的函數,用于測試終端設備的連接情況等。下面將對其進行具體講解。

        1.打開串口

        打開串口和打開普通文件一樣,都是使用open()函數,如下所示:

        fd=open(/dev/ttyS0,O_RDWR|O_NOCTTY|O_NDELAY);

        可以看到,這里除了普通的讀寫參數外,還有兩個參數O_NOCTTY和O_NDELAY。

        n O_NOCTTY標志用于通知系統,該參數不會使打開的文件成為這個進程的控制終端。如果沒有指定這個標志,那么任何一個輸入(諸如鍵盤中止信號等)都將會影響用戶的進程。

        n O_NDELAY標志通知系統,這個程序不關心DCD信號線所處的狀態(端口的另一端是否激活或者停止)。如果用戶指定了這個標志,則進程將會一直處在睡眠狀態,直到DCD信號線被激活。

        接下來可恢復串口的狀態為阻塞狀態,用于等待串口數據的讀入,可用fcntl()函數實現,如下所示:

        fcntl(fd,F_SETFL,0);

        再接著可以測試打開文件描述符是否連接到一個終端設備,以進一步確認串口是否正確打開,如下所示:

        isatty(STDIN_FILENO);

        該函數調用成功則返回0,若失敗則返回-1。

        這時,一個串口就已經成功打開了。接下來就可以對這個串口進行讀和寫操作。下面給出了一個完整的打開串口的函數,同樣考慮到了各種不同的情況。程序如下所示:

        /*打開串口函數*/

        intopen_port(intcom_port)

        {

        intfd;

        #if(COM_TYPE==GNR_COM)/*使用普通串口*/

        char*dev[]={/dev/ttyS0,/dev/ttyS1,/dev/ttyS2};

        #else/*使用USB轉串口*/

        char*dev[]={/dev/ttyUSB0,/dev/ttyUSB1,/dev/ttyUSB2};

        #endif

        if((com_port0)||(com_port>MAX_COM_NUM))

        {

        return-1;

        }

        /*打開串口*/

        fd=open(dev[com_port-1],O_RDWR|O_NOCTTY|O_NDELAY);

        if(fd0)

        {

        perror(openserialport);

        return(-1);

        }

        /*恢復串口為阻塞狀態*/

        if(fcntl(fd,F_SETFL,0)0)

        {

        perror(fcntlF_SETFLn);

        }

        /*測試是否為終端設備*/

        if(isatty(STDIN_FILENO)==0)

        {

        perror(standardinputisnotaterminaldevice);

        }

        returnfd;

        }

        2.讀寫串口

        讀寫串口操作和讀寫普通文件一樣,使用read()和write()函數即可,如下所示:

        write(fd,buff,strlen(buff));

        read(fd,buff,BUFFER_SIZE);

        下面兩個實例給出了串口讀和寫的兩個程序,其中用到前面所講述的open_port()和set_com_config()函數。寫串口的程序將在宿主機上運行,讀串口的程序將在目標板上運行。

        寫串口的程序如下所示。

        /*com_writer.c*/

        #includestdio.h>

        #includestdlib.h>

        #includestring.h>

        #includesys/types.h>

        #includesys/stat.h>

        #includeerrno.h>

        #includeuart_api.h

        intmain(void)

        {

        intfd;

        charbuff[BUFFER_SIZE];

        if((fd=open_port(HOST_COM_PORT))0)/*打開串口*/

        {

        perror(open_port);

        return1;

        }

        if(set_com_config(fd,115200,8,'N',1)0)/*配置串口*/

        {

        perror(set_com_config);

        return1;

        }

        do

        {

        printf(Inputsomewords(enter'quit'toexit):);

        memset(buff,0,BUFFER_SIZE);

        if(fgets(buff,BUFFER_SIZE,stdin)==NULL)

        {

        perror(fgets);

        break;

        }

        write(fd,buff,strlen(buff));

        }while(strncmp(buff,quit,4));

        close(fd);

        return0;

        }

        讀串口的程序如下所示:

        /*com_reader.c*/

        #includestdio.h>

        #includestdlib.h>

        #includestring.h>

        #includesys/types.h>

        #includesys/stat.h>

        #includeerrno.h>

        #includeuart_api.h

        intmain(void)

        {

        intfd;

        charbuff[BUFFER_SIZE];

        if((fd=open_port(TARGET_COM_PORT))0)/*打開串口*/

        {

        perror(open_port);

        return1;

        }

        if(set_com_config(fd,115200,8,'N',1)0)/*配置串口*/

        {

        perror(set_com_config);

        return1;

        }

        do

        {

        memset(buff,0,BUFFER_SIZE);

        if(read(fd,buff,BUFFER_SIZE)>0)

        {

        printf(Thereceivedwordsare:%s,buff);

        }

        }while(strncmp(buff,quit,4));

        close(fd);

        return0;

        }

        在宿主機上運行寫串口的程序,而在目標板上運行讀串口的程序,運行結果如下所示。

        /*宿主機,寫串口*/

        $./com_writer

        Inputsomewords(enter'quit'toexit):hello,Reader!

        Inputsomewords(enter'quit'toexit):ImWriter!

        Inputsomewords(enter'quit'toexit):Thisisaserialporttestingprogram.

        Inputsomewords(enter'quit'toexit):quit

        /*目標板,讀串口*/

        $./com_reader

        Thereceivedwordsare:hello,Reader!

        Thereceivedwordsare:ImWriter!

        Thereceivedwordsare:Thisisaserialporttestingprogram.

        Thereceivedwordsare:quit

        另外,讀者還可以考慮一下如何使用select()函數實現串口的非阻塞讀寫,具體實例會在本章的后面的實驗中給出。

        linux操作系統文章專題:linux操作系統詳解(linux不再難懂)

        linux相關文章:linux教程



        上一頁 1 2 3 4 5 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 曲水县| 凤山县| 蕉岭县| 温泉县| 延寿县| 汕尾市| 和龙市| 互助| 南雄市| 阳高县| 稷山县| 靖远县| 古丈县| 镇原县| 枣强县| 灌云县| 平乐县| 岳池县| 丰台区| 安阳县| 湛江市| 洛阳市| 武鸣县| 江油市| 永仁县| 西乡县| 理塘县| 吴桥县| 泸定县| 衡阳市| 北安市| 酉阳| 黎城县| 金塔县| 常宁市| 淳化县| 汾阳市| 拉萨市| 彩票| 恩平市| 兴文县|