草庐IT

spi 子系统

spi在应用层的体现spi分为主机模式和从机模式,一般soc自带的spi控制器,我们都将它用作主机模式与外挂的从设备通信。从设备例如oled芯片、flash芯片、陀螺仪芯片等等。那么spi驱动和设备,自然也就分为主机驱动、设备和从机驱动、设备。那么如何在Linux下查看这些信息呢?首先查看spi控制器的驱动和设备信息:spi控制器的驱动和设备在内核中由platform总线来管理,使用platform_device表示设备,platform_driver表示驱动。所以查找/sys/bus/platform/devices/目录就可以发现spi控制器的设备信息,设备名字由设备树的节点名来决定:在设

AXI-Stream 学习笔记

参考https://wuzhikai.blog.csdn.net/article/details/121326701https://zhuanlan.zhihu.com/p/152283168AXI4介绍AXI4是ARM公司提出的一种片内总线,描述了主从设备之间的数据传输方式。主要有AXI4_LITE、AXI4_FULL、AXI4_STREAM三种。AXI4_LITE:不支持突发传输,一般用于小数据量的IP初始化和嵌入式设备数据传输。AXI4_FULL:可称为AXI4,支持突发传输,突发长度为1~256。AXI4_STREAM:流数据,丢弃了地址项,用于高速数据传输。AXI-Stream顾名思

SPI通信协议及基于Arduino的SPI通信例程

一、SPI通信协议介绍SPI通信协议(SerialPeripheralInterface)是一种同步串行通信协议,由Motorola公司在1980年代初开发。SPI协议常用于单片机、嵌入式系统和外围设备之间的通信。SPI协议使用四根线进行通信:时钟线(SCLK)、数据输入线(MOSI)、数据输出线(MISO)和从机选择线(SS)。主设备控制时钟线,每产生一个时钟脉冲,数据输入线上就会输出一个数据位,数据输出线上则会输入一个数据位。从机通过从机选择线来判断自己是否需要响应主设备的传输请求。SPI协议具有以下特点:速度较快:SPI通信协议采用同步传输方式,可以达到高速传输的目的,最高传输速率可以达

SPI方式读写SD卡速度有多快?

很久没有写公众号了,一方面忙,另一方面也不知道写些什么内容,大家如果有想了解的(前提是我也懂),可以后台发送给我。今天主要来测试一下SPI读写SD卡的速度。SD卡是一个嵌入式中非常常用的外设,可以用于存储一些大容量的数据。但用单片机读写SD卡速度一般都有限(对于高速SD卡,主要是受限于单片机本身的接口速度),在高速、实时数据存储时可能会有影响。但具体速度可以达到多少呢,今天就来实际测试一下。SD卡一般有两种常用的接口SPI和SDIO,SDIO又有1线和4线之分。很多单片机没有SDIO接口,但SPI接口就比较常用,今天主要来测试一下SPI接口读写SD卡的速度,主要是写入速度。     测试条件:

AXI 协议中的“对齐”与“非对齐”访问

1.对齐传输:在实际硬件中,一个寄存器一般是存储8位数据,所以对于一笔32位的数据,就需要4个寄存器来存储,因此这笔32位的数据的地址需要以0X00,0X04,0X08···这样使用,也就是所谓的地址对齐2.非对齐传输AHB总线只支持对齐传输,而AXI协议支持地址的非对齐传输(且burst类型为wrap的不支持)。非对齐传输也就是所谓的可以访问的地址不需要以上例中0X00,0X04,0X08···这样使用。在第一笔数据的传输时,如果首地址不是对齐的,那么主设备会在第一笔传输中对数据进行填充,直到首次传输填充至地址对齐,然后,再用WSTRB信号将填充的数据标记为无效。以访问(32位数据)地址为0

on-chip-bus(四)AXI总线:突发长度、突发大小以及非对齐传输的理解

1.突发长度、突发大小突发长度(burstlength):指在一次突发传输中进行的数据传输次数,用AxLEN字段标识。由于标识值是从0开始的,实际的突发长度应为标识值+1,即突发长度=AxLEN+1.突发大小(burstsize):指突发传输中的每次数据传输的字节数,用AxSIZE字段标示。突发大小=2^AxSIZE2.非对齐传输(UnalignedTransfer)    首先需要理解地址的对齐传输:在ARM的32bit的地址总线中,其最低两位[1:0]=0,所以从第三位开始,地址也就是4的倍数,如0x00,0x04,0x08等,都是对齐的。    AHB总线只支持对齐传输,而AXI协议支持

AXI4协议学习:架构、信号定义、工作时序和握手机制

目录1AXI是什么?2AXI怎么工作?3AXI协议3.1架构3.1.1通道定义3.1.2接口与互连(interconnect)3.1.3Registerslices3.2基本事务3.2.1突发读示例3.2.2重叠突发读示例3.2.3突发写示例3.2.4事务顺序3.3额外的功能4信号定义4.1全局信号4.2写地址通道信号4.3写数据通道信号4.4写响应通道信号4.5读地址通道信号4.6读数据通道信号4.7低功耗接口信号4.8字段定义的简单说明:4.9AXI-Lite与AXI-stream的接口5通道握手机制5.1握手过程5.2通道之间的关系5.3通道握手信号之间的依赖关系6AXI4相关文件7需要

GD32 SPI DMA收发

由于需求用到GD32SPI,故做相关实验记录分享,本实验为SPIDMA发送与接收 16bit数据,GD32相关配置如下GD32F30x系列DMA配置如下 SPIDMA发:使用SPI0,对应的DMA为0Channel2。 注意打开对应DMA与SPI相关时钟,DMAwrite使用时需要先拉低NSS,发送结束,拉高NSSvoidSPI0_config(void){ rcu_periph_clock_enable(RCU_GPIOA);rcu_periph_clock_enable(RCU_SPI0); rcu_periph_clock_enable(RCU_DMA0);/*SPI0GPIOconfi

STM32模拟SPI协议获取24位模数转换(24bit ADC)芯片AD7791电压采样数据

STM32模拟SPI协议获取24位模数转换(24bitADC)芯片AD7791电压采样数据STM32大部分芯片只有12位的ADC采样性能,如果要实现更高精度的模数转换如24位ADC采样,则需要连接外部ADC实现。AD7791是亚德诺(ADI)半导体一款用于低功耗、24位Σ-Δ型模数转换器(ADC),适合低频测量应用,提供50Hz/60Hz同步抑制。这里介绍基于AD7791的24位ADC采样实现。AD7791控制协议AD7791的管脚如下所示:AD7791可以工作在2.5V~5.25V供电范围(VDD),而用于模数转换的参考电压可以通过引脚REFIN(+)和REFIN(–)单独设置,从而可以针对

FPGA基于AXI 1G/2.5G Ethernet Subsystem实现UDP通信DMA传输 提供工程源码和技术支持

目录1、前言2、我这里已有的UDP方案3、详细设计方案传统UDP网络通信方案本方案详细设计说明DMA和BRAMAXIS-FIFOUDP模块设计UDP模块FIFOAXI1G/2.5GEthernetSubsystem:输出4、vivado工程详解5、上板调试验证并演示注意事项6、福利:工程代码的获取1、前言目前网上的fpga实现udp基本生态如下:1:verilog编写的udp收发器,但不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的代码,试想,多机互联,出现了问题,你的网卡都不带ping功能,连基本的问题排查机制都不具备,这样的代码谁敢用?2