完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
1.设备树
&spi0 { /delete-property/ pinctrl-1; max-freq = <50000000>; pinctrl-0 = <&spi0m1_clk &spi0m1_cs0n &spi0m1_cs1n &spi0m1_miso &spi0m1_mosi>; status = "okay"; spi_test@00 { compatible = "rockchip,spidev"; reg = <0>; spi-max-frequency = <5000000>; }; }; 重新编译内核,启动后看日志是否加载成功,并且启动后有类似/dev/spidev0.0名称的设备。 2. 测试 2.1 使用shell测试 echo 1 > /dev/spidev0.0 时钟和数据线会有波形。 2.2 测试应用 #include "spi_test.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #define SPI_DEBUG 1 static const char *device = "/dev/spidev0.0"; static uint8_t mode = 3; /* SPI通信使用全双工,设置CPOL=1,CPHA=1。 */ static uint8_t bits = 8; /* 8bits读写,MSB first。*/ static uint32_t speed = 24 * 1000 * 1000;/* 设置12M传输速度 */ static uint16_t delay = 0; int g_SPI_Fd; /********************************************************************************** * 功 能:打开设备 并初始化设备 * 入口参数 : * 出口参数: * 返回值:0 表示已打开 0XF1 表示SPI已打开 其它出错 ***********************************************************************************/ int spi_init(void) { int fd; int ret = 0; // mode=SPI_MODE_0; if (g_SPI_Fd != 0) /* 设备已打开 */ return 0xF1; fd = open(device, O_RDWR); if (fd < 0) printf("can't open device"); else printf("SPI - Open Succeed. Start Init SPI...n"); g_SPI_Fd = fd; /* * spi mode */ ret = ioctl(fd, SPI_IOC_WR_MODE, &mode); if (ret == -1) printf("can't set spi mode"); ret = ioctl(fd, SPI_IOC_RD_MODE, &mode); if (ret == -1) printf("can't get spi mode"); /* * bits per word */ ret = ioctl(fd, SPI_IOC_WR_BITS_PER_WORD, &bits); if (ret == -1) printf("can't set bits per word"); ret = ioctl(fd, SPI_IOC_RD_BITS_PER_WORD, &bits); if (ret == -1) printf("can't get bits per word"); /* * max speed hz */ ret = ioctl(fd, SPI_IOC_WR_MAX_SPEED_HZ, &speed); if (ret == -1) printf("can't set max speed hz"); ret = ioctl(fd, SPI_IOC_RD_MAX_SPEED_HZ, &speed); if (ret == -1) printf("can't get max speed hz"); printf("spi mode: %dn", mode); printf("bits per word: %dn", bits); printf("max speed: %d KHz (%d MHz)n", speed / 1000, speed / 1000 / 1000); return ret; } /************************************************************************************* * 功 能:自发自收测试程序 * 接收到的数据与发送的数据如果不一样 ,则失败 * 说明: * 在硬件上需要把输入与输出引脚短跑 ***********************************************************************************/ int spi_lookback_test(void) { int ret, i; const int BufSize = 16; uint8_t tx[BufSize], rx[BufSize]; bzero(rx, sizeof(rx)); for (i = 0; i < BufSize; i++) tx = i; printf("nSPI - LookBack Mode Test...n"); ret = spi_transfer(tx, rx, BufSize); if (ret > 1) { ret = memcmp(tx, rx, BufSize); if (ret != 0) { printf("LookBack Mode Test errorn"); //printf("error"); } else printf("SPI - LookBack Mode OKn"); } return ret; } /*********************************************************************************** * 功 能:同步数据传输 * 入口参数 : * TxBuf -> 发送数据首地址 * len -> 交换数据的长度 * 出口参数: * RxBuf -> 接收数据缓冲区 * 返回值:0 成功 ***********************************************************************************/ int spi_transfer(const uint8_t *TxBuf, uint8_t *RxBuf, uint32_t len) { int ret; int fd = g_SPI_Fd; struct spi_ioc_transfer tr ={ .tx_buf = (unsigned long) TxBuf, .rx_buf = (unsigned long) RxBuf, .len = len, .speed_hz = speed, .delay_usecs = delay, .bits_per_word = bits, .cs_change = 0, .tx_nbits = 8, .rx_nbits = 8, .pad = 0, }; ret = ioctl(fd, SPI_IOC_MESSAGE(1), &tr); if (ret < 1) printf("can't send spi message"); else { #if SPI_DEBUG int i; printf("nsend spi message Succeed"); printf("nSPI Send [Len:%d]: ", len); for (i = 0; i < len; i++) { if (i % 8 == 0) printf("nt"); printf("0x%02X ", TxBuf); } printf("n"); printf("SPI Receive [len:%d]:", len); for (i = 0; i < len; i++) { if (i % 8 == 0) printf("nt"); printf("0x%02X ", RxBuf); } printf("n"); #endif } return ret; } /********************************************************************************** * 功 能:发送数据 * 入口参数 : * TxBuf -> 发送数据首地址 * len -> 发送与长度 * 返回值:0 成功 ***********************************************************************************/ int spi_write(uint8_t *TxBuf, int len) { int ret; ret = write(g_SPI_Fd, TxBuf, len); if (ret < 0) printf("SPI Write errorn"); #if SPI_DEBUG else { int i; printf("nSPI Write [Len:%d]: ", len); for (i = 0; i < len; i++) { if (i % 8 == 0) printf("nt"); printf("0x%02X ", TxBuf); } printf("n"); } #endif return ret; } /********************************************************************************** * 功 能:接收数据 * 出口参数: * RxBuf -> 接收数据缓冲区 * rtn -> 接收到的长度 * 返回值:>=0 成功 ***********************************************************************************/ int spi_read(uint8_t *RxBuf, int len) { int ret; int fd = g_SPI_Fd; ret = read(fd, RxBuf, len); if (ret < 0) printf("SPI Read errornn"); else { #if SPI_DEBUG int i; printf("SPI Read [len:%d]:", len); for (i = 0; i < len; i++) { if (i % 8 == 0) printf("nt"); printf("0x%02X ", RxBuf); } printf("n"); #endif } return ret; } int count = 0; /******************************************************************************* * 描述 : 入口Main函数 *******************************************************************************/ int main(void) { spi_init(); uint8_t data[4] = "123"; while(1) { spi_write(data, 3); sleep(1); count++; printf("count:%dn", count); } return 0; } |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1567 浏览 1 评论
synopsys 的design ware:DW_fpv_div,浮点数除法器,默认32位下,想提升覆盖率(TMAX),如果用功能case去提升覆盖率呢?
1790 浏览 1 评论
RK3588 GStreamer调试四路鱼眼摄像头四宫格显示报错
4465 浏览 1 评论
【飞凌嵌入式OK3576-C开发板体验】RKNN神经网络-YOLO图像识别
254 浏览 0 评论
【飞凌嵌入式OK3576-C开发板体验】SSH远程登录网络配置及CAN通讯
1336 浏览 0 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-10 16:19 , Processed in 0.365971 second(s), Total 41, Slave 34 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号