Merge "Fixed loc_get_target() and removed 1530 support"
This commit is contained in:
commit
1e6d1c02ce
3 changed files with 20 additions and 98 deletions
|
@ -109,7 +109,6 @@ static const loc_name_val_s_type target_name[] =
|
||||||
NAME_VAL(GNSS_MSM),
|
NAME_VAL(GNSS_MSM),
|
||||||
NAME_VAL(GNSS_GSS),
|
NAME_VAL(GNSS_GSS),
|
||||||
NAME_VAL(GNSS_MDM),
|
NAME_VAL(GNSS_MDM),
|
||||||
NAME_VAL(GNSS_QCA1530),
|
|
||||||
NAME_VAL(GNSS_AUTO),
|
NAME_VAL(GNSS_AUTO),
|
||||||
NAME_VAL(GNSS_UNKNOWN)
|
NAME_VAL(GNSS_UNKNOWN)
|
||||||
};
|
};
|
||||||
|
|
|
@ -61,12 +61,6 @@
|
||||||
#define LENGTH(s) (sizeof(s) - 1)
|
#define LENGTH(s) (sizeof(s) - 1)
|
||||||
#define GPS_CHECK_NO_ERROR 0
|
#define GPS_CHECK_NO_ERROR 0
|
||||||
#define GPS_CHECK_NO_GPS_HW 1
|
#define GPS_CHECK_NO_GPS_HW 1
|
||||||
/* When system server is started, it uses 20 seconds as ActivityManager
|
|
||||||
* timeout. After that it sends SIGSTOP signal to process.
|
|
||||||
*/
|
|
||||||
#define QCA1530_DETECT_TIMEOUT 15
|
|
||||||
#define QCA1530_DETECT_PRESENT "yes"
|
|
||||||
#define QCA1530_DETECT_PROGRESS "detect"
|
|
||||||
|
|
||||||
static unsigned int gTarget = (unsigned int)-1;
|
static unsigned int gTarget = (unsigned int)-1;
|
||||||
|
|
||||||
|
@ -92,63 +86,6 @@ static int read_a_line(const char * file_path, char * line, int line_size)
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
* \brief Checks if QCA1530 is avalable.
|
|
||||||
*
|
|
||||||
* Function verifies if qca1530 SoC is configured on the device. The test is
|
|
||||||
* based on property value. For 1530 scenario, the value shall be one of the
|
|
||||||
* following: "yes", "no", "detect". All other values are treated equally to
|
|
||||||
* "no". When the value is "detect" the system waits for SoC detection to
|
|
||||||
* finish before returning result.
|
|
||||||
*
|
|
||||||
* \retval true - QCA1530 is available.
|
|
||||||
* \retval false - QCA1530 is not available.
|
|
||||||
*/
|
|
||||||
static bool is_qca1530(void)
|
|
||||||
{
|
|
||||||
static const char qca1530_property_name[] = "sys.qca1530";
|
|
||||||
bool res = false;
|
|
||||||
int ret, i;
|
|
||||||
char buf[PROPERTY_VALUE_MAX];
|
|
||||||
|
|
||||||
memset(buf, 0, sizeof(buf));
|
|
||||||
|
|
||||||
for (i = 0; i < QCA1530_DETECT_TIMEOUT; ++i)
|
|
||||||
{
|
|
||||||
ret = platform_lib_abstraction_property_get(qca1530_property_name, buf, NULL);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
LOC_LOGV( "qca1530: property %s is not accessible, ret=%d",
|
|
||||||
qca1530_property_name,
|
|
||||||
ret);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
LOC_LOGV( "qca1530: property %s is set to %s",
|
|
||||||
qca1530_property_name,
|
|
||||||
buf);
|
|
||||||
|
|
||||||
if (!memcmp(buf, QCA1530_DETECT_PRESENT,
|
|
||||||
sizeof(QCA1530_DETECT_PRESENT)))
|
|
||||||
{
|
|
||||||
res = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (!memcmp(buf, QCA1530_DETECT_PROGRESS,
|
|
||||||
sizeof(QCA1530_DETECT_PROGRESS)))
|
|
||||||
{
|
|
||||||
LOC_LOGV("qca1530: SoC detection is in progress.");
|
|
||||||
sleep(1);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
LOC_LOGD("qca1530: detected=%s", res ? "true" : "false");
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*The character array passed to this function should have length
|
/*The character array passed to this function should have length
|
||||||
of atleast PROPERTY_VALUE_MAX*/
|
of atleast PROPERTY_VALUE_MAX*/
|
||||||
void loc_get_target_baseband(char *baseband, int array_length)
|
void loc_get_target_baseband(char *baseband, int array_length)
|
||||||
|
@ -209,11 +146,6 @@ unsigned int loc_get_target(void)
|
||||||
char baseband[LINE_LEN];
|
char baseband[LINE_LEN];
|
||||||
char rd_auto_platform[LINE_LEN];
|
char rd_auto_platform[LINE_LEN];
|
||||||
|
|
||||||
if (is_qca1530()) {
|
|
||||||
gTarget = TARGET_QCA1530;
|
|
||||||
goto detected;
|
|
||||||
}
|
|
||||||
|
|
||||||
loc_get_target_baseband(baseband, sizeof(baseband));
|
loc_get_target_baseband(baseband, sizeof(baseband));
|
||||||
|
|
||||||
if (!access(hw_platform, F_OK)) {
|
if (!access(hw_platform, F_OK)) {
|
||||||
|
@ -249,35 +181,28 @@ unsigned int loc_get_target(void)
|
||||||
gTarget = TARGET_NO_GNSS;
|
gTarget = TARGET_NO_GNSS;
|
||||||
else
|
else
|
||||||
gTarget = TARGET_APQ_SA;
|
gTarget = TARGET_APQ_SA;
|
||||||
}
|
} else if (((!memcmp(rd_hw_platform, STR_LIQUID, LENGTH(STR_LIQUID))
|
||||||
else {
|
|
||||||
if( (!memcmp(rd_hw_platform, STR_LIQUID, LENGTH(STR_LIQUID))
|
|
||||||
&& IS_STR_END(rd_hw_platform[LENGTH(STR_LIQUID)])) ||
|
&& IS_STR_END(rd_hw_platform[LENGTH(STR_LIQUID)])) ||
|
||||||
(!memcmp(rd_hw_platform, STR_SURF, LENGTH(STR_SURF))
|
(!memcmp(rd_hw_platform, STR_SURF, LENGTH(STR_SURF))
|
||||||
&& IS_STR_END(rd_hw_platform[LENGTH(STR_SURF)])) ||
|
&& IS_STR_END(rd_hw_platform[LENGTH(STR_SURF)])) ||
|
||||||
(!memcmp(rd_hw_platform, STR_MTP, LENGTH(STR_MTP))
|
(!memcmp(rd_hw_platform, STR_MTP, LENGTH(STR_MTP))
|
||||||
&& IS_STR_END(rd_hw_platform[LENGTH(STR_MTP)]))) {
|
&& IS_STR_END(rd_hw_platform[LENGTH(STR_MTP)]))) &&
|
||||||
|
!read_a_line( mdm, rd_mdm, LINE_LEN)) {
|
||||||
if (!read_a_line( mdm, rd_mdm, LINE_LEN))
|
|
||||||
gTarget = TARGET_MDM;
|
gTarget = TARGET_MDM;
|
||||||
}
|
} else if( (!memcmp(rd_id, MSM8930_ID_1, LENGTH(MSM8930_ID_1))
|
||||||
|
|
||||||
else if( (!memcmp(rd_id, MSM8930_ID_1, LENGTH(MSM8930_ID_1))
|
|
||||||
&& IS_STR_END(rd_id[LENGTH(MSM8930_ID_1)])) ||
|
&& IS_STR_END(rd_id[LENGTH(MSM8930_ID_1)])) ||
|
||||||
(!memcmp(rd_id, MSM8930_ID_2, LENGTH(MSM8930_ID_2))
|
(!memcmp(rd_id, MSM8930_ID_2, LENGTH(MSM8930_ID_2))
|
||||||
&& IS_STR_END(rd_id[LENGTH(MSM8930_ID_2)])) )
|
&& IS_STR_END(rd_id[LENGTH(MSM8930_ID_2)])) ) {
|
||||||
gTarget = TARGET_MSM_NO_SSC;
|
gTarget = TARGET_MSM_NO_SSC;
|
||||||
|
} else if ( !memcmp(baseband, STR_MSM, LENGTH(STR_MSM)) ||
|
||||||
else if ( !memcmp(baseband, STR_MSM, LENGTH(STR_MSM)) ||
|
!memcmp(baseband, STR_SDM, LENGTH(STR_SDM)) ) {
|
||||||
!memcmp(baseband, STR_SDM, LENGTH(STR_SDM)) )
|
|
||||||
gTarget = TARGET_DEFAULT;
|
gTarget = TARGET_DEFAULT;
|
||||||
|
} else {
|
||||||
else
|
|
||||||
gTarget = TARGET_UNKNOWN;
|
gTarget = TARGET_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
detected:
|
detected:
|
||||||
LOC_LOGD("HAL: %s returned %d", __FUNCTION__, gTarget);
|
LOC_LOGW("HAL: %s returned %d", __FUNCTION__, gTarget);
|
||||||
return gTarget;
|
return gTarget;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,6 @@
|
||||||
#define TARGET_APQ_SA TARGET_SET(GNSS_GSS, NO_SSC)
|
#define TARGET_APQ_SA TARGET_SET(GNSS_GSS, NO_SSC)
|
||||||
#define TARGET_NO_GNSS TARGET_SET(GNSS_NONE, NO_SSC)
|
#define TARGET_NO_GNSS TARGET_SET(GNSS_NONE, NO_SSC)
|
||||||
#define TARGET_MSM_NO_SSC TARGET_SET(GNSS_MSM, NO_SSC)
|
#define TARGET_MSM_NO_SSC TARGET_SET(GNSS_MSM, NO_SSC)
|
||||||
#define TARGET_QCA1530 TARGET_SET(GNSS_QCA1530, NO_SSC)
|
|
||||||
#define TARGET_AUTO TARGET_SET(GNSS_AUTO, NO_SSC)
|
#define TARGET_AUTO TARGET_SET(GNSS_AUTO, NO_SSC)
|
||||||
#define TARGET_UNKNOWN TARGET_SET(GNSS_UNKNOWN, NO_SSC)
|
#define TARGET_UNKNOWN TARGET_SET(GNSS_UNKNOWN, NO_SSC)
|
||||||
#define getTargetGnssType(target) (target>>1)
|
#define getTargetGnssType(target) (target>>1)
|
||||||
|
@ -69,7 +68,6 @@ typedef enum {
|
||||||
GNSS_MSM,
|
GNSS_MSM,
|
||||||
GNSS_GSS,
|
GNSS_GSS,
|
||||||
GNSS_MDM,
|
GNSS_MDM,
|
||||||
GNSS_QCA1530,
|
|
||||||
GNSS_AUTO,
|
GNSS_AUTO,
|
||||||
GNSS_UNKNOWN
|
GNSS_UNKNOWN
|
||||||
}GNSS_TARGET;
|
}GNSS_TARGET;
|
||||||
|
|
Loading…
Reference in a new issue