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

相关文章

Java中的CompletableFuture核心用法和常见场景

《Java中的CompletableFuture核心用法和常见场景》CompletableFuture是Java8引入的强大的异步编程工具,支持链式异步编程、组合、异常处理和回调,介绍其核心用法,通过... 目录1、引言2. 基本概念3. 创建 CompletableFuture3.1. 手动创建3.2.

Java线程池核心参数原理及使用指南

《Java线程池核心参数原理及使用指南》本文详细介绍了Java线程池的基本概念、核心类、核心参数、工作原理、常见类型以及最佳实践,通过理解每个参数的含义和工作原理,可以更好地配置线程池,提高系统性能,... 目录一、线程池概述1.1 什么是线程池1.2 线程池的优势二、线程池核心类三、ThreadPoolE

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

Spring Boot 集成 mybatis核心机制

《SpringBoot集成mybatis核心机制》这篇文章给大家介绍SpringBoot集成mybatis核心机制,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值... 目录Spring Boot浅析1.依赖管理(Starter POMs)2.自动配置(AutoConfigu

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1

Spring Boot/Spring MVC核心注解的作用详解

《SpringBoot/SpringMVC核心注解的作用详解》本文详细介绍了SpringBoot和SpringMVC中最常用的15个核心注解,涵盖了请求路由映射、参数绑定、RESTfulAPI、... 目录一、Spring/Spring MVC注解的核心作用二、请求映射与RESTful API注解系列2.1

CPython与PyPy解释器架构的性能测试结果对比

《CPython与PyPy解释器架构的性能测试结果对比》Python解释器的选择对应用程序性能有着决定性影响,CPython以其稳定性和丰富的生态系统著称;而PyPy作为基于JIT(即时编译)技术的替... 目录引言python解释器架构概述CPython架构解析PyPy架构解析架构对比可视化性能基准测试测

Python异常处理之避免try-except滥用的3个核心原则

《Python异常处理之避免try-except滥用的3个核心原则》在Python开发中,异常处理是保证程序健壮性的关键机制,本文结合真实案例与Python核心机制,提炼出避免异常滥用的三大原则,有需... 目录一、精准打击:只捕获可预见的异常类型1.1 通用异常捕获的陷阱1.2 精准捕获的实践方案1.3

深入浅出Java中的Happens-Before核心规则

《深入浅出Java中的Happens-Before核心规则》本文解析Java内存模型中的Happens-Before原则,解释其定义、核心规则及实际应用,帮助理解多线程可见性与有序性问题,掌握并发编程... 目录前言一、Happens-Before是什么?为什么需要它?1.1 从一个问题说起1.2 Haht

Python进阶之列表推导式的10个核心技巧

《Python进阶之列表推导式的10个核心技巧》在Python编程中,列表推导式(ListComprehension)是提升代码效率的瑞士军刀,本文将通过真实场景案例,揭示列表推导式的进阶用法,希望对... 目录一、基础语法重构:理解推导式的底层逻辑二、嵌套循环:破解多维数据处理难题三、条件表达式:实现分支