NXP iMX7 M4 核心 SPI Slave 测试

2024-04-19 11:08
文章标签 测试 核心 spi m4 nxp slave imx7

本文主要是介绍NXP iMX7 M4 核心 SPI Slave 测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

By Toradex秦海

1). 简介

在之前的两篇文章中已经介绍过基于NXP iMX7 异构多核架构进行开发调试,以及iMX7 M4核心PWM驱动开发。本文就继续演示基于iMX7 M4 SPI Slave Mode功能测试。

 

本文所演示的ARM平台同样来自于Toradex 基于NXP iMX7 ARM处理器的Colibri iMX7 ARM嵌入式平台。

 

2. 准备

a). Colibri iMX7S ARM核心版配合Colibri Evaluation Board,分别连接A7核心默认调试串口UART1(载板X27)和M4核心默认调试串口UART2(载板X25上)到开发主机方便调试,另外由于iMX7S只支持一个USB接口,需要通过载板X30连接一个USB Hub后来扩展键盘鼠标外设。更多关于Colibri iMX7的说明请参考Datasheet和Linux开发上手指南。

 

b). 为了测试iMX7 M4 SPI Slave,相应的需要一个SPI Master设备,这里使用Toradex 基于NXP iMX6 ARM处理器的Apalis iMX6 嵌入式模块配合Apalis Evaluation Board 作为SPI Master使用。连接默认调试串口UART1(载板X29)到开发主机方便调试。

 

c). Colibri iMX7 A7核心系统使用Toradex官方发布的Embedded Linux,更新方法请参考这里。

 

d). Apalis iMX6核心系统使用Toradex官方发布的Embedded Linux,更新方法请参考这里。

 

c). 由于本文演示示例使用到了SPI资源,Apalis iMX6和 Colibri iMX7 默认的SPI资源可以参考这里, Apalis iMX6使用SPI1相应管脚,Colibri iMX6使用Colibri默认的SPI管脚,因此需要硬件连接如下:

Apalis Evaluation Board X8 MXM3_221 -> Colibri Evaluation Board X10 SODIMM_88

Apalis Evaluation Board X8 MXM3_223 -> Colibri Evaluation Board X10 SODIMM_90

Apalis Evaluation Board X8 MXM3_225 -> Colibri Evaluation Board X10 SODIMM_92

Apalis Evaluation Board X8 MXM3_227 -> Colibri Evaluation Board X10 SODIMM_86

 

 

3). Colibri iMX7 M4核心FreeRTOS基本资料

a). Colibri iMX7 架构基本说明请参考如下:

   https://developer.toradex.cn/knowledge-base/freertos-on-the-cortex-m4-of-a-colibri-imx7

 

b). 本示例中M4核心运行FreeRTOS v8系统,相关的源代码和sample程序请从下面git下载:

http://git.toradex.cn/cgit/freertos-toradex.git/

 

c). 基本的SDK配置和编译请参考如下:

https://developer.toradex.cn/knowledge-base/freertos-on-the-cortex-m4-of-a-colibri-imx7#Linux_support

 

d). 编译好的M4 firmware如何在Colibri iMX7上面加载运行请参考如下:

https://developer.toradex.cn/knowledge-base/freertos-on-the-cortex-m4-of-a-colibri-imx7#Running_a_Firmware_on_CortexM4

 

e). 几个自带的sample代码简单说明请参考如下:

https://developer.toradex.com/knowledge-base/freertos-on-the-cortex-m4-of-a-colibri-imx7#Examples

 

 

4). Colibri iMX7 M4核心FreeRTOS SPI Slave Mode示例驱动开发

a). 在上一章节中提到的iMX7 M4 FreeRTOS源代码中,已经包含SPI Interrupt/Polling两种模式的Master Mode驱动示例,但没有包含Slave Mode,因此这里我们需要自己创建,本文只演示基于Interrupt模式的Slave Mode驱动示例。

 

b). 首先先对 pin_mux 定义进行修改,添加SPI slave的管脚初始化代码

./ 文件为 freertos-toradex/examples/imx7_colibri_m4/ 路径下的pin_mux.h和pin_mux.c 文件,patch参考如下:

https://github.com/simonqin09/iMX7_M4_SPI_Slave_Driver/blob/master/pin_mux.patch

 

c). 然后在 FreeRTOS 源代码目录下 “v8/freertos-toradex/examples/imx7_colibri_m4/driver_examples/ecspi/ecspi_interrupt/” 创建 slave项目目录,项目包含文件如下:

./ hardware_init.c 文件,硬件初始化配置,具体内容参考如下:

https://github.com/simonqin09/iMX7_M4_SPI_Slave_Driver/blob/master/hardware_init.c

./ armgcc目录,用于编译,几乎和master项目下的armgcc文件是完全一样的,唯一就是修改了 CMakeLists.txt 文件中定义的 ProjectName 为 ecspi_interrupt_slave 以便于和 master 应用区分,具体文件内容可以参考如下:

https://github.com/simonqin09/iMX7_M4_SPI_Slave_Driver/tree/master/armgcc

./ main.c 文件,SPI interrupt slave的核心程序代码,具体内容和一些简单说明如下:

https://github.com/simonqin09/iMX7_M4_SPI_Slave_Driver/blob/master/main.c

 

// ECSPI_SlaveGetTransferStatus 函数用于标识传输完成

// ECSPI_SlaveConfig 函数用于初始化SPI slave模式的相关参数,使能相关中断,初始化发送寄存器等

// BOARD_ECSPI_HANDLER 函数用于处理中断,这里主要实现接收并保存收到的数据,同时向发送寄存器推送预存的数据

// main 函数为主函数,主要调用上面的初始化函数进行初始化,然后通过一个while循环将接收和发送的数据打印出来。

 

d). 对iMX7 M4 FreeRTOS代码进行debug的方法请参考这里,本文就不再赘述。

 

 

5). Colibri iMX7 M4 SPI Slave驱动示例部署

a). 在部署之前,首先需要确保将本文所使用的 SPI资源从 iMX7 A7 核心 Linux device tree中disable,以免发生资源冲突。有两种方法如下:

./ 参考这里下载A7 Linux kernel源代码,再参考这里修改device tree后重新编译部署。

 

./ 可以直接在uboot中通过 ”fdt_fixup” 环境变量来临时禁止

-----------------------------

/* set fdt_fixup variable with UARTB and SPI disable */

# setenv fdt_fixup ‘fdt_fixup=fdt addr ${fdt_addr_r} && fdt rm /soc/aips-bus@30800000/spba-bus@30800000/serial@30890000 && fdt rm /soc/aips-bus@30800000/spba-bus@30800000/ecspi@30840000’

-----------------------------

 

b). 对应的基于Apalis iMX6平台的SPI Master 使用基于Linux kernel自带的 spidev_test 应用来进行测试,部署如下:

./ linux kernel spidev_test 原始源代码请参考这里,为了测试方便,本文应用做了如下修改:

https://github.com/simonqin09/iMX7_M4_SPI_Slave_Driver/blob/master/spidev_test.patch

./ 参考这里的说明对 spidev_test.c 进行编译,生成 spidev_test 可执行程序,将程序复制到 Apalis iMX6模块准备后续使用。

 

c). 参考上面的相关文档或者之前的文章将SPI slave测试驱动的M4 firmware “ecspi_interrupt_slave.elf” 通过iMX7 uboot进行加载运行,本文通过tftp进行加载测试

------------------------------------------

Colibri iMX7 # tftp ${loadaddr} ecspi_interrupt_slave.elf

Using FEC0 device

TFTP from server 10.20.1.116; our IP address is 10.20.1.10

Filename 'ecspi_interrupt_slave.elf'.

Load address: 0x80800000

Loading: ##################################################  38.3 KiB

         4.2 MiB/s

done

Bytes transferred = 39262 (995e hex)

Colibri iMX7 # bootaux ${loadaddr}

## Starting auxiliary core at 0x1FFF80D1 ...

------------------------------------------

 

d). SPI master和slave 数据传输测试

./ 首先上面的M4 firmware加载运行成功后,M4 调试串口打印信息如下:

------------------------------------------

-------------- ECSPI slave driver example --------------

This example application demonstrates usage of SPI driver in slave mode.

It responses to remote processor in SPI master mode.

SLAVE: Ready to transfer data with Master.

------------------------------------------

 

./ 然后在Apalis iMX6执行 spidev_test程序,iMX6 调试串口打印信息如下:

------------------------------------------

root@apalis-imx6:~# ./spidev_test_new -H -v

spi mode: 0x1

bits per word: 8

max speed: 500000 Hz (500 KHz)

TX | 01 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | FF __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

TX | 02 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | FE __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 03 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | FD __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 04 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | FC __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 05 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | FB __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 06 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | FA __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 07 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F9 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 08 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F8 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 09 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F7 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 0A __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F6 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 0B __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F5 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 0C __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F4 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 0D __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F3 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 0E __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F2 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 0F __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F1 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

TX | 10 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | .

RX | F0 __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __ __  | �

------------------------------------------

 

./ 此时 iMX7 M4 调试串口打印信息如下

------------------------------------------

SLAVE: Data transfer result:

Rx data:  0x01 0x02 0x03 0x04 0x05 0x06 0x07 0x08 0x09 0x0A 0x0B 0x0C 0x0D 0x0E 0x0F 0x10

Tx data:  0xFF 0xFE 0xFD 0xFC 0xFB 0xFA 0xF9 0xF8 0xF7 0xF6 0xF5 0xF4 0xF3 0xF2 0xF1 0xF0

------------------------------------------

 

./ 对比可以看到,M4 SPI slave 成功收到了 iMX6 SPI master发出的数据,同时也将预存的数据发送给了iMX6 SPI master,并且其也成功正确接收了。

 

 

7). 总结

本文简单示例了基于iMX7 M4 SPI Slave模式的驱动供参考。

这篇关于NXP iMX7 M4 核心 SPI Slave 测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/917367

相关文章

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

PostgreSQL核心功能特性与使用领域及场景分析

PostgreSQL有什么优点? 开源和免费 PostgreSQL是一个开源的数据库管理系统,可以免费使用和修改。这降低了企业的成本,并为开发者提供了一个活跃的社区和丰富的资源。 高度兼容 PostgreSQL支持多种操作系统(如Linux、Windows、macOS等)和编程语言(如C、C++、Java、Python、Ruby等),并提供了多种接口(如JDBC、ODBC、ADO.NET等

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理 秒杀系统是应对高并发、高压力下的典型业务场景,涉及到并发控制、库存管理、事务管理等多个关键技术点。本文将深入剖析秒杀商品业务中常见的几个核心问题,包括 AOP 事务管理、同步锁机制、乐观锁、CAS 操作,以及用户限购策略。通过这些技术的结合,确保秒杀系统在高并发场景下的稳定性和一致性。 1. AOP 代理对象与事务管理 在秒杀商品

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采