在给STM32烧写程序调试的时候,传统20脚JTAG底座个头大,占用PCB面积多,连接线复杂。采用SWD模式st-link,只需要四根线即可与目标板实现通讯,可实现程序下载,单步调试等功能,除了不能检测目标板电压、不能给目标板供电、速度有所降低之外,与完整版ST-Link的功能是一样的。连接图TCKisSWCLK(SerialWireClock)TMsisSWDIO(SerialWiredebugDataInput/Output)
文章目录一、AXI_Lite简介二、AXI_Lite系统框图三、握手协议三、AXI-Lite信号表四、AXI传输机制五、AXI读写时序总结一、AXI_Lite简介AXI_Lite顾名思义即简化版的AXI协议,是对完整的AXI协议裁剪后的AXI协议;特点:突发长度永远是1,即只能单次读写,无法连续读写,常用于配置寄存器;由于删减了逻辑,其资源也消耗较少;地址映射,相较于AXI-Stream,AXI-Lite的每个数据读写都需要对应的地址;二、AXI_Lite系统框图AXI_Lite的系统框图如下:首先,AXI_Lite的读写通道分离,即AXI是一种全双工总线,在同一时刻可以同时进行读写操作;其次
AXI(AdvancedeXtensibleInterface)是ARM公司推出的一种高性能、低成本、可扩展的高速总线接口。它被广泛应用于数字系统中,尤其是嵌入式系统中。AXI接口具有高度的灵活性和可扩展性,可以适应不同的应用场景和系统需求。它支持多种传输类型,包括读取、写入、缓存、锁定和原子性操作,同时还支持带宽、延迟和优先级等参数的配置。此外,AXI接口还支持多个主设备和多个从设备之间的交互操作,可以方便地构建高度集成的系统。AXI接口有三种类型:AXI4、AXI4-Lite和AXI4-Stream。其中,AXI4是最完整、最全面的版本,它支持大量的高级特性,包括数据一致性
【STM32CubeIDE】STM32F103硬件SPI驱动1.8寸TFTLCD128X160ST7735S✨虽然STM32CubeIDE也是基于HAL库,但是还是不能直接转KeilMDK工程,本驱动案例从GitHub下载来的,原始工程使用的是较老版本的STM32CubeIDE配置的,没法在继续在新版本上程序配置,工程只是做了初始化配置。程序并不能直接被点亮,重新配置了lcd初始化函数以及复位函数后,才点被亮屏幕,同时调整好了屏幕显示像素便宜的问题。点亮屏幕是关键,后续可以很方便移植到KeilMDK环境下开发使用。📌Github原工程地址:https://github.com/cat-bear
本人初次接触AXI接口,在了解了AXI接口读写时序后,计划使用AXI接口对BRAM进行读写,并进行仿真测试,AXI接口有三种类型:AXI4、AXI-lite、AXI-stream,我一开始成功对AXI4进行了读写测试,在了解读写时序后这是很简单的,但是在对AXI-lite进行读写测试时,本以为读写时序与AXI4一致,并且端口数量大大减少,实验应该会很快做完,但却出现了下图所示情况: 图中即使使awvalid信号一直为高,awready信号却迟迟无法拉高,这与AXI4仿真时情况不符,之后再一次偶然打包AXI接口的ip时,发现了原因,如下图所示: 此处展示的是模拟
文章目录@[toc]CAN总线概述AXI_CAN简介MicroBlaze硬件配置常用函数使用示例波形实测参考资料工程下载本文是XilinxMicroBlaze系列教程的第8篇文章。CAN总线概述**CAN(ControllerAreaNetwork)**是ISO国际标准化的串行通信协议,是由德国博世(BOSCH)公司在20世纪80年代专门为汽车行业开发的一种串行通信总线。CAN总线有两个ISO国际标准:ISO11519和ISO11898。ISO11519定义了通信速率为10~125Kbps的低速CAN通信标准,属于开环总线,传输速率为40Kbps时,总线长度可达1000米;ISO11898定义
前言一切程序以最后百度网盘链接的程序为准,可能在写文章的时候有些地方有改动。主控:STM32F103C8T61.69TFT-LCD(st7789驱动)一硬件相关说明1.1接线说明CLK:PA4SDA:PA5RST:PA6D/C:PA7BLK:PC14CS:PA81.2硬件初始化TFT-LCD是采用SPI通信的,这里使用stm32f103c8t6的SPI1,初始化代码如下 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE); //使能A端口时钟 GPIO_InitStructure.GPIO_Pin=GPIO_Pin_4|GPIO_Pin_5|
问题描述当使用CubeIDE下载程序时,在这里遇到个STM32CubeIDE需要STLink更新的提示弹出“inordertousetheattachedST-LINKwiththisversionofSTM32CubeIDEanupdateoftheSTLINKfirmwareisrequired”“为了将连接的ST-LINK与此版本的STM32CubeIDE一起使用,需要更新ST-LINK固件”但是使用Cube更新失败的情况,出现如无法读取STLINK版本固件版本号;更新固件过程中,先出现错误后出现成功提示,但更新未完成等问题。解决方法下载并安装STM32ST_LINKUtility软件更
一、前言最近笔者在做项目的时候需要使用zynq中的AXI4-HP总线在PL端读取DDR中的数据这种功能,但是网上很多历程对于这方面只是创建了一个官方提供的IP核用于测试,并且每次写入和读取的长度为4K字节。所以为了满足我自己的项目需求,笔者将官方提供的测试IP核上做修改,主要实现一下功能:1、上升沿使能读取数据。2、读使能后,IP核需要从基地址开始,突发读取X次(X数量可控)3、内置一个同步FIFO将读出的数据暂存在FIFO中。二、IP核修改过程第一步:创建一个官方提供的带AXI4的IP核。可得到两个文件。(创建过程略,网上有很多教程)其中AXI4_v1_0.v是IP核的顶层文件,AXI4读写
文章目录1.1OutstandingTransfer(超前传输)1.1.1什么是Outstanding?1.1.2AXIOutstandingDepth(超前传输深度)1.1.3AXIOutstanding场景上篇文章:ARMAMBAAXI入门2-AXI协议中的BURST下篇文章:ARMAMBAAXI入门4-AXI协议中的Out-of-Ordertransferandinterleave介绍1.1OutstandingTransfer(超前传输)AXI协议上写了一句:theaxiprotocalsupportsmultipleoutstandingtransactions.那么应该怎么理解这个