am335x system upgrade kernel tf(五)
1 Scope of Document
This document describes TF hardware design
2 Requiremen
2.1 Function Requirement
Enumerate tf card , support boot from tf and can mount in rootfs when nand boot.
2.2 Performance Requirement
Support common capacity tf card
3 Hardware Overview
tf interface,pin map:
// data signal
AM335X_MMC0_DAT3----------MMC0_DAT3
AM335X_MMC0_DAT2----------MMC0_DAT2
AM335X_MMC0_DAT1----------MMC0_DAT1
AM335X_MMC0_DAT0----------MMC0_DAT0
// clk/cmd signal
AM335X_MMC0_CLK-----------MMC0_CLK
AM335X_MMC0_CMD----------MMC0_CMD
// card detect signal
AM335X_MCASP0_ACLK-----MCASP0_ACLKR (gpio3_18)

Figure 1 tf interface block diagram
4 Functional Description
4.1 Functional Block Diagram

Figure 2 inter block diagram
4.2 TF
4.2.1 Overview

AM335x has 3 instances MMC/SD/SDIO host controller, which provides an interface between microprocessor and either MMC, SD memory cards, or SDIO cards.
The MMC/SD driver is implemented as a block driver on top of host controller as a HSMMC controller driver and supports SD, SD High Speed and SDHC cards. The driver only supports for 4 bit modes(no SPI mode, 1/8 Bit). Both DMA & polled mode of data transfer is supported.
5 Porting
5.1 Uboot porting
Index: u-boot-2018.01/include/configs/am335x_evm.h
===================================================================
--- am335x_evm.h (revision 4)
+++ am335x_evm.h (revision 5)
@@ -17,6 +17,7 @@
#define __CONFIG_AM335X_EVM_H
#include <configs/ti_am335x_common.h>
+#define CONFIG_SD_BOOT
#ifndef CONFIG_SPL_BUILD
# define CONFIG_TIMESTAMPKernel porting
Nand to do pin mux in board/ti/am335x/mux.c
configure_module_pin_mux(mmc0_pin_mux_sk_evm);
5.2 Kernel porting
Device Drivers --->
<*> MMC/SD/SDIO card support --->
<*> MMC block device driver
<*> TI OMAP High Speed Multimedia Card Interface support
<M> MMC/SD/SDIO card support --->
<M> MMC block device driver
<M> TI OMAP High Speed Multimedia Card Interface support
Dts file change:
regulators {
compatible = "simple-bus";
vcc3v3: fixedregulator1 {
compatible =
"regulator-fixed";
regulator-name = "vcc3v3";
regulator-min-microvolt
= <3300000>;
regulator-max-microvolt
= <3300000>;
regulator-boot-on;
};
};
mmc1_pins: pinmux_mmc1_pins {
pinctrl-single,pins = <
AM33XX_IOPAD(0x8fc,
PIN_INPUT_PULLUP | MUX_MODE0) /*
mmc0_dat0.mmc0_dat0 */
AM33XX_IOPAD(0x8f8,
PIN_INPUT_PULLUP | MUX_MODE0) /*
mmc0_dat1.mmc0_dat1 */
AM33XX_IOPAD(0x8f4,
PIN_INPUT_PULLUP | MUX_MODE0) /*
mmc0_dat2.mmc0_dat2 */
AM33XX_IOPAD(0x8f0,
PIN_INPUT_PULLUP | MUX_MODE0) /*
mmc0_dat3.mmc0_dat3 */
AM33XX_IOPAD(0x904,
PIN_INPUT_PULLUP | MUX_MODE0) /*
mmc0_cmd.mmc0_cmd */
AM33XX_IOPAD(0x900,
PIN_INPUT_PULLUP | MUX_MODE0) /*
mmc0_clk.mmc0_clk */
AM33XX_IOPAD(0x9a0,
PIN_INPUT_PULLUP | MUX_MODE7) /*
mcasp0_aclkr.mmc0_sdwp */
>;
};
&mmc1
{
status = "okay";
/*vmmc-supply =
<&vmmc_reg>;*/
vmmc-supply = <&vcc3v3>;
bus-width = <4>;
pinctrl-names = "default";
pinctrl-0 = <&mmc1_pins>;
cd-gpios = <&gpio3 18
GPIO_ACTIVE_LOW>;
};
[
1.272256] omap_hsmmc 48060000.mmc: using lookup tables for GPIO lookup
[
1.272266] omap_hsmmc 48060000.mmc: lookup for GPIO wp failed
[
1.513463] mmc0: host does not support reading read-only switch, assuming
write-enable
[
1.532796] mmc0: new high speed SDHC card at address 0007
[
1.542753] mmcblk0: mmc0:0007 SD16G 14.5 GiB
[
1.554116] mmcblk0: p1
6
Follow-up
We can do some optimize: for example fs check
function
Manual fs check :
root@am335x-evm:~# fsck /dev/mmcblk0p1
fsck from util-linux 2.30
CP437: Invalid argument
fsck.fat 4.1 (2017-01-24)
0x41: Dirty bit is set. Fs was not properly
unmounted and some data may be corrupt.
1) Remove dirty bit
2) No action
? 1
Perform changes ? (y/n) y
/dev/mmcblk0p1: 10 files, 35768/1901241 clusters
Auto fs check:
root@am335x-evm:/etc# vi /etc/fstab
# stock fstab - you probably want to override this
with a machine specific one
/dev/root
/ auto defaults 1 1
proc
/proc proc defaults 0
0
devpts
/dev/pts devpts mode=0620,gid=5 0
0
usbdevfs
/proc/bus/usb usbdevfs noauto 0 0
tmpfs /run tmpfs mode=0755,nodev,nosuid,strictatime 0 0
tmpfs
/var/volatile tmpfs defaults,size=50M 0 0
tmpfs
/media/ram tmpfs defaults,size=16M 0 0
# uncomment this if your device has a
SD/MMC/Transflash slot
/dev/mmcblk0p1 /media/card auto defaults,sync,noauto 0 1
am335x system upgrade kernel tf(五)的更多相关文章
- am335x system upgrade kernel i2c rtc eeprom(六)
1 Scope of Document This document describes i2c bus hardware design and support i2c-devices: ee ...
- am335x system upgrade kernel ethernet(四)
1 Scope of Document This document describes ethernet hardware design and porting KZS8081 to ubo ...
- am335x system upgrade kernel gpio(九)
1 Hardware Overview gpio interface,pin map: AM335X_I2C0_W_C----------------------MCASP0_AXR1 /* ...
- am335x system upgrade kernel can(八)
1 Scope of Document This document describes can bus hardware design and can bus driver developm ...
- am335x system upgrade kernel uart(七)
1 Scope of Document This document describes UART hardware design, uart driver porting 2 Re ...
- am335x system upgrade kernel ec20 simcom7600ce(十一)
1 Scope of Document This document describes 4G hardware design, support quectel ec20 4G module/ ...
- am335x system upgrade kernel usb stroage(十)
1 Scope of Document This document describes USB hardware design, support stardard usb2.0 port o ...
- am335x system upgrade kernel f-ram fm25l16b(十六)
1 Scope of Document This document describes SPI F-RAM hardware design 2 Requiremen 2.1 ...
- am335x system upgrade kernel emmc(十八)
1 Scope of Document This document describes EMMC hardware design 2 Requiremen 2.1 Func ...
随机推荐
- golang 网络编程之如何正确关闭tcp连接以及管理它的生命周期
欢迎访问我的个人网站获取更佳阅读排版 golang 网络编程之如何正确关闭tcp连接以及管理它的生命周期 | yoko blog (https://pengrl.com/p/47401/) 本篇文章部 ...
- python递归函数和河内塔问题
关于递归函数: 函数内部调用自身的函数. 以n阶乘为例: f(n) = n ! = 1 x 2 x 3 x 4 x...x(n-1)x(n) = n x (n-1) ! def factorial(n ...
- jdbc 简单示例和优缺点
一个使用JDBC的例子: Class.forName("com.mysql.cj.jdbc.Driver"); //加载驱动 Connection connection = Dri ...
- [cf 1236 E] Alice and the Unfair Game
题意: 给定一个长度为m的序列$A$,你有一个长度为n的棋盘,可以任选一个位置x作为起点. 在时刻$[1,m+1]$你可以向左或向右移动一格. 设时刻i你移动后所在的位置为$B_i$,你需要满足对于任 ...
- Hive 系列(二)—— Linux 环境下 Hive 的安装部署
一.安装Hive 1.1 下载并解压 下载所需版本的 Hive,这里我下载版本为 cdh5.15.2.下载地址:http://archive.cloudera.com/cdh5/cdh/5/ # 下载 ...
- WinForm下开发插件DevExpress安装及使用
WinForm下开发插件DevExpress安装及使用在Visual Studio中安装DevExpress开发插件插件的使用方法简单的Demo介绍下载链接:https://pan.baidu.com ...
- angular js根据json文件动态生成路由状态
项目上有一个新需求,就是需要根据json文件动态生成路由状态,查阅了一下资料,现在总结一下发出来: 首先项目用到的是angular的UI-路由,所以必须引入angular.js和angular-ui- ...
- Node.js到底是什么
接触前端也有一段时间了,逐渐开始接触Node.js,刚刚接触Node.js的时候一直都以为Node.js就是JavaScript,当对Node.js有一定的了解之后,其实并不然两者之间有关系,其中的关 ...
- MySQL数据库之互联网常用分库分表方案
一.数据库瓶颈 不管是IO瓶颈,还是CPU瓶颈,最终都会导致数据库的活跃连接数增加,进而逼近甚至达到数据库可承载活跃连接数的阈值.在业务Service来看就是,可用数据库连接少甚至无连接可用.接下来就 ...
- 报错The "chunk" argument must be one of type string or Buffer. Received type object
报错内容: TypeError [ERR_INVALID_ARG_TYPE]: The "chunk" argument must be one of type string or ...