1. 程式人生 > >在 S5PV210 的 開發板上 使用 串口 收發信息

在 S5PV210 的 開發板上 使用 串口 收發信息

devices type 編譯 打印 fin 參考 hello += 文件寫入

參考學習教程:周立功嵌入式Linux開發教程-(上冊)

材料:首先 準備一個 安裝好 Linux 的 開發板

使用 xshell 工具 連接 開發板 ,winscp 工具 連接 開發板 , 準備 一個 Ubuntu 32位 ,裝上 交叉編譯鏈。。

使用下面 代碼 和 Makefile 文件 進行編譯 ,生成的 執行 文件 利用 winscp 軟件復制到 Linux開發板上 ,利用 xshell 運行 這個可執行文件。

下面 代碼的 功能 是 打開 串口 ,進行 等待接收 串口的 數據 ,接收完畢 後 利用 printf 打印出來 ,然後給串口返回一個 hello ,這個 是 在 led的 基礎上更改的 。。。2017年6月29日10:31:03

#include <stdint.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <getopt.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include <linux/types.h>
#include <string.h>

//socket 頭文件 2017年6月28日09:40:47,所長
#include <netinet/in.h>
#include 
<sys/socket.h> #include <arpa/inet.h> #include <errno.h> #include <stdbool.h> #define LED_PATH "/sys/devices/platform/x210-led" #define UART0_PATH "/dev/ttyS0" #define OPEN_LED "1" #define OFF_LED "0" #define LED1 1 #define LED2 2 #define
LED3 3 #define LED4 4 #define ledOperationTypeOPEN 1 #define ledOperationTypeOFF 0 #define SERVER_IP "192.168.10.11" #define SERVER_PORT ((uint16_t)7007) int led(int ledNumber,int ledOperationType) { char path[40],data[2]; int fd, ret, flag; strcpy(path, LED_PATH); if ( ledNumber == 1 ) strcat(path, "/led1"); else if( ledNumber == 2 ) strcat(path, "/led2"); else if( ledNumber == 3 ) strcat(path, "/led3"); else if( ledNumber == 4 ) strcat(path, "/led4"); else return -1; printf("打開路徑%s文件",path); fd = open(path, O_RDWR);//打開/sys/devices/platform/x210-led路徑下的 led ledNumber 文件 if( fd < 0 ) //判斷是否打開失敗 { perror("open"); return -2; } else { printf("led%d 文件打開成功.\r\n",ledNumber); } if( ledOperationType == 1) ret = write(fd, OPEN_LED, strlen(OPEN_LED) );//文件寫入內容: OPEN_LED else if( ledOperationType == 0) ret = write(fd, OFF_LED, strlen(OFF_LED) ); //文件寫入內容: OFF_LED else return -3; if( ret < 0 ) { perror("write"); return -4; } else { flag =1; printf("led%d 文件寫入ledOperationType(1:打開LED 0:關閉LED): %d 數據成功.\r\n",ledNumber,ledOperationType); } /* for(;;) { //閃爍 LED1 if( flag == 1 ) {//如果LED燈 是打開的狀態 就關閉LED燈 flag = 0; ret = write(fd, OFF_LED, strlen(OFF_LED) );//文件寫入內容: OFF_LED } else {//如果LED燈 是關閉的狀態 就打開LED燈 flag = 1; ret = write(fd, OPEN_LED, strlen(OPEN_LED) );//文件寫入內容:OPEN_LED } sleep(1); } */ printf("關閉文件,退出進程!\r\n"); close(fd);//文件寫入完畢後 要進行關閉文件 return 0; } int main(int argc, char *argv[]) { int flag =0 ; int fd; int len, i,ret; char buf[64] = "hello GXP!"; char responseMessage[64] = "hello GXP!\r\n"; fd = open(UART0_PATH, O_RDWR | O_NOCTTY); if(fd < 0) { perror(UART0_PATH); printf("打開串口0 失敗!\r\n"); return -1; } else { printf("打開串口0 成功!\r\n"); } for(;;) { (void)memset(buf, 0, sizeof(buf)); len = read(fd, buf, sizeof(buf)); if (len < 0) { printf("read error \n"); return -1; } printf("%s", buf); len = write(fd, responseMessage, strlen(responseMessage)); if (len < 0) { printf("write data error \n"); } } /* for(;;) { //閃爍 LED1 if( flag == 1 ) {//如果LED燈 是打開的狀態 就關閉LED燈 flag = 0; led( LED1 ,ledOperationTypeOFF ); } else {//如果LED燈 是關閉的狀態 就打開LED燈 flag = 1; led( LED1 ,ledOperationTypeOPEN ); } sleep(1); } */ return(0); }

註意 下面 是 Makefile 文件 : 其中 arm-gcc-linux 在 安裝交叉 編譯器 的時候被我 重定義了 應該是 :arm-none-linux-gnueabi-gcc

CFLAGS += -Wall
obj := uart 
src := uart.c
CC  := arm-linux-gcc 

$(obj): $(src)
    $(CC) $(CFLAGS) $^ -o $@ -g

.PHONY: clean
clean:
    -rm $(obj) 

在 S5PV210 的 開發板上 使用 串口 收發信息