Commit d0bfd7c9 authored by Stephen Boyd's avatar Stephen Boyd Committed by Andy Gross

soc: qcom: smem: Move RPM message ram out of smem DT node

SMEM is a software construct built on top of a DDR reserved region
and sometimes a device memory region called RPM message ram. Having
the RPM message ram in the smem DT node's reg property leads to the
smem node being located in different places depending on if the
message ram is being used or not. Let's add a qcom specific
property, qcom,rpm-msg-ram, and point to the device memory from
the SMEM node via a phandle.  As SMEM is a software construct, it
really needs to reside at the root of the DT regardless of whether
it's using the message ram or not.

Cc: Bjorn Andersson <bjorn.andersson@sonymobile.com>
Signed-off-by: default avatarStephen Boyd <sboyd@codeaurora.org>
Signed-off-by: default avatarAndy Gross <agross@codeaurora.org>
parent a8ddd1b9
...@@ -100,6 +100,15 @@ timer { ...@@ -100,6 +100,15 @@ timer {
clock-frequency = <19200000>; clock-frequency = <19200000>;
}; };
smem {
compatible = "qcom,smem";
memory-region = <&smem_region>;
qcom,rpm-msg-ram = <&rpm_msg_ram>;
hwlocks = <&tcsr_mutex 3>;
};
soc: soc { soc: soc {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
...@@ -250,13 +259,9 @@ tcsr_mutex: tcsr-mutex { ...@@ -250,13 +259,9 @@ tcsr_mutex: tcsr-mutex {
#hwlock-cells = <1>; #hwlock-cells = <1>;
}; };
smem@fa00000 { rpm_msg_ram: memory@fc428000 {
compatible = "qcom,smem"; compatible = "qcom,rpm-msg-ram";
memory-region = <&smem_region>;
reg = <0xfc428000 0x4000>; reg = <0xfc428000 0x4000>;
hwlocks = <&tcsr_mutex 3>;
}; };
blsp1_uart2: serial@f991e000 { blsp1_uart2: serial@f991e000 {
......
...@@ -664,37 +664,47 @@ static int qcom_smem_enumerate_partitions(struct qcom_smem *smem, ...@@ -664,37 +664,47 @@ static int qcom_smem_enumerate_partitions(struct qcom_smem *smem,
return 0; return 0;
} }
static int qcom_smem_count_mem_regions(struct platform_device *pdev) static int qcom_smem_map_memory(struct qcom_smem *smem, struct device *dev,
const char *name, int i)
{ {
struct resource *res; struct device_node *np;
int num_regions = 0; struct resource r;
int i; int ret;
for (i = 0; i < pdev->num_resources; i++) {
res = &pdev->resource[i];
if (resource_type(res) == IORESOURCE_MEM) np = of_parse_phandle(dev->of_node, name, 0);
num_regions++; if (!np) {
dev_err(dev, "No %s specified\n", name);
return -EINVAL;
} }
return num_regions; ret = of_address_to_resource(np, 0, &r);
of_node_put(np);
if (ret)
return ret;
smem->regions[i].aux_base = (u32)r.start;
smem->regions[i].size = resource_size(&r);
smem->regions[i].virt_base = devm_ioremap_nocache(dev, r.start,
resource_size(&r));
if (!smem->regions[i].virt_base)
return -ENOMEM;
return 0;
} }
static int qcom_smem_probe(struct platform_device *pdev) static int qcom_smem_probe(struct platform_device *pdev)
{ {
struct smem_header *header; struct smem_header *header;
struct device_node *np;
struct qcom_smem *smem; struct qcom_smem *smem;
struct resource *res;
struct resource r;
size_t array_size; size_t array_size;
int num_regions = 0; int num_regions;
int hwlock_id; int hwlock_id;
u32 version; u32 version;
int ret; int ret;
int i;
num_regions = qcom_smem_count_mem_regions(pdev) + 1; num_regions = 1;
if (of_find_property(pdev->dev.of_node, "qcom,rpm-msg-ram", NULL))
num_regions++;
array_size = num_regions * sizeof(struct smem_region); array_size = num_regions * sizeof(struct smem_region);
smem = devm_kzalloc(&pdev->dev, sizeof(*smem) + array_size, GFP_KERNEL); smem = devm_kzalloc(&pdev->dev, sizeof(*smem) + array_size, GFP_KERNEL);
...@@ -704,36 +714,13 @@ static int qcom_smem_probe(struct platform_device *pdev) ...@@ -704,36 +714,13 @@ static int qcom_smem_probe(struct platform_device *pdev)
smem->dev = &pdev->dev; smem->dev = &pdev->dev;
smem->num_regions = num_regions; smem->num_regions = num_regions;
np = of_parse_phandle(pdev->dev.of_node, "memory-region", 0); ret = qcom_smem_map_memory(smem, &pdev->dev, "memory-region", 0);
if (!np) {
dev_err(&pdev->dev, "No memory-region specified\n");
return -EINVAL;
}
ret = of_address_to_resource(np, 0, &r);
of_node_put(np);
if (ret) if (ret)
return ret; return ret;
smem->regions[0].aux_base = (u32)r.start; if (num_regions > 1 && (ret = qcom_smem_map_memory(smem, &pdev->dev,
smem->regions[0].size = resource_size(&r); "qcom,rpm-msg-ram", 1)))
smem->regions[0].virt_base = devm_ioremap_nocache(&pdev->dev, return ret;
r.start,
resource_size(&r));
if (!smem->regions[0].virt_base)
return -ENOMEM;
for (i = 1; i < num_regions; i++) {
res = platform_get_resource(pdev, IORESOURCE_MEM, i - 1);
smem->regions[i].aux_base = (u32)res->start;
smem->regions[i].size = resource_size(res);
smem->regions[i].virt_base = devm_ioremap_nocache(&pdev->dev,
res->start,
resource_size(res));
if (!smem->regions[i].virt_base)
return -ENOMEM;
}
header = smem->regions[0].virt_base; header = smem->regions[0].virt_base;
if (le32_to_cpu(header->initialized) != 1 || if (le32_to_cpu(header->initialized) != 1 ||
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment