disp: msm: parse SPMI registers and append to IO lend list

Parse the display peripheral related SPMI SID/Peripheral
mask from device-tree and get the dynamic register range
of these peripherals using the SPMI API. These registers
are appended to the list of display IO ranges that is
lent from HLOS to trusted VM during trusted UI. This would
help in adding restrictions for SPMI registers on HLOS during
the trusted UI use case along with validation of the register
ranges in trusted VM.

Change-Id: I7077dac7962466e845d061e9ccd205f1bc0ce3ea
Signed-off-by: Veera Sundaram Sankaran <veeras@codeaurora.org>
This commit is contained in:
Veera Sundaram Sankaran
2020-06-09 18:35:42 -07:00
committed by Gerrit - the friendly Code Review server
parent 20ed4f0785
commit f7fece8238
3 changed files with 58 additions and 0 deletions

View File

@@ -7,6 +7,7 @@
#include <linux/err.h>
#include <linux/io.h>
#include <linux/regulator/consumer.h>
#include <linux/soc/qcom/spmi-pmic-arb.h>
#include <linux/delay.h>
#include <linux/sde_io_util.h>
#include <linux/sde_vm_event.h>
@@ -130,6 +131,55 @@ void msm_dss_iounmap(struct dss_io_data *io_data)
} /* msm_dss_iounmap */
EXPORT_SYMBOL(msm_dss_iounmap);
int msm_dss_get_pmic_io_mem(struct platform_device *pdev,
struct list_head *mem_list)
{
struct list_head temp_head;
struct msm_io_mem_entry *io_mem;
struct resource *res = NULL;
struct property *prop;
const __be32 *cur;
int rc = 0;
u32 val;
INIT_LIST_HEAD(&temp_head);
res = kzalloc(sizeof(struct resource), GFP_KERNEL);
if (!res)
return -ENOMEM;
of_property_for_each_u32(pdev->dev.of_node, "qcom,pmic-arb-address",
prop, cur, val) {
rc = spmi_pmic_arb_map_address(&pdev->dev, val, res);
if (rc < 0) {
DEV_ERR("%pS - failed to map pmic address, rc:%d\n",
__func__, rc);
goto parse_fail;
}
io_mem = kzalloc(sizeof(struct msm_io_mem_entry), GFP_KERNEL);
if (!io_mem) {
rc = -ENOMEM;
goto parse_fail;
}
io_mem->base = res->start;
io_mem->size = resource_size(res);
list_add(&io_mem->list, &temp_head);
}
list_splice(&temp_head, mem_list);
goto end;
parse_fail:
msm_dss_clean_io_mem(&temp_head);
end:
kzfree(res);
return rc;
}
EXPORT_SYMBOL(msm_dss_get_pmic_io_mem);
int msm_dss_get_io_mem(struct platform_device *pdev, struct list_head *mem_list)
{
struct list_head temp_head;