2016-10-30 09:03:05 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2016, The CyanogenMod Project
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are
|
|
|
|
met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above
|
|
|
|
copyright notice, this list of conditions and the following
|
|
|
|
disclaimer in the documentation and/or other materials provided
|
|
|
|
with the distribution.
|
|
|
|
* Neither the name of The Linux Foundation nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
|
|
|
|
WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
|
|
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
|
|
|
|
BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
|
|
|
|
BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
|
|
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
|
|
|
|
OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
|
|
|
|
IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "vendor_init.h"
|
|
|
|
#include "property_service.h"
|
|
|
|
#include "log.h"
|
|
|
|
#include "util.h"
|
|
|
|
|
2016-11-07 00:01:35 +00:00
|
|
|
static char board_id[PROP_VALUE_MAX];
|
|
|
|
|
2016-10-30 09:03:05 +00:00
|
|
|
static int read_file2(const char *fname, char *data, int max_size)
|
|
|
|
{
|
|
|
|
int fd, rc;
|
|
|
|
|
|
|
|
if (max_size < 1)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
fd = open(fname, O_RDONLY);
|
|
|
|
if (fd < 0) {
|
|
|
|
ERROR("failed to open '%s'\n", fname);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
rc = read(fd, data, max_size - 1);
|
|
|
|
if ((rc > 0) && (rc < max_size))
|
|
|
|
data[rc] = '\0';
|
|
|
|
else
|
|
|
|
data[0] = '\0';
|
|
|
|
close(fd);
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2016-11-07 00:01:35 +00:00
|
|
|
static void import_cmdline(char *name, int for_emulator)
|
|
|
|
{
|
|
|
|
char *value = strchr(name, '=');
|
|
|
|
int name_len = strlen(name);
|
|
|
|
const char s[2] = ":";
|
|
|
|
|
|
|
|
if (value == 0) return;
|
|
|
|
*value++ = 0;
|
|
|
|
if (name_len == 0) return;
|
|
|
|
|
|
|
|
if (!strcmp(name, "board_id")) {
|
|
|
|
value = strtok(value, s);
|
|
|
|
strlcpy(board_id, value, sizeof(board_id));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-30 09:03:05 +00:00
|
|
|
static void init_alarm_boot_properties()
|
|
|
|
{
|
|
|
|
char const *alarm_file = "/proc/sys/kernel/boot_reason";
|
|
|
|
char buf[64];
|
2016-11-06 13:25:09 +00:00
|
|
|
char tmp[PROP_VALUE_MAX];
|
|
|
|
|
|
|
|
property_get("ro.boot.alarmboot", tmp);
|
2016-10-30 09:03:05 +00:00
|
|
|
|
|
|
|
if (read_file2(alarm_file, buf, sizeof(buf))) {
|
|
|
|
/*
|
|
|
|
* Setup ro.alarm_boot value to true when it is RTC triggered boot up
|
|
|
|
* For existing PMIC chips, the following mapping applies
|
|
|
|
* for the value of boot_reason:
|
|
|
|
*
|
|
|
|
* 0 -> unknown
|
|
|
|
* 1 -> hard reset
|
|
|
|
* 2 -> sudden momentary power loss (SMPL)
|
|
|
|
* 3 -> real time clock (RTC)
|
|
|
|
* 4 -> DC charger inserted
|
|
|
|
* 5 -> USB charger insertd
|
|
|
|
* 6 -> PON1 pin toggled (for secondary PMICs)
|
|
|
|
* 7 -> CBLPWR_N pin toggled (for external power supply)
|
|
|
|
* 8 -> KPDPWR_N pin toggled (power key pressed)
|
|
|
|
*/
|
2016-11-06 13:25:09 +00:00
|
|
|
if (buf[0] == '3' || !strcmp(tmp,"true"))
|
2016-10-30 09:03:05 +00:00
|
|
|
property_set("ro.alarm_boot", "true");
|
|
|
|
else
|
|
|
|
property_set("ro.alarm_boot", "false");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void vendor_load_properties()
|
|
|
|
{
|
2016-11-07 00:01:35 +00:00
|
|
|
import_kernel_cmdline(0, import_cmdline);
|
|
|
|
|
|
|
|
property_set("ro.product.wt.boardid", board_id);
|
|
|
|
ERROR("Detected board ID=%s\n", board_id);
|
|
|
|
|
|
|
|
if (!strcmp(board_id, "S88537AA1")) {
|
|
|
|
property_set("ro.build.display.wtid", "SW_S88537AA1_V053_M20_MP_XM");
|
|
|
|
} else if (!strcmp(board_id, "S88537AB1")) {
|
|
|
|
property_set("ro.build.display.wtid", "SW_S88537AB1_V053_M20_MP_XM");
|
|
|
|
} else if (!strcmp(board_id, "S88537AC1")) {
|
|
|
|
property_set("ro.build.display.wtid", "SW_S88537AC1_V053_M20_MP_XM");
|
|
|
|
} else if (!strcmp(board_id, "S88537BA1")) {
|
|
|
|
property_set("ro.build.display.wtid", "SW_S88537BA1_V053_M20_MP_XM");
|
|
|
|
} else if (!strcmp(board_id, "S88537CA1")) {
|
|
|
|
property_set("ro.build.display.wtid", "SW_S88537CA1_V053_M20_MP_XM");
|
|
|
|
} else if (!strcmp(board_id, "S88537EC1")) {
|
|
|
|
property_set("ro.build.display.wtid", "SW_S88537EC1_V053_M20_MP_XM");
|
|
|
|
}
|
|
|
|
|
2016-10-30 09:03:05 +00:00
|
|
|
init_alarm_boot_properties();
|
|
|
|
}
|