Merge "qcacld-3.0: Return correct failure code" into wlan-cld3.driver.lnx.1.1-dev

Bu işleme şunda yer alıyor:
Service qcabuildsw
2016-07-21 15:30:32 -07:00
işlemeyi yapan: Gerrit - the friendly Code Review server
işleme 9f6c463da1

Dosyayı Görüntüle

@@ -48,7 +48,6 @@
#define PLD_PCIE_REGISTERED BIT(0)
#define PLD_SNOC_REGISTERED BIT(1)
#define PLD_SDIO_REGISTERED BIT(2)
#define PLD_BUS_MASK 0x7
static struct pld_context *pld_ctx;
@@ -210,7 +209,7 @@ enum pld_bus_type pld_get_bus_type(struct device *dev)
* device is online.
*
* Return: 0 for success
* pld_driver_state for errors
* Non zero failure code for errors
*/
int pld_register_driver(struct pld_driver_ops *ops)
{
@@ -240,19 +239,36 @@ int pld_register_driver(struct pld_driver_ops *ops)
pld_context->ops = ops;
if (0 == pld_pcie_register_driver())
pld_context->pld_driver_state |= PLD_PCIE_REGISTERED;
if (0 == pld_snoc_register_driver())
pld_context->pld_driver_state |= PLD_SNOC_REGISTERED;
if (0 == pld_sdio_register_driver())
pld_context->pld_driver_state |= PLD_SDIO_REGISTERED;
if ((PLD_BUS_MASK & pld_context->pld_driver_state) != PLD_BUS_MASK) {
pr_err("driver falied to register, state %x\n",
pld_context->pld_driver_state);
ret = pld_context->pld_driver_state;
ret = pld_pcie_register_driver();
if (ret) {
pr_err("Fail to register pcie driver\n");
goto fail_pcie;
}
pld_context->pld_driver_state |= PLD_PCIE_REGISTERED;
ret = pld_snoc_register_driver();
if (ret) {
pr_err("Fail to register snoc driver\n");
goto fail_snoc;
}
pld_context->pld_driver_state |= PLD_SNOC_REGISTERED;
ret = pld_sdio_register_driver();
if (ret) {
pr_err("Fail to register sdio driver\n");
goto fail_sdio;
}
pld_context->pld_driver_state |= PLD_SDIO_REGISTERED;
return ret;
fail_sdio:
pld_snoc_unregister_driver();
fail_snoc:
pld_pcie_unregister_driver();
fail_pcie:
pld_context->pld_driver_state = 0;
pld_context->ops = NULL;
out:
return ret;
}