Commit 378f2b61 authored by Ilpo Järvinen's avatar Ilpo Järvinen

Merge branch 'pdx86/platform-drivers-x86-mellanox-init' into review-ilpo

parents a41357ad 8634c111
...@@ -368,7 +368,7 @@ struct mlxplat_priv { ...@@ -368,7 +368,7 @@ struct mlxplat_priv {
}; };
static struct platform_device *mlxplat_dev; static struct platform_device *mlxplat_dev;
static int mlxplat_i2c_main_complition_notify(void *handle, int id); static int mlxplat_i2c_main_completion_notify(void *handle, int id);
static void __iomem *i2c_bridge_addr, *jtag_bridge_addr; static void __iomem *i2c_bridge_addr, *jtag_bridge_addr;
/* Regions for LPC I2C controller and LPC base register space */ /* Regions for LPC I2C controller and LPC base register space */
...@@ -384,7 +384,7 @@ static const struct resource mlxplat_lpc_resources[] = { ...@@ -384,7 +384,7 @@ static const struct resource mlxplat_lpc_resources[] = {
/* Platform systems default i2c data */ /* Platform systems default i2c data */
static struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_i2c_default_data = { static struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_i2c_default_data = {
.completion_notify = mlxplat_i2c_main_complition_notify, .completion_notify = mlxplat_i2c_main_completion_notify,
}; };
/* Platform i2c next generation systems data */ /* Platform i2c next generation systems data */
...@@ -409,7 +409,7 @@ static struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_i2c_ng_data = { ...@@ -409,7 +409,7 @@ static struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_i2c_ng_data = {
.mask = MLXPLAT_CPLD_AGGR_MASK_COMEX, .mask = MLXPLAT_CPLD_AGGR_MASK_COMEX,
.cell_low = MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET, .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET,
.mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_I2C, .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_I2C,
.completion_notify = mlxplat_i2c_main_complition_notify, .completion_notify = mlxplat_i2c_main_completion_notify,
}; };
/* Platform default channels */ /* Platform default channels */
...@@ -6291,7 +6291,7 @@ static void mlxplat_pci_fpga_devices_exit(void) ...@@ -6291,7 +6291,7 @@ static void mlxplat_pci_fpga_devices_exit(void)
} }
static int static int
mlxplat_pre_init(struct resource **hotplug_resources, unsigned int *hotplug_resources_size) mlxplat_logicdev_init(struct resource **hotplug_resources, unsigned int *hotplug_resources_size)
{ {
int err; int err;
...@@ -6302,7 +6302,7 @@ mlxplat_pre_init(struct resource **hotplug_resources, unsigned int *hotplug_reso ...@@ -6302,7 +6302,7 @@ mlxplat_pre_init(struct resource **hotplug_resources, unsigned int *hotplug_reso
return err; return err;
} }
static void mlxplat_post_exit(void) static void mlxplat_logicdev_exit(void)
{ {
if (lpc_bridge) if (lpc_bridge)
mlxplat_pci_fpga_devices_exit(); mlxplat_pci_fpga_devices_exit();
...@@ -6310,7 +6310,7 @@ static void mlxplat_post_exit(void) ...@@ -6310,7 +6310,7 @@ static void mlxplat_post_exit(void)
mlxplat_lpc_cpld_device_exit(); mlxplat_lpc_cpld_device_exit();
} }
static int mlxplat_post_init(struct mlxplat_priv *priv) static int mlxplat_platdevs_init(struct mlxplat_priv *priv)
{ {
int i = 0, err; int i = 0, err;
...@@ -6407,7 +6407,7 @@ static int mlxplat_post_init(struct mlxplat_priv *priv) ...@@ -6407,7 +6407,7 @@ static int mlxplat_post_init(struct mlxplat_priv *priv)
return err; return err;
} }
static void mlxplat_pre_exit(struct mlxplat_priv *priv) static void mlxplat_platdevs_exit(struct mlxplat_priv *priv)
{ {
int i; int i;
...@@ -6429,7 +6429,7 @@ mlxplat_i2c_mux_complition_notify(void *handle, struct i2c_adapter *parent, ...@@ -6429,7 +6429,7 @@ mlxplat_i2c_mux_complition_notify(void *handle, struct i2c_adapter *parent,
{ {
struct mlxplat_priv *priv = handle; struct mlxplat_priv *priv = handle;
return mlxplat_post_init(priv); return mlxplat_platdevs_init(priv);
} }
static int mlxplat_i2c_mux_topology_init(struct mlxplat_priv *priv) static int mlxplat_i2c_mux_topology_init(struct mlxplat_priv *priv)
...@@ -6471,7 +6471,7 @@ static void mlxplat_i2c_mux_topology_exit(struct mlxplat_priv *priv) ...@@ -6471,7 +6471,7 @@ static void mlxplat_i2c_mux_topology_exit(struct mlxplat_priv *priv)
} }
} }
static int mlxplat_i2c_main_complition_notify(void *handle, int id) static int mlxplat_i2c_main_completion_notify(void *handle, int id)
{ {
struct mlxplat_priv *priv = handle; struct mlxplat_priv *priv = handle;
...@@ -6514,6 +6514,7 @@ static int mlxplat_i2c_main_init(struct mlxplat_priv *priv) ...@@ -6514,6 +6514,7 @@ static int mlxplat_i2c_main_init(struct mlxplat_priv *priv)
return 0; return 0;
fail_mlxplat_i2c_mux_topology_init: fail_mlxplat_i2c_mux_topology_init:
platform_device_unregister(priv->pdev_i2c);
fail_platform_i2c_register: fail_platform_i2c_register:
fail_mlxplat_mlxcpld_verify_bus_topology: fail_mlxplat_mlxcpld_verify_bus_topology:
return err; return err;
...@@ -6521,6 +6522,7 @@ static int mlxplat_i2c_main_init(struct mlxplat_priv *priv) ...@@ -6521,6 +6522,7 @@ static int mlxplat_i2c_main_init(struct mlxplat_priv *priv)
static void mlxplat_i2c_main_exit(struct mlxplat_priv *priv) static void mlxplat_i2c_main_exit(struct mlxplat_priv *priv)
{ {
mlxplat_platdevs_exit(priv);
mlxplat_i2c_mux_topology_exit(priv); mlxplat_i2c_mux_topology_exit(priv);
if (priv->pdev_i2c) if (priv->pdev_i2c)
platform_device_unregister(priv->pdev_i2c); platform_device_unregister(priv->pdev_i2c);
...@@ -6542,7 +6544,7 @@ static int mlxplat_probe(struct platform_device *pdev) ...@@ -6542,7 +6544,7 @@ static int mlxplat_probe(struct platform_device *pdev)
mlxplat_dev = pdev; mlxplat_dev = pdev;
} }
err = mlxplat_pre_init(&hotplug_resources, &hotplug_resources_size); err = mlxplat_logicdev_init(&hotplug_resources, &hotplug_resources_size);
if (err) if (err)
return err; return err;
...@@ -6597,11 +6599,11 @@ static int mlxplat_probe(struct platform_device *pdev) ...@@ -6597,11 +6599,11 @@ static int mlxplat_probe(struct platform_device *pdev)
fail_register_reboot_notifier: fail_register_reboot_notifier:
fail_regcache_sync: fail_regcache_sync:
mlxplat_pre_exit(priv); mlxplat_i2c_main_exit(priv);
fail_mlxplat_i2c_main_init: fail_mlxplat_i2c_main_init:
fail_regmap_write: fail_regmap_write:
fail_alloc: fail_alloc:
mlxplat_post_exit(); mlxplat_logicdev_exit();
return err; return err;
} }
...@@ -6614,9 +6616,8 @@ static void mlxplat_remove(struct platform_device *pdev) ...@@ -6614,9 +6616,8 @@ static void mlxplat_remove(struct platform_device *pdev)
pm_power_off = NULL; pm_power_off = NULL;
if (mlxplat_reboot_nb) if (mlxplat_reboot_nb)
unregister_reboot_notifier(mlxplat_reboot_nb); unregister_reboot_notifier(mlxplat_reboot_nb);
mlxplat_pre_exit(priv);
mlxplat_i2c_main_exit(priv); mlxplat_i2c_main_exit(priv);
mlxplat_post_exit(); mlxplat_logicdev_exit();
} }
static const struct acpi_device_id mlxplat_acpi_table[] = { static const struct acpi_device_id mlxplat_acpi_table[] = {
......
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