summaryrefslogtreecommitdiff
path: root/common/image-android.c
diff options
context:
space:
mode:
authorzhang sanshan <b51434@freescale.com>2015-09-22 22:11:03 +0800
committerzhang sanshan <b51434@freescale.com>2015-11-06 18:17:39 +0800
commit24356fe059abbc9eae1b192f7af8a46f204a36f4 (patch)
tree5b89c23725af0953f187b20aefb6d2153ed243f2 /common/image-android.c
parentf78cbee0375dcb81b10bac2e0dcd254d0551baa9 (diff)
downloadu-boot-imx-24356fe059abbc9eae1b192f7af8a46f204a36f4.zip
u-boot-imx-24356fe059abbc9eae1b192f7af8a46f204a36f4.tar.gz
u-boot-imx-24356fe059abbc9eae1b192f7af8a46f204a36f4.tar.bz2
MA-7053 when I add selinux=disable in the cmdline, the board do OTA update will fail
The ota update script will set selinux label with set_metadata when do nand ota update. The root cause is set_metadata will fail if disable selinux in recovery mode. This patch is a workaround which will enable selinux in recovery mode, even if have disable selinux in commandline. Signed-off-by: zhang sanshan <b51434@freescale.com>
Diffstat (limited to 'common/image-android.c')
-rw-r--r--common/image-android.c34
1 files changed, 31 insertions, 3 deletions
diff --git a/common/image-android.c b/common/image-android.c
index d56380d..78a1f32 100644
--- a/common/image-android.c
+++ b/common/image-android.c
@@ -78,9 +78,14 @@ int android_image_get_kernel(const struct andr_img_hdr *hdr, int verify,
serialnr.high,
serialnr.low);
#endif
-
- setenv("bootargs", commandline);
-
+ if (getenv("bootcmd_android_recovery")) {
+ char new_commandline[ANDR_BOOT_ARGS_SIZE];
+ char cmd_selinux[30] = "androidboot.selinux=disabled";
+ del_sub_str(commandline, cmd_selinux, new_commandline);
+ setenv("bootargs", new_commandline);
+ } else {
+ setenv("bootargs", commandline);
+ }
if (os_data) {
*os_data = (ulong)hdr;
*os_data += hdr->page_size;
@@ -151,3 +156,26 @@ int android_image_get_fdt(const struct andr_img_hdr *hdr,
return 0;
}
+void del_sub_str(const char *str, const char *sub_str, char *cmdline)
+{
+ int str_len = strlen(str);
+ int sub_str_len = strlen(sub_str);
+
+ while (*str != '\0') {
+ while (*str != *sub_str && *str != '\0') {
+ *cmdline = *str;
+ str++;
+ cmdline++;
+ }
+ if (strncmp(str, sub_str, sub_str_len) != 0) {
+ *cmdline = *str;
+ str++;
+ cmdline++;
+ continue;
+ } else {
+ str += sub_str_len;
+ }
+
+ }
+ *cmdline = '\0';
+}