3696
- 收藏
- 点赞
- 分享
- 举报
雄迈400万TF卡内核补丁
雄迈板子SDIO电压是固定3.3V,由于UHS操作电压是1.8V,因此把UHS支持关掉。
需要注释掉 drivers/mmc/host/himci/himci.c 里面的
/* | MMC_CAP_UHS_SDR12 */
/* | MMC_CAP_UHS_SDR25 */
/* | MMC_CAP_UHS_SDR50 */
/* | MMC_CAP_UHS_DDR50 */
/* | MMC_CAP_UHS_SDR104 */
另外由于CARD_DETECT是上拉到3.3V了,而且没有导出这只引脚,因此放弃使用CARD_DETECT,使用PWR_EN引脚作为CARD_DETECT
需要修改 uboot 的reginfo.bin,修改引脚复用
200F0000
0x0EC muxctrl_reg59 SDIO1_CARD_POWER_EN 管脚的复用控制寄存器2-97
0 GPIO11_1
1 SDIO1_CARD_POWER_EN
这个复用改成0。也就是说把J21引脚功能改成GPIO11_1
还需要修改hi_mci_sys_card_detect函数的实现,下面会说怎么改
先说GPIO怎么配置
GPIO11基地址 0x201F_0000
表13-21 GPIO 寄存器概览
偏移地址 名称 描述 页码
0x000~0x3FC GPIO_DATA GPIO 数据寄存器 13-148
0x400 GPIO_DIR GPIO 方向控制寄存器 13-148 <<<<<<<<<<<< [0:7]有效 0输入 1输出 <<<<<<<<<<<<<<
0x404 GPIO_IS GPIO 中断触发寄存器 13-149
0x408 GPIO_IBE GPIO 双沿触发中断寄存器 13-149
0x40C GPIO_IEV GPIO 触发中断条件寄存器 13-150
0x410 GPIO_IE GPIO 中断屏蔽寄存器 13-150 <<<<<<<<<<<< [0:7]有效 0屏蔽 1不屏蔽 <<<<<<<<<<<<<<
0x414 GPIO_RIS GPIO 原始中断状态寄存器 13-151
0x418 GPIO_MIS GPIO 屏蔽状态中断寄存器 13-151
0x41C GPIO_IC GPIO 中断清除寄存器 13-152
DATA寄存器 0~3FC [9:0] 共10比特,低2比特是 4字节对齐操作的,因此高8比特分别对应8个GPIO管脚的有效MASK
例如
如果只想写入GPIOX_7为1,则向地址 +0x200 写入 0x80 即可。
如果只想写入GPIOX_1为1,则向地址 +0x8 写入 0x02 即可。
读取同理<<<<<<<<<<<<<
修改代码 hi_mci.h
himci_host 结构体 追加
void __iomem *gpio_cd_base;
修改代码 himci.c
hi_mci_probe函数
#ifdef CONFIG_HIMCI0
host->id = 0;
host->base = ioremap_nocache(CONFIG_HIMCI0_IOBASE, HI_MCI_IO_SIZE);
host->gpio_cd_base = NULL; //sdio0 not use
#endif
} else if (1 == pdev->id) {
#ifdef CONFIG_HIMCI1
unsigned int regv;
host->id = 1;
host->base = ioremap_nocache(CONFIG_HIMCI1_IOBASE, HI_MCI_IO_SIZE);
host->gpio_cd_base = ioremap_nocache(0x201F0000, 0x1000);
regv = readl(host->gpio_cd_base + 0x400);
himci_writel(regv & (~(1<<1)), host->gpio_cd_base + 0x400);
regv = readl(host->gpio_cd_base + 0x410);
himci_writel(regv & (~(1<<1)), host->gpio_cd_base + 0x410);
#endif
修改函数 hi_mci_sys_card_detect
/**********************************************
*1: card off
*0: card on
***********************************************/
static unsigned int hi_mci_sys_card_detect(struct himci_host *host)
{
unsigned int regv;
if(host->gpio_cd_base == NULL)
return 1;
regv = readl(host->gpio_cd_base + 0x3FC);
if(regv & (1<<1))
return 1;
return 0;
}
这样原P8的12pin座第七个引脚SDIO1_POWER_EN就改成了CARD_DETECT功能。注意这个引脚是直接引出的,这里使用的时候需要上拉电阻到3.3V。当CD被拉低时表示有卡插入
编译了内核后测试正常
反复插卡拔卡日志如下
card connected!
mmc1: new high speed SDHC card at address aaaa
mmcblk0: mmc1:aaaa SL16G 14.8 GiB
mmcblk0: p1
card disconnected!
mmc1: card aaaa removed
card connected!
mmc1: new high speed SDHC card at address aaaa
mmcblk0: mmc1:aaaa SL16G 14.8 GiB
mmcblk0: p1
card disconnected!
mmc1: card aaaa removed
card connected!
mmc1: new high speed SDHC card at address aaaa
mmcblk0: mmc1:aaaa SL16G 14.8 GiB
mmcblk0: p1
需要注释掉 drivers/mmc/host/himci/himci.c 里面的
/* | MMC_CAP_UHS_SDR12 */
/* | MMC_CAP_UHS_SDR25 */
/* | MMC_CAP_UHS_SDR50 */
/* | MMC_CAP_UHS_DDR50 */
/* | MMC_CAP_UHS_SDR104 */
另外由于CARD_DETECT是上拉到3.3V了,而且没有导出这只引脚,因此放弃使用CARD_DETECT,使用PWR_EN引脚作为CARD_DETECT
需要修改 uboot 的reginfo.bin,修改引脚复用
200F0000
0x0EC muxctrl_reg59 SDIO1_CARD_POWER_EN 管脚的复用控制寄存器2-97
0 GPIO11_1
1 SDIO1_CARD_POWER_EN
这个复用改成0。也就是说把J21引脚功能改成GPIO11_1
还需要修改hi_mci_sys_card_detect函数的实现,下面会说怎么改
先说GPIO怎么配置
GPIO11基地址 0x201F_0000
表13-21 GPIO 寄存器概览
偏移地址 名称 描述 页码
0x000~0x3FC GPIO_DATA GPIO 数据寄存器 13-148
0x400 GPIO_DIR GPIO 方向控制寄存器 13-148 <<<<<<<<<<<< [0:7]有效 0输入 1输出 <<<<<<<<<<<<<<
0x404 GPIO_IS GPIO 中断触发寄存器 13-149
0x408 GPIO_IBE GPIO 双沿触发中断寄存器 13-149
0x40C GPIO_IEV GPIO 触发中断条件寄存器 13-150
0x410 GPIO_IE GPIO 中断屏蔽寄存器 13-150 <<<<<<<<<<<< [0:7]有效 0屏蔽 1不屏蔽 <<<<<<<<<<<<<<
0x414 GPIO_RIS GPIO 原始中断状态寄存器 13-151
0x418 GPIO_MIS GPIO 屏蔽状态中断寄存器 13-151
0x41C GPIO_IC GPIO 中断清除寄存器 13-152
DATA寄存器 0~3FC [9:0] 共10比特,低2比特是 4字节对齐操作的,因此高8比特分别对应8个GPIO管脚的有效MASK
例如
如果只想写入GPIOX_7为1,则向地址 +0x200 写入 0x80 即可。
如果只想写入GPIOX_1为1,则向地址 +0x8 写入 0x02 即可。
读取同理<<<<<<<<<<<<<
修改代码 hi_mci.h
himci_host 结构体 追加
void __iomem *gpio_cd_base;
修改代码 himci.c
hi_mci_probe函数
#ifdef CONFIG_HIMCI0
host->id = 0;
host->base = ioremap_nocache(CONFIG_HIMCI0_IOBASE, HI_MCI_IO_SIZE);
host->gpio_cd_base = NULL; //sdio0 not use
#endif
} else if (1 == pdev->id) {
#ifdef CONFIG_HIMCI1
unsigned int regv;
host->id = 1;
host->base = ioremap_nocache(CONFIG_HIMCI1_IOBASE, HI_MCI_IO_SIZE);
host->gpio_cd_base = ioremap_nocache(0x201F0000, 0x1000);
regv = readl(host->gpio_cd_base + 0x400);
himci_writel(regv & (~(1<<1)), host->gpio_cd_base + 0x400);
regv = readl(host->gpio_cd_base + 0x410);
himci_writel(regv & (~(1<<1)), host->gpio_cd_base + 0x410);
#endif
修改函数 hi_mci_sys_card_detect
/**********************************************
*1: card off
*0: card on
***********************************************/
static unsigned int hi_mci_sys_card_detect(struct himci_host *host)
{
unsigned int regv;
if(host->gpio_cd_base == NULL)
return 1;
regv = readl(host->gpio_cd_base + 0x3FC);
if(regv & (1<<1))
return 1;
return 0;
}
这样原P8的12pin座第七个引脚SDIO1_POWER_EN就改成了CARD_DETECT功能。注意这个引脚是直接引出的,这里使用的时候需要上拉电阻到3.3V。当CD被拉低时表示有卡插入
编译了内核后测试正常
反复插卡拔卡日志如下
card connected!
mmc1: new high speed SDHC card at address aaaa
mmcblk0: mmc1:aaaa SL16G 14.8 GiB
mmcblk0: p1
card disconnected!
mmc1: card aaaa removed
card connected!
mmc1: new high speed SDHC card at address aaaa
mmcblk0: mmc1:aaaa SL16G 14.8 GiB
mmcblk0: p1
card disconnected!
mmc1: card aaaa removed
card connected!
mmc1: new high speed SDHC card at address aaaa
mmcblk0: mmc1:aaaa SL16G 14.8 GiB
mmcblk0: p1
我来回答
回答3个
时间排序
认可量排序
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2016-03-22 10:19:16
-
2015-04-25 09:18:14
-
2016-07-25 12:33:28
-
2015-07-28 14:21:13
-
2016-03-22 10:21:21
-
72018-04-20 10:37:01
-
2020-03-02 16:08:48
-
2014-12-08 09:42:40
-
2018-01-31 12:45:55
-
2020-09-01 20:55:24
-
2016-09-09 17:43:12
-
2016-10-30 19:00:28
-
2015-09-30 11:59:36
-
2013-08-22 16:25:09
-
2019-06-24 17:30:54
-
2016-08-03 12:43:05
-
2020-04-25 11:00:17
-
2018-05-11 10:13:42
-
2017-11-01 11:51:15
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5SS928的emmc有32GB,bootargs设置使用16GB,但是为啥能用的只有rootfs的大小
-
33SS928怎样烧写ubuntu系统
-
10ToolPlatform下载rootfs提示网络失败
-
10谁有GK7205V500的SDK
-
5Hi3516CV610 烧录不进去
-
10Hi3559AV100 芯片硬解码h265编码格式的视频时出现视频播放错误,解码错误信息 s32PackErr:码流有错
-
5海思SS928 / SD3403的sample_venc.c摄像头编码Demo中,采集到的摄像头的YUV数据在哪个相关的函数中?
-
5海鸥派openEuler无法启动网卡,连接WIFI存在问题
-
66有没有ISP相关的巨佬帮忙看看SS928对接IMX347的图像问题
-
50求助hi3559与FPGA通过SLVS-EC接口对接问题
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认