mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 07:42:07 +00:00
Merge branch 'topic/qcom_hidma' into for-linus
This commit is contained in:
commit
2cb1800ccf
@ -17,6 +17,7 @@
|
|||||||
#include <linux/acpi.h>
|
#include <linux/acpi.h>
|
||||||
#include <linux/of.h>
|
#include <linux/of.h>
|
||||||
#include <linux/property.h>
|
#include <linux/property.h>
|
||||||
|
#include <linux/of_address.h>
|
||||||
#include <linux/of_irq.h>
|
#include <linux/of_irq.h>
|
||||||
#include <linux/of_platform.h>
|
#include <linux/of_platform.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
@ -356,59 +357,29 @@ static int __init hidma_mgmt_of_populate_channels(struct device_node *np)
|
|||||||
{
|
{
|
||||||
struct platform_device *pdev_parent = of_find_device_by_node(np);
|
struct platform_device *pdev_parent = of_find_device_by_node(np);
|
||||||
struct platform_device_info pdevinfo;
|
struct platform_device_info pdevinfo;
|
||||||
struct of_phandle_args out_irq;
|
|
||||||
struct device_node *child;
|
struct device_node *child;
|
||||||
struct resource *res = NULL;
|
struct resource *res;
|
||||||
const __be32 *cell;
|
int ret = 0;
|
||||||
int ret = 0, size, i, num;
|
|
||||||
u64 addr, addr_size;
|
/* allocate a resource array */
|
||||||
|
res = kcalloc(3, sizeof(*res), GFP_KERNEL);
|
||||||
|
if (!res)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
for_each_available_child_of_node(np, child) {
|
for_each_available_child_of_node(np, child) {
|
||||||
struct resource *res_iter;
|
|
||||||
struct platform_device *new_pdev;
|
struct platform_device *new_pdev;
|
||||||
|
|
||||||
cell = of_get_property(child, "reg", &size);
|
ret = of_address_to_resource(child, 0, &res[0]);
|
||||||
if (!cell) {
|
if (!ret)
|
||||||
ret = -EINVAL;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
size /= sizeof(*cell);
|
|
||||||
num = size /
|
|
||||||
(of_n_addr_cells(child) + of_n_size_cells(child)) + 1;
|
|
||||||
|
|
||||||
/* allocate a resource array */
|
|
||||||
res = kcalloc(num, sizeof(*res), GFP_KERNEL);
|
|
||||||
if (!res) {
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* read each reg value */
|
|
||||||
i = 0;
|
|
||||||
res_iter = res;
|
|
||||||
while (i < size) {
|
|
||||||
addr = of_read_number(&cell[i],
|
|
||||||
of_n_addr_cells(child));
|
|
||||||
i += of_n_addr_cells(child);
|
|
||||||
|
|
||||||
addr_size = of_read_number(&cell[i],
|
|
||||||
of_n_size_cells(child));
|
|
||||||
i += of_n_size_cells(child);
|
|
||||||
|
|
||||||
res_iter->start = addr;
|
|
||||||
res_iter->end = res_iter->start + addr_size - 1;
|
|
||||||
res_iter->flags = IORESOURCE_MEM;
|
|
||||||
res_iter++;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = of_irq_parse_one(child, 0, &out_irq);
|
|
||||||
if (ret)
|
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
res_iter->start = irq_create_of_mapping(&out_irq);
|
ret = of_address_to_resource(child, 1, &res[1]);
|
||||||
res_iter->name = "hidma event irq";
|
if (!ret)
|
||||||
res_iter->flags = IORESOURCE_IRQ;
|
goto out;
|
||||||
|
|
||||||
|
ret = of_irq_to_resource(child, 0, &res[2]);
|
||||||
|
if (ret <= 0)
|
||||||
|
goto out;
|
||||||
|
|
||||||
memset(&pdevinfo, 0, sizeof(pdevinfo));
|
memset(&pdevinfo, 0, sizeof(pdevinfo));
|
||||||
pdevinfo.fwnode = &child->fwnode;
|
pdevinfo.fwnode = &child->fwnode;
|
||||||
@ -416,7 +387,7 @@ static int __init hidma_mgmt_of_populate_channels(struct device_node *np)
|
|||||||
pdevinfo.name = child->name;
|
pdevinfo.name = child->name;
|
||||||
pdevinfo.id = object_counter++;
|
pdevinfo.id = object_counter++;
|
||||||
pdevinfo.res = res;
|
pdevinfo.res = res;
|
||||||
pdevinfo.num_res = num;
|
pdevinfo.num_res = 3;
|
||||||
pdevinfo.data = NULL;
|
pdevinfo.data = NULL;
|
||||||
pdevinfo.size_data = 0;
|
pdevinfo.size_data = 0;
|
||||||
pdevinfo.dma_mask = DMA_BIT_MASK(64);
|
pdevinfo.dma_mask = DMA_BIT_MASK(64);
|
||||||
@ -434,8 +405,6 @@ static int __init hidma_mgmt_of_populate_channels(struct device_node *np)
|
|||||||
*/
|
*/
|
||||||
of_msi_configure(&new_pdev->dev, child);
|
of_msi_configure(&new_pdev->dev, child);
|
||||||
of_node_put(child);
|
of_node_put(child);
|
||||||
kfree(res);
|
|
||||||
res = NULL;
|
|
||||||
}
|
}
|
||||||
out:
|
out:
|
||||||
kfree(res);
|
kfree(res);
|
||||||
|
Loading…
Reference in New Issue
Block a user