OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3464|回复: 13

stm32mp157的spi1使用问题

[复制链接]

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
发表于 2022-5-13 16:15:53 | 显示全部楼层 |阅读模式
10金钱
写了一个使用spi1进行数据接收的demo,在debug模式下调试使用HAL_SPI_Receive接收和HAL_SPI_Receive_DMA接收都可以正常的接收到数据。之后想要在emmc模式下去进行spi1的数据传输。
如下屏蔽了spi给a7的节点,增加给m4的节点

增加节点信息


将stm32mp157-m4-srm.dtsi内的节点状态设为okay

编译后进行工程模式调试,HAL_SPI_Receive函数一直是返回错误,接收超时。搜索了引脚文件spi1的nss引脚并没有被使用。查看/dev文件下也并没有spi节点。我想知道问题出在哪里,应该怎样修改


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-5-13 16:42:52 | 显示全部楼层
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-5-13 16:43:23 | 显示全部楼层
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-5-13 16:43:54 | 显示全部楼层
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-5-13 16:44:29 | 显示全部楼层
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165353
金钱
165353
注册时间
2010-12-1
在线时间
2108 小时
发表于 2022-5-15 20:11:40 | 显示全部楼层
帮顶
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-6-25 11:03:09 | 显示全部楼层
修改tf文件内的spi1时钟为pll4p即可
回复

使用道具 举报

2

主题

394

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2085
金钱
2085
注册时间
2012-5-8
在线时间
312 小时
发表于 2022-6-29 08:41:21 | 显示全部楼层
楼主是不是使用的mode3模式,使用spi的mode3模式,不知道为什么就不正常
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-7-14 14:43:53 | 显示全部楼层
zuoyi 发表于 2022-6-29 08:41
楼主是不是使用的mode3模式,使用spi的mode3模式,不知道为什么就不正常

把tf里的CLK_SPI2S1_PLL3Q改成CLK_SPI2S1_PLL4P,更新一下tf就可以了
回复

使用道具 举报

2

主题

394

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2085
金钱
2085
注册时间
2012-5-8
在线时间
312 小时
发表于 2022-7-16 08:19:20 | 显示全部楼层
uoe 发表于 2022-7-14 14:43
把tf里的CLK_SPI2S1_PLL3Q改成CLK_SPI2S1_PLL4P,更新一下tf就可以了

请问为什么跟时钟有关系?我看逻辑分析仪,是SCLK片选有效时候才高电平,片选无效时,变为低电平。
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-7-18 13:30:52 | 显示全部楼层
zuoyi 发表于 2022-7-16 08:19
请问为什么跟时钟有关系?我看逻辑分析仪,是SCLK片选有效时候才高电平,片选无效时,变为低电平。

你可以试一下把内核的sdmmc3节点屏蔽掉,或者把tf里的sdmmc3的时钟设为DISABLED,再看一下在debug和emmmc模式下的接收时间,可以看到emmc模式下的时间要长很多,这个问题我现在还没有解决。
回复

使用道具 举报

1

主题

96

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
426
金钱
426
注册时间
2021-3-9
在线时间
56 小时
发表于 2022-7-19 16:44:04 | 显示全部楼层
用ide调试m核是用的m核里面配置的时钟,在a核运行起了Linux后时钟是受tf-a管理。
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-7-20 08:40:12 | 显示全部楼层
xiaoxiao315 发表于 2022-7-19 16:44
用ide调试m核是用的m核里面配置的时钟,在a核运行起了Linux后时钟是受tf-a管理。

但是不知道 为什么spi1用pll4p以外的时钟源,spi接收不到数据
回复

使用道具 举报

4

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2020-5-22
在线时间
22 小时
 楼主| 发表于 2022-7-20 15:14:55 | 显示全部楼层
xiaoxiao315 发表于 2022-7-19 16:44
用ide调试m核是用的m核里面配置的时钟,在a核运行起了Linux后时钟是受tf-a管理。

spi1时钟源为pll3q的时候要正常接收的话,要把drives/clk/clk.c里的static bool clk_ignore_unused;改为static bool clk_ignore_unused=true;然后更换uImage
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-25 12:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表