作過android平臺的同仁大多都知道android原生態只支持了一個sd卡,默認的掛載點也就是/mnt/sdcard,因此在應用中使用getExternalStorageDirectory()獲得的都是/mnt/sdcard,一般會symlink 到/sdcard目錄。作過全志平臺的童鞋也知道全志android SDK支持2個sd卡,一般是一個內置的,一個外置的,內置的通常是從nand上或者emmc上的用戶數據區,由於如今的nand、emmc容量都比較大,存放android程序、cache、backup、download等以外,還有大量的空間剩餘,所以這部分大多都會作成一個sd卡來使用,一般掛載到/mnt/sdcard上;外置的是掛載在/mnt/extsd節點上。可是,如何在全志平臺上使用三個sd卡呢?即再增長一個外置的SD卡支持。html
爲了多支持一個SD卡,咱們有如下基本須要作:node
一、 在系統配置文件裏,打開對應的SD卡驅動支持,設置好檢測方式,若是是gpio方式的要配置好gpio引腳;筆者測試過,若是兩個外置的SD卡,都使用gpio polling的方式,系統只識別一個SD卡,筆者把兩個SD卡一個配置成gpio polling,另一個配置成了GPIO IRQ中斷模式;react
- [mmc0_para]
- sdc_used = 1
- sdc_detmode = 2
- sdc_buswidth = 4
- sdc_clk = port:PF02<2><1><2><default>
- sdc_cmd = port:PF03<2><1><2><default>
- sdc_d0 = port:PF01<2><1><2><default>
- sdc_d1 = port:PF00<2><1><2><default>
- sdc_d2 = port:PF05<2><1><2><default>
- sdc_d3 = port:PF04<2><1><2><default>
- sdc_det = port:PH3<6><1><default><default>
- sdc_use_wp = 0
- sdc_wp =
- sdc_isio = 0
- sdc_regulator = "none"
-
- [mmc1_para]
- sdc_used = 1
- sdc_detmode = 1
- sdc_buswidth = 4
- sdc_clk = port:PH23<5><1><2><default>
- sdc_cmd = port:PH22<5><1><2><default>
- sdc_d0 = port:PH24<5><1><2><default>
- sdc_d1 = port:PH25<5><1><2><default>
- sdc_d2 = port:PH26<5><1><2><default>
- sdc_d3 = port:PH27<5><1><2><default>
- sdc_det = port:PH2<0><1><default><default>
- sdc_use_wp = 0
- sdc_wp =
- sdc_isio = 0
- sdc_regulator = "none"
- [mmc0_para]
- sdc_used = 1
- sdc_detmode = 2
- sdc_buswidth = 4
- sdc_clk = port:PF02<2><1><2><default>
- sdc_cmd = port:PF03<2><1><2><default>
- sdc_d0 = port:PF01<2><1><2><default>
- sdc_d1 = port:PF00<2><1><2><default>
- sdc_d2 = port:PF05<2><1><2><default>
- sdc_d3 = port:PF04<2><1><2><default>
- sdc_det = port:PH3<6><1><default><default>
- sdc_use_wp = 0
- sdc_wp =
- sdc_isio = 0
- sdc_regulator = "none"
-
- [mmc1_para]
- sdc_used = 1
- sdc_detmode = 1
- sdc_buswidth = 4
- sdc_clk = port:PH23<5><1><2><default>
- sdc_cmd = port:PH22<5><1><2><default>
- sdc_d0 = port:PH24<5><1><2><default>
- sdc_d1 = port:PH25<5><1><2><default>
- sdc_d2 = port:PH26<5><1><2><default>
- sdc_d3 = port:PH27<5><1><2><default>
- sdc_det = port:PH2<0><1><default><default>
- sdc_use_wp = 0
- sdc_wp =
- sdc_isio = 0
- sdc_regulator = "none"
[mmc0_para]
sdc_used = 1
sdc_detmode = 2
sdc_buswidth = 4
sdc_clk = port:PF02<2><1><2><default>
sdc_cmd = port:PF03<2><1><2><default>
sdc_d0 = port:PF01<2><1><2><default>
sdc_d1 = port:PF00<2><1><2><default>
sdc_d2 = port:PF05<2><1><2><default>
sdc_d3 = port:PF04<2><1><2><default>
sdc_det = port:PH3<6><1><default><default>
sdc_use_wp = 0
sdc_wp =
sdc_isio = 0
sdc_regulator = "none"
[mmc1_para]
sdc_used = 1
sdc_detmode = 1
sdc_buswidth = 4
sdc_clk = port:PH23<5><1><2><default>
sdc_cmd = port:PH22<5><1><2><default>
sdc_d0 = port:PH24<5><1><2><default>
sdc_d1 = port:PH25<5><1><2><default>
sdc_d2 = port:PH26<5><1><2><default>
sdc_d3 = port:PH27<5><1><2><default>
sdc_det = port:PH2<0><1><default><default>
sdc_use_wp = 0
sdc_wp =
sdc_isio = 0
sdc_regulator = "none"
二、 在vold.fstab裏,須要修改一下,以下:android
- ## Vold 2.0 fstab for HTC Passion
- #
- ## - San Mehat (san@android.com)
- ##
- #######################
- ## Regular device mount
- ##
- ## Format: dev_mount <label> <mount_point> <part> <sysfs_path1...>
- ## label - Label for the volume
- ## mount_point - Where the volume will be mounted
- ## part - Partition # (1 based), or 'auto' for first usable partition.
- ## <sysfs_path> - List of sysfs paths to source devices
- ######################
-
- # Mounts the first usable partition of the specified device
- #/devices/platform/awsmc.3/mmc_host for sdio
- dev_mount sdcard /mnt/sdcard auto /devices/virtual/block/nandk /devices/platform/sunxi-mmc.2/mmc_host
- dev_mount extsd /mnt/extsd auto /devices/platform/sunxi-mmc.1/mmc_host
- dev_mount extsd2 /mnt/extsd2 auto /devices/platform/sunxi-mmc.0/mmc_host
- dev_mount usbhost1 /mnt/usbhost1 auto /devices/platform/sw-ehci.1 /devices/platform/sw_hcd_host0 /devices/platform/sw-ohci.1
- ## Vold 2.0 fstab for HTC Passion
- #
- ## - San Mehat (san@android.com)
- ##
- #######################
- ## Regular device mount
- ##
- ## Format: dev_mount <label> <mount_point> <part> <sysfs_path1...>
- ## label - Label for the volume
- ## mount_point - Where the volume will be mounted
- ## part - Partition # (1 based), or 'auto' for first usable partition.
- ## <sysfs_path> - List of sysfs paths to source devices
- ######################
-
- # Mounts the first usable partition of the specified device
- #/devices/platform/awsmc.3/mmc_host for sdio
- dev_mount sdcard /mnt/sdcard auto /devices/virtual/block/nandk /devices/platform/sunxi-mmc.2/mmc_host
- dev_mount extsd /mnt/extsd auto /devices/platform/sunxi-mmc.1/mmc_host
- dev_mount extsd2 /mnt/extsd2 auto /devices/platform/sunxi-mmc.0/mmc_host
- dev_mount usbhost1 /mnt/usbhost1 auto /devices/platform/sw-ehci.1 /devices/platform/sw_hcd_host0 /devices/platform/sw-ohci.1
## Vold 2.0 fstab for HTC Passion
#
## - San Mehat (san@android.com)
##
#######################
## Regular device mount
##
## Format: dev_mount <label> <mount_point> <part> <sysfs_path1...>
## label - Label for the volume
## mount_point - Where the volume will be mounted
## part - Partition # (1 based), or 'auto' for first usable partition.
## <sysfs_path> - List of sysfs paths to source devices
######################
# Mounts the first usable partition of the specified device
#/devices/platform/awsmc.3/mmc_host for sdio
dev_mount sdcard /mnt/sdcard auto /devices/virtual/block/nandk /devices/platform/sunxi-mmc.2/mmc_host
dev_mount extsd /mnt/extsd auto /devices/platform/sunxi-mmc.1/mmc_host
dev_mount extsd2 /mnt/extsd2 auto /devices/platform/sunxi-mmc.0/mmc_host
dev_mount usbhost1 /mnt/usbhost1 auto /devices/platform/sw-ehci.1 /devices/platform/sw_hcd_host0 /devices/platform/sw-ohci.1
這三個SD卡掛載點都是能夠隨便交換的;git
三、 若是完成了上面兩步,extsd2對應的SD卡熱插拔是能夠自動掛載,若是是開機啓動前就在sd卡槽裏面的話,就不會自動識別,所以咱們得明確告訴系統storage配置,配置在storage_list.xml文件中,以下:測試
- <storage android:mountPoint="/mnt/extsd"
-
- android:storageDescription="extsd"
-
- android:primary="false"
-
- android:removable="true"
-
- android:emulated="false"
-
- android:mtpReserve="0"
-
- android:allowMassStorage="true"
-
- android:maxFileSize="0"/>
-
- <storage android:mountPoint="/mnt/extsd"
-
- android:storageDescription="extsd"
-
- android:primary="false"
-
- android:removable="true"
-
- android:emulated="false"
-
- android:mtpReserve="0"
-
- android:allowMassStorage="true"
-
- android:maxFileSize="0"/>
-
<storage android:mountPoint="/mnt/extsd"
android:storageDescription="extsd"
android:primary="false"
android:removable="true"
android:emulated="false"
android:mtpReserve="0"
android:allowMassStorage="true"
android:maxFileSize="0"/>
四、 在system/vold下面作一些處理,相似extsd處理,加上便可,以下:ui
- diff --git a/DirectVolume.cpp b/DirectVolume.cpp
- index 16ac2d8..43ce612 100755
- --- a/DirectVolume.cpp
- +++ b/DirectVolume.cpp
- @@ -346,7 +346,7 @@ void DirectVolume::handlePartitionRemoved(const char *devpath, NetlinkEvent *evt
- * Yikes, our mounted partition is going away!
- */
-
- - if(!strstr(getLabel(),"usb")&&!strstr(getLabel(),"extsd")){
- + if(!strstr(getLabel(),"usb")&&!strstr(getLabel(),"extsd")&&!strstr(getLabel(),"extsd2")){
- snprintf(msg, sizeof(msg), "Volume %s %s bad removal (%d:%d)",
- getLabel(), getMountpoint(), major, minor);
- mVm->getBroadcaster()->sendBroadcast(ResponseCode::VolumeBadRemoval,
- diff --git a/Volume.cpp b/Volume.cpp
- old mode 100644
- new mode 100755
- index 23556ea..a1f059a
- --- a/Volume.cpp
- +++ b/Volume.cpp
- @@ -864,7 +864,7 @@ int Volume::unmountVol(bool force, bool revert) {
- setState(Volume::State_Unmounting);
- usleep(1000 * 1000); // Give the framework some time to react
-
- - if(getMountpoint()!=NULL&&!strstr(getMountpoint(),"usb")&&!strstr(getMountpoint(),"extsd")){
- + if(getMountpoint()!=NULL&&!strstr(getMountpoint(),"usb")&&!strstr(getMountpoint(),"extsd")&&!strstr(getMountpoint(),"extsd2")){
- /*
- * Remove the bindmount we were using to keep a reference to
- * the previously obscured directory.
- diff --git a/DirectVolume.cpp b/DirectVolume.cpp
- index 16ac2d8..43ce612 100755
- --- a/DirectVolume.cpp
- +++ b/DirectVolume.cpp
- @@ -346,7 +346,7 @@ void DirectVolume::handlePartitionRemoved(const char *devpath, NetlinkEvent *evt
- * Yikes, our mounted partition is going away!
- */
-
- - if(!strstr(getLabel(),"usb")&&!strstr(getLabel(),"extsd")){
- + if(!strstr(getLabel(),"usb")&&!strstr(getLabel(),"extsd")&&!strstr(getLabel(),"extsd2")){
- snprintf(msg, sizeof(msg), "Volume %s %s bad removal (%d:%d)",
- getLabel(), getMountpoint(), major, minor);
- mVm->getBroadcaster()->sendBroadcast(ResponseCode::VolumeBadRemoval,
- diff --git a/Volume.cpp b/Volume.cpp
- old mode 100644
- new mode 100755
- index 23556ea..a1f059a
- --- a/Volume.cpp
- +++ b/Volume.cpp
- @@ -864,7 +864,7 @@ int Volume::unmountVol(bool force, bool revert) {
- setState(Volume::State_Unmounting);
- usleep(1000 * 1000); // Give the framework some time to react
-
- - if(getMountpoint()!=NULL&&!strstr(getMountpoint(),"usb")&&!strstr(getMountpoint(),"extsd")){
- + if(getMountpoint()!=NULL&&!strstr(getMountpoint(),"usb")&&!strstr(getMountpoint(),"extsd")&&!strstr(getMountpoint(),"extsd2")){
- /*
- * Remove the bindmount we were using to keep a reference to
- * the previously obscured directory.
diff --git a/DirectVolume.cpp b/DirectVolume.cpp
index 16ac2d8..43ce612 100755
--- a/DirectVolume.cpp
+++ b/DirectVolume.cpp
@@ -346,7 +346,7 @@ void DirectVolume::handlePartitionRemoved(const char *devpath, NetlinkEvent *evt
* Yikes, our mounted partition is going away!
*/
- if(!strstr(getLabel(),"usb")&&!strstr(getLabel(),"extsd")){
+ if(!strstr(getLabel(),"usb")&&!strstr(getLabel(),"extsd")&&!strstr(getLabel(),"extsd2")){
snprintf(msg, sizeof(msg), "Volume %s %s bad removal (%d:%d)",
getLabel(), getMountpoint(), major, minor);
mVm->getBroadcaster()->sendBroadcast(ResponseCode::VolumeBadRemoval,
diff --git a/Volume.cpp b/Volume.cpp
old mode 100644
new mode 100755
index 23556ea..a1f059a
--- a/Volume.cpp
+++ b/Volume.cpp
@@ -864,7 +864,7 @@ int Volume::unmountVol(bool force, bool revert) {
setState(Volume::State_Unmounting);
usleep(1000 * 1000); // Give the framework some time to react
- if(getMountpoint()!=NULL&&!strstr(getMountpoint(),"usb")&&!strstr(getMountpoint(),"extsd")){
+ if(getMountpoint()!=NULL&&!strstr(getMountpoint(),"usb")&&!strstr(getMountpoint(),"extsd")&&!strstr(getMountpoint(),"extsd2")){
/*
* Remove the bindmount we were using to keep a reference to
* the previously obscured directory.
完成了以上幾步,三個SD卡已經能夠自動識別掛載了,mount的信息以下:spa
- root@android:/ # mount
-
- rootfs / rootfs rw 0 0
- tmpfs /dev tmpfs rw,nosuid,relatime,mode=755 0 0
- devpts /dev/pts devpts rw,relatime,mode=600 0 0
- proc /proc proc rw,relatime 0 0
- sysfs /sys sysfs rw,relatime 0 0
- debugfs /sys/kernel/debug debugfs rw,relatime 0 0
- none /acct cgroup rw,relatime,cpuacct 0 0
- tmpfs /mnt/secure tmpfs rw,relatime,mode=700 0 0
- tmpfs /mnt/asec tmpfs rw,relatime,mode=755,gid=1000 0 0
- tmpfs /mnt/obb tmpfs rw,relatime,mode=755,gid=1000 0 0
- none /dev/cpuctl cgroup rw,relatime,cpu 0 0
- /dev/block/nandd /system ext4 rw,nodev,noatime,nobarrier,data=ordered 0 0
- /dev/block/nande /data ext4 rw,nosuid,nodev,noatime,journal_checksum,nobarrier,noauto_da_alloc,data=ordered 0 0
- /dev/block/nandh /cache ext4 rw,nosuid,nodev,noatime,journal_checksum,nobarrier,noauto_da_alloc,data=ordered 0 0
- /dev/block/vold/179:16 /mnt/extsd vfat rw,dirsync,nosuid,nodev,noexec,relatime,uid=1000,gid=1023,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=ascii,shortname=mixed,utf8,errors=remount-ro 0 0
- /dev/block/vold/179:0 /mnt/extsd2 vfat rw,dirsync,nosuid,nodev,noexec,relatime,uid=1000,gid=1023,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=ascii,shortname=mixed,utf8,errors=remount-ro 0 0
- /dev/block/vold/93:80 /mnt/sdcard vfat rw,dirsync,nosuid,nodev,noexec,relatime,uid=1000,gid=1015,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=ascii,shortname=mixed,utf8,errors=remount-ro 0 0
- /dev/block/vold/93:80 /mnt/secure/asec vfat rw,dirsync,nosuid,nodev,noexec,relatime,uid=1000,gid=1015,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=ascii,shortname=mixed,utf8,errors=remount-ro 0 0
- tmpfs /mnt/sdcard/.android_secure tmpfs ro,relatime,size=0k,mode=000 0 0
- root@android:/ #