在上一篇之后,做了不少debug工作,终于把uboot给弄好了,现在可以对SD卡进行读写操作了,而且能够通过uboot来启动内核了。
1. 首先需要给设备树添加一些compatible信息,因为之前对设备树了解得并不多,所以没有感觉到compatible信息有多重要,后来看了一写blog后才知道,compatible属性中的字符和操作系统选择什么样的驱动来初始化设备有关,网上查到的信息如下:compatible属性,该属性的值是string list,定义了一系列的modle(每个string是一个model)。这些字符串列表被操作系统用来选择用哪一个driver来驱动该设备。假设定义该属性:compatible = “aaaaaa”, “bbbbb”。那么操作操作系统可能首先使用aaaaaa来匹配适合的driver,如果没有匹配到,那么使用字符串bbbbb来继续寻找适合的driver,最后代码修改如下:
--- a/arch/arm/dts/exynos4210-tiny4412.dts
+++ b/arch/arm/dts/exynos4210-tiny4412.dts
@@ -14,7 +14,7 @@
/ {
model = "Insignal Tiny4412 evaluation board based on Exynos4412";
- compatible = "insignal,tiny4412", "samsung,exynos4412";
+ compatible = "friendlyarm,tiny4412", "samsung,exynos4412", "samsung,exynos4";
chosen {
bootargs ="";
@@ -26,6 +26,7 @@
serial0 = "/serial@13800000";
console = "/serial@13800000";
mmc2 = "/sdhci@12530000";
+ mmc4 = "/dwmmc@12550000";
};
serial0:serial@13810000 {
@@ -33,20 +34,24 @@
};
sdhci@12510000 {
+ compatible = "samsung,exynos4412-sdhci";
status = "disabled";
};
sdhci@12520000 {
+ compatible = "samsung,exynos4412-sdhci";
status = "disabled";
};
sdhc