使用串口时O_NOCTTY | O_NDELAY参数作用

Linux打开串口和打开文件一样使用open函数

例如:

fd1 = open( "...", O_RDWR | O_NOCTTY | O_NDELAY);

参数:
“…” : 文件路径

O_RDWR : 可读可写

O_NOCTTY :该参数不会使打开的文件成为该进程的控制终端。如果没有指定这个标志,那么任何一个 输入都将会影响用户的进程。

O_NDELAY :这个程序不关心DCD信号线所处的状态,端口的另一端是否激活或者停止。如果用户不指定了这个标志,则进程将会一直处在睡眠状态,直到DCD信号线被激活。

  • 8
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
解释以下代码#include <stdio.h>#include <stdlib.h>#include <string.h>#include <unistd.h>#include <fcntl.h>#include <termios.h>#define XBEE_DEV "/dev/ttyUSB0"#define BAUDRATE B9600int xbee_fd;int open_xbee() { xbee_fd = open(XBEE_DEV, O_RDWR | O_NOCTTY | O_NDELAY); if (xbee_fd < 0) { perror("open"); return -1; } struct termios options; tcgetattr(xbee_fd, &options); cfsetispeed(&options, BAUDRATE); cfsetospeed(&options, BAUDRATE); options.c_cflag |= (CLOCAL | CREAD); options.c_cflag &= ~CSIZE; options.c_cflag |= CS8; options.c_cflag &= ~PARENB; options.c_cflag &= ~CSTOPB; options.c_cflag &= ~CRTSCTS; options.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG); options.c_oflag &= ~OPOST; tcsetattr(xbee_fd, TCSANOW, &options); return 0;}void close_xbee() { close(xbee_fd);}int send_xbee(const char* data, size_t len) { return write(xbee_fd, data, len);}int recv_xbee(char* buf, size_t len) { return read(xbee_fd, buf, len);}int main() { if (open_xbee() < 0) { return 1; } // 发送 AT 命令,获取本地节点的网络地址 send_xbee("ATMY\r", 5); usleep(100000); char recv_buf[256]; size_t recv_len = recv_xbee(recv_buf, 256); if (recv_len <= 0) { printf("Failed to get local address\n"); close_xbee(); return 1; } recv_buf[recv_len] = '\0'; printf("Local address: %s", recv_buf); // 发送 AT 命令,启用协调器模式 send_xbee("ATCE\r", 5); usleep(100000); // 发送 AT 命令,设置 PAN ID send_xbee("ATID1234\r", 10); usleep(100000); // 发送 AT 命令,设置信道 send_xbee("ATCH0C\r", 8); usleep(100000); // 发送 AT 命令,保存参数 send_xbee("ATWR\r", 4); usleep(100000); // 发送 AT 命令,重启 XBee 模块 send_xbee("ATFR\r", 4); usleep(100000); // 等待重启完成 sleep(1); // 发送 AT 命令,获取协调器的地址 send_xbee("ATND\r", 5); usleep(100000); recv_len = recv_xbee(recv_buf, 256); if (recv_len <= 0) { printf("Failed to get coordinator address\n"); close_xbee(); return 1; } recv_buf[recv_len] = '\0'; char *p = strstr(recv_buf, "Addr"); if (p != NULL) { p += 6; printf("Coordinator address: %c%c%c%c\n", p[0], p[1], p[2], p[3]); } else { printf("Failed to get coordinator address\n"); } close_xbee(); return 0;}
最新发布
05-24

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值