Commit ea1a76ba authored by Axel Lin's avatar Axel Lin Committed by Darren Hart

platform/x86: intel_pmc_ipc: Convert to use platform_device_register_full

Use platform_device_register_full() instead of open-coded.
Signed-off-by: default avatarAxel Lin <axel.lin@ingics.com>
Signed-off-by: default avatarDarren Hart <dvhart@linux.intel.com>
parent b5643539
...@@ -522,48 +522,36 @@ static struct resource telemetry_res[] = { ...@@ -522,48 +522,36 @@ static struct resource telemetry_res[] = {
static int ipc_create_punit_device(void) static int ipc_create_punit_device(void)
{ {
struct platform_device *pdev; struct platform_device *pdev;
int ret; const struct platform_device_info pdevinfo = {
.parent = ipcdev.dev,
pdev = platform_device_alloc(PUNIT_DEVICE_NAME, -1); .name = PUNIT_DEVICE_NAME,
if (!pdev) { .id = -1,
dev_err(ipcdev.dev, "Failed to alloc punit platform device\n"); .res = punit_res_array,
return -ENOMEM; .num_res = ARRAY_SIZE(punit_res_array),
} };
pdev->dev.parent = ipcdev.dev; pdev = platform_device_register_full(&pdevinfo);
ret = platform_device_add_resources(pdev, punit_res_array, if (IS_ERR(pdev))
ARRAY_SIZE(punit_res_array)); return PTR_ERR(pdev);
if (ret) {
dev_err(ipcdev.dev, "Failed to add platform punit resources\n");
goto err;
}
ret = platform_device_add(pdev);
if (ret) {
dev_err(ipcdev.dev, "Failed to add punit platform device\n");
goto err;
}
ipcdev.punit_dev = pdev; ipcdev.punit_dev = pdev;
return 0; return 0;
err:
platform_device_put(pdev);
return ret;
} }
static int ipc_create_tco_device(void) static int ipc_create_tco_device(void)
{ {
struct platform_device *pdev; struct platform_device *pdev;
struct resource *res; struct resource *res;
int ret; const struct platform_device_info pdevinfo = {
.parent = ipcdev.dev,
pdev = platform_device_alloc(TCO_DEVICE_NAME, -1); .name = TCO_DEVICE_NAME,
if (!pdev) { .id = -1,
dev_err(ipcdev.dev, "Failed to alloc tco platform device\n"); .res = tco_res,
return -ENOMEM; .num_res = ARRAY_SIZE(tco_res),
} .data = &tco_info,
.size_data = sizeof(tco_info),
pdev->dev.parent = ipcdev.dev; };
res = tco_res + TCO_RESOURCE_ACPI_IO; res = tco_res + TCO_RESOURCE_ACPI_IO;
res->start = ipcdev.acpi_io_base + TCO_BASE_OFFSET; res->start = ipcdev.acpi_io_base + TCO_BASE_OFFSET;
...@@ -577,45 +565,26 @@ static int ipc_create_tco_device(void) ...@@ -577,45 +565,26 @@ static int ipc_create_tco_device(void)
res->start = ipcdev.gcr_base + TCO_PMC_OFFSET; res->start = ipcdev.gcr_base + TCO_PMC_OFFSET;
res->end = res->start + TCO_PMC_SIZE - 1; res->end = res->start + TCO_PMC_SIZE - 1;
ret = platform_device_add_resources(pdev, tco_res, ARRAY_SIZE(tco_res)); pdev = platform_device_register_full(&pdevinfo);
if (ret) { if (IS_ERR(pdev))
dev_err(ipcdev.dev, "Failed to add tco platform resources\n"); return PTR_ERR(pdev);
goto err;
}
ret = platform_device_add_data(pdev, &tco_info, sizeof(tco_info));
if (ret) {
dev_err(ipcdev.dev, "Failed to add tco platform data\n");
goto err;
}
ret = platform_device_add(pdev);
if (ret) {
dev_err(ipcdev.dev, "Failed to add tco platform device\n");
goto err;
}
ipcdev.tco_dev = pdev; ipcdev.tco_dev = pdev;
return 0; return 0;
err:
platform_device_put(pdev);
return ret;
} }
static int ipc_create_telemetry_device(void) static int ipc_create_telemetry_device(void)
{ {
struct platform_device *pdev; struct platform_device *pdev;
struct resource *res; struct resource *res;
int ret; const struct platform_device_info pdevinfo = {
.parent = ipcdev.dev,
pdev = platform_device_alloc(TELEMETRY_DEVICE_NAME, -1); .name = TELEMETRY_DEVICE_NAME,
if (!pdev) { .id = -1,
dev_err(ipcdev.dev, .res = telemetry_res,
"Failed to allocate telemetry platform device\n"); .num_res = ARRAY_SIZE(telemetry_res),
return -ENOMEM; };
}
pdev->dev.parent = ipcdev.dev;
res = telemetry_res + TELEMETRY_RESOURCE_PUNIT_SSRAM; res = telemetry_res + TELEMETRY_RESOURCE_PUNIT_SSRAM;
res->start = ipcdev.telem_punit_ssram_base; res->start = ipcdev.telem_punit_ssram_base;
...@@ -625,26 +594,13 @@ static int ipc_create_telemetry_device(void) ...@@ -625,26 +594,13 @@ static int ipc_create_telemetry_device(void)
res->start = ipcdev.telem_pmc_ssram_base; res->start = ipcdev.telem_pmc_ssram_base;
res->end = res->start + ipcdev.telem_pmc_ssram_size - 1; res->end = res->start + ipcdev.telem_pmc_ssram_size - 1;
ret = platform_device_add_resources(pdev, telemetry_res, pdev = platform_device_register_full(&pdevinfo);
ARRAY_SIZE(telemetry_res)); if (IS_ERR(pdev))
if (ret) { return PTR_ERR(pdev);
dev_err(ipcdev.dev,
"Failed to add telemetry platform resources\n");
goto err;
}
ret = platform_device_add(pdev);
if (ret) {
dev_err(ipcdev.dev,
"Failed to add telemetry platform device\n");
goto err;
}
ipcdev.telemetry_dev = pdev; ipcdev.telemetry_dev = pdev;
return 0; return 0;
err:
platform_device_put(pdev);
return ret;
} }
static int ipc_create_pmc_devices(void) static int ipc_create_pmc_devices(void)
......
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