From 08d1991041febda3a2f07c260f839b71658a7eda Mon Sep 17 00:00:00 2001 From: Ajay Ramaswamy Date: Thu, 29 Aug 2013 07:07:58 +0530 Subject: [PATCH] fixes for jellybean after kernel 3.0 came out we need to change the kernel commandline, and for jellybean we need to pass 2 extra tags to the kernel commandline androidboot.hardware and androidboot.serialno to use this we will also have to change the cyanoboot_acclaim_defconfig to use CONFIG_CMDLINE_FORCE=n --- board/omap4430sdp/mmc.c | 26 +++++++++++++++++--------- common/Makefile | 2 +- include/configs/omap4430sdp.h | 5 +++-- 3 files changed, 21 insertions(+), 12 deletions(-) diff --git a/board/omap4430sdp/mmc.c b/board/omap4430sdp/mmc.c index 3699f78..3d504dd 100644 --- a/board/omap4430sdp/mmc.c +++ b/board/omap4430sdp/mmc.c @@ -670,6 +670,7 @@ int determine_boot_type(void) extern uint16_t check_charging(uint8_t* enabling); unsigned long bootcount = bootcount_load(); char s [5]; + char *buffer[256]; setenv("bootlimit", stringify(ACCLAIM_BOOTLIMIT)); setenv("altbootcmd", "mmcinit 1; booti mmc1 recovery"); @@ -694,6 +695,11 @@ int determine_boot_type(void) lcd_console_setcolor((batt_lvl < 30?(batt_lvl <= 10?CONSOLE_COLOR_RED:CONSOLE_COLOR_ORANGE):CONSOLE_COLOR_GREEN), CONSOLE_COLOR_BLACK); lcd_printf("batt level: %d\n charging %s", batt_lvl, (charging?"ENABLED":"DISABLED")); + if (load_serial_num() == 0) { + char *serialnum = getenv("serialnum"); + sprintf(buffer, "setenv hwbootargs androidboot.serialno=%s", serialnum); + run_command(buffer, 0); + } int action = get_boot_action(); @@ -704,37 +710,39 @@ int determine_boot_type(void) lcd_bl_set_brightness(100); //batt very low, let it charge switch(action) { case BOOT_SD_NORMAL: - setenv ("bootcmd", "setenv setbootargs setenv bootargs ${sdbootargs}; run setbootargs; mmcinit 0; fatload mmc 0:1 0x81000000 boot.img; booti 0x81000000"); + setenv ("bootcmd", "setenv setbootargs setenv bootargs ${sdbootargs} ${hwbootargs}; run setbootargs; mmcinit 0; fatload mmc 0:1 0x81000000 boot.img; booti 0x81000000"); setenv ("altbootcmd", "run bootcmd"); // for sd boot altbootcmd is the same as bootcmd display_feedback(BOOT_SD_NORMAL); return 0; - case BOOT_SD_RECOVERY: - setenv ("bootcmd", "setenv setbootargs setenv bootargs ${sdbootargs}; run setbootargs; mmcinit 0; fatload mmc 0:1 0x81000000 recovery.img; booti 0x81000000"); - setenv ("altbootcmd", "run bootcmd"); // for sd boot altbootcmd is the same as bootcmd + case BOOT_SD_RECOVERY: + setenv ("bootcmd", "setenv setbootargs setenv bootargs ${sdbootargs} ${hwbootargs}; run setbootargs; mmcinit 0; fatload mmc 0:1 0x81000000 recovery.img; booti 0x81000000"); + setenv ("altbootcmd", "run bootcmd"); // for sd boot altbootcmd is the same as bootcmd display_feedback(BOOT_SD_RECOVERY); - return 0; + return 0; case BOOT_SD_ALTBOOT: - setenv ("bootcmd", "setenv setbootargs setenv bootargs ${sdbootargs}; run setbootargs; mmcinit 0; fatload mmc 0:1 0x81000000 altboot.img; booti 0x81000000"); + setenv ("bootcmd", "setenv setbootargs setenv bootargs ${sdbootargs} ${hwbootargs}; run setbootargs; mmcinit 0; fatload mmc 0:1 0x81000000 altboot.img; booti 0x81000000"); setenv ("altbootcmd", "run bootcmd"); // for sd boot altbootcmd is the same as bootcmd display_feedback(BOOT_SD_ALTBOOT); return 0; //actually, boot from boot+512K -- thanks bauwks! case BOOT_EMMC_NORMAL: - setenv("bootcmd", "mmcinit 1; booti mmc1 boot 0x80000"); + setenv("setbootargs", "setenv bootargs ${bootargs} ${hwbootargs};"); + setenv("bootcmd", "run setbootargs; mmcinit 1; booti mmc1 boot 0x80000"); display_feedback(BOOT_EMMC_NORMAL); return 0; //actually, boot from recovery+512K -- thanks bauwks! case BOOT_EMMC_RECOVERY: - setenv("bootcmd", "mmcinit 1; booti mmc1 recovery 0x80000"); + setenv("setbootargs", "setenv bootargs ${bootargs} ${hwbootargs};"); + setenv("bootcmd", "run setbootargs; mmcinit 1; booti mmc1 recovery 0x80000"); display_feedback(BOOT_EMMC_RECOVERY); return 0; case BOOT_EMMC_ALTBOOT: // no 512K offset, this is just a file. - setenv ("bootcmd", "setenv setbootargs setenv bootargs ${emmcbootargs}; run setbootargs; mmcinit 1; fatload mmc 1:5 0x81000000 altboot.img; booti 0x81000000"); + setenv ("bootcmd", "setenv setbootargs setenv bootargs ${emmcbootargs} ${hwbootargs}; run setbootargs; mmcinit 1; fatload mmc 1:5 0x81000000 altboot.img; booti 0x81000000"); setenv ("altbootcmd", "run bootcmd"); // for emmc altboot altbootcmd is the same as bootcmd display_feedback(BOOT_EMMC_ALTBOOT); return 0; diff --git a/common/Makefile b/common/Makefile index 9879c68..af13aa3 100644 --- a/common/Makefile +++ b/common/Makefile @@ -83,6 +83,6 @@ sinclude .depend ifeq ($(BOARD),omap4430sdp) # Pull in the default kernel command line #include $(TOPDIR)/../../../device/ti/blaze/BoardConfig.mk -BOARD_KERNEL_CMDLINE := androidboot.console=ttyO0 console=ttyO0,115200n8 mem=448M@0x80000000 mem=512M@0xA0000000 init=/init rootwait vram=32M,82000000 omapfb.vram=0:5M@82000000 +BOARD_KERNEL_CMDLINE := console=/dev/null CFLAGS += -DBOARD_KERNEL_CMDLINE="$(BOARD_KERNEL_CMDLINE)" endif diff --git a/include/configs/omap4430sdp.h b/include/configs/omap4430sdp.h index f2eaec9..347d53c 100644 --- a/include/configs/omap4430sdp.h +++ b/include/configs/omap4430sdp.h @@ -162,8 +162,9 @@ #define CONFIG_BOOTARGS "" #define CONFIG_EXTRA_ENV_SETTINGS \ "commonbootargs=" stringify(BOARD_KERNEL_CMDLINE) "\0" \ - "sdbootargs=${commonbootargs} root=/dev/mmcblk1p2 rw" "\0" \ - "emmcbootargs=${commonbootargs} root=/dev/mmcblk1p2 rw" "\0" + "androidbootargs=androidboot.console=/dev/null androidboot.hardware=acclaim" "\0" \ + "sdbootargs=${commonbootargs} ${androidbootargs} root=/dev/mmcblk1p2 rw" "\0" \ + "emmcbootargs=${commonbootargs} ${androidbootargs} root=/dev/mmcblk1p2 rw" "\0" #define CONFIG_BOOTCOMMAND "booti mmc1"