On Wed 11 Oct 14:29 PDT 2017, Chris Lew wrote: > From: Chris Lew <clew@xxxxxxxxxxxxxx> > > The SMEM header structure includes the version information. Read the > version directly from the header instead of getting an item from the > global heap. > Acked-by: Bjorn Andersson <bjorn.andersson@xxxxxxxxxx> Regards, Bjorn > Signed-off-by: Chris Lew <clew@xxxxxxxxxxxxxx> > --- > > Changes since v1: > - Remove unused smem item version macro > - Move smem get version change to separate commit > > Changes since v2: > - Reduce subject to 50 chars and wrap summary to 72 chars > > drivers/soc/qcom/smem.c | 25 ++++++++----------------- > 1 file changed, 8 insertions(+), 17 deletions(-) > > diff --git a/drivers/soc/qcom/smem.c b/drivers/soc/qcom/smem.c > index db04c45d4132..540322ae409e 100644 > --- a/drivers/soc/qcom/smem.c > +++ b/drivers/soc/qcom/smem.c > @@ -63,13 +63,12 @@ > */ > > /* > - * Item 3 of the global heap contains an array of versions for the various > - * software components in the SoC. We verify that the boot loader version is > - * what the expected version (SMEM_EXPECTED_VERSION) as a sanity check. > + * The version member of the smem header contains an array of versions for the > + * various software components in the SoC. We verify that the boot loader > + * version is a valid version as a sanity check. > */ > -#define SMEM_ITEM_VERSION 3 > -#define SMEM_MASTER_SBL_VERSION_INDEX 7 > -#define SMEM_EXPECTED_VERSION 11 > +#define SMEM_MASTER_SBL_VERSION_INDEX 7 > +#define SMEM_EXPECTED_VERSION 11 > > /* > * The first 8 items are only to be allocated by the boot loader while > @@ -604,19 +603,11 @@ int qcom_smem_get_free_space(unsigned host) > > static int qcom_smem_get_sbl_version(struct qcom_smem *smem) > { > + struct smem_header *header; > __le32 *versions; > - size_t size; > - > - versions = qcom_smem_get_global(smem, SMEM_ITEM_VERSION, &size); > - if (IS_ERR(versions)) { > - dev_err(smem->dev, "Unable to read the version item\n"); > - return -ENOENT; > - } > > - if (size < sizeof(unsigned) * SMEM_MASTER_SBL_VERSION_INDEX) { > - dev_err(smem->dev, "Version item is too small\n"); > - return -EINVAL; > - } > + header = smem->regions[0].virt_base; > + versions = header->version; > > return le32_to_cpu(versions[SMEM_MASTER_SBL_VERSION_INDEX]); > } > -- > The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, > a Linux Foundation Collaborative Project > -- To unsubscribe from this list: send the line "unsubscribe linux-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html