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(五)的更多相关文章

  1. am335x system upgrade kernel i2c rtc eeprom(六)

    1      Scope of Document This document describes i2c bus hardware design and support i2c-devices: ee ...

  2. am335x system upgrade kernel ethernet(四)

    1      Scope of Document This document describes ethernet hardware design and porting KZS8081 to ubo ...

  3. am335x system upgrade kernel gpio(九)

    1      Hardware Overview gpio interface,pin map: AM335X_I2C0_W_C----------------------MCASP0_AXR1 /* ...

  4. am335x system upgrade kernel can(八)

    1      Scope of Document This document describes can bus hardware design and can bus driver developm ...

  5. am335x system upgrade kernel uart(七)

    1      Scope of Document This document describes UART hardware design, uart driver porting 2      Re ...

  6. am335x system upgrade kernel ec20 simcom7600ce(十一)

    1      Scope of Document This document describes 4G hardware design, support quectel ec20 4G module/ ...

  7. am335x system upgrade kernel usb stroage(十)

    1      Scope of Document This document describes USB hardware design, support stardard usb2.0 port o ...

  8. am335x system upgrade kernel f-ram fm25l16b(十六)

    1      Scope of Document This document describes SPI F-RAM hardware design 2      Requiremen 2.1     ...

  9. am335x system upgrade kernel emmc(十八)

    1      Scope of Document This document describes EMMC hardware design 2      Requiremen 2.1     Func ...

随机推荐

  1. Oracle的字串處理

    Oracle的字串處理 除了寫程式之外,資料庫的應用也是蠻重要的,而SQL語法,用法大致相同,但各公司所出的資料庫還是有所差別,而ORACLE SQL給了相當多的函數應用,下面列了一些函法的名稱和用法 ...

  2. js 数组传统方法

    js 数组传统方法 push() 功能:向数组的末尾添加一个或多个元素 var arr = [4]; arr.push(1,2,3); // [4,1,2,3] 返回: 会返回新数组的长度length ...

  3. vue 路由跳转带参 方式query ,params

    a.vue向b.vue传值 a.vue this.$router.push({ path: '/payType', query: { putUpList: this.putUpList, name:' ...

  4. [Atcoder AGC030C]Coloring Torus

    题目大意:有$k$种颜色,要求构造出一个$n\times n$的矩阵,填入这$k$种颜色,满足对于每一种颜色,其中填充这种颜色的每一个方格,满足其相连的四个格子的颜色的个数和种类相同(对于每一种颜色而 ...

  5. AutoFac的简单使用教程

    Autofac可以对代码进行依赖注入,实现控制反转.以下是本菜鸟在初次入门时的代码配置,其源码,内部原理都还有待日后研究.目前也只是仅仅做到了能够使项目正常使用而已. 跟我一样刚刚入门的菜鸟朋友们可以 ...

  6. 使用 Create-React-App 开发 Chrome 扩展

    整理 Kindle 标注.书签和笔记从未如此简单! Kindle 标注管理应用 Kindle Mate 只支持 Windows,不支持 Mac.标注只是解析我的剪贴文本文件,配合 FileReader ...

  7. JAVA基础之设置随机成语验证码

    package com.oracle; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import ja ...

  8. .gitignore详解(附上eclipse的java项目的 .gitignore文件)

    今天讲讲Git中非常重要的一个文件――.gitignore. 首先要强调一点,这个文件的完整文件名就是“.gitignore”,注意最前面有个“.”.这样没有扩展名的文件在Windows下不太好创建, ...

  9. gitlab中clone项目时,IP地址是一串数字

    问题:docker安装后,clone显示ip是一串地址 解决(如果是非docker启动的,自然就是进入gitlab下): 1.进入docker 后台: docker exec -it gitlab / ...

  10. python(练习题)

    1.请写出冒泡排序将list1进行排序? List1 = [1,2,34,12,33,25,12,33,90,28] 2.使用python语言打印出name=”I love python”的长度 3. ...