summaryrefslogtreecommitdiffstats
path: root/arch/arm/boards/solidrun-microsom/board.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/boards/solidrun-microsom/board.c')
-rw-r--r--arch/arm/boards/solidrun-microsom/board.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/arch/arm/boards/solidrun-microsom/board.c b/arch/arm/boards/solidrun-microsom/board.c
index b9041687e4..155199ff78 100644
--- a/arch/arm/boards/solidrun-microsom/board.c
+++ b/arch/arm/boards/solidrun-microsom/board.c
@@ -78,7 +78,9 @@ static void microsom_eth_init(void)
static int hummingboard_device_init(void)
{
if (!of_machine_is_compatible("solidrun,hummingboard/dl") &&
- !of_machine_is_compatible("solidrun,hummingboard/q"))
+ !of_machine_is_compatible("solidrun,hummingboard/q") &&
+ !of_machine_is_compatible("solidrun,hummingboard2/dl") &&
+ !of_machine_is_compatible("solidrun,hummingboard2/q"))
return 0;
microsom_eth_init();
@@ -108,13 +110,26 @@ device_initcall(h100_device_init);
static int hummingboard_late_init(void)
{
+ bool emmc_present = false;
+
if (!of_machine_is_compatible("solidrun,hummingboard/dl") &&
!of_machine_is_compatible("solidrun,hummingboard/q") &&
+ !of_machine_is_compatible("solidrun,hummingboard2/dl") &&
+ !of_machine_is_compatible("solidrun,hummingboard2/q") &&
!of_machine_is_compatible("auvidea,h100"))
return 0;
+ if (of_machine_is_compatible("solidrun,hummingboard2/dl") ||
+ of_machine_is_compatible("solidrun,hummingboard2/q"))
+ emmc_present = true;
+
imx6_bbu_internal_mmc_register_handler("sdcard", "/dev/mmc1.barebox",
- BBU_HANDLER_FLAG_DEFAULT);
+ emmc_present ? 0 : BBU_HANDLER_FLAG_DEFAULT);
+
+ if (emmc_present) {
+ imx6_bbu_internal_mmc_register_handler("emmc",
+ "/dev/mmc2.barebox", BBU_HANDLER_FLAG_DEFAULT);
+ }
return 0;
}