}
EXPORT_SYMBOL_GPL(__spi_alloc_controller);
-static void devm_spi_release_controller(struct device *dev, void *ctlr)
+static void devm_spi_release_controller(void *ctlr)
{
- spi_controller_put(*(struct spi_controller **)ctlr);
+ spi_controller_put(ctlr);
}
/**
unsigned int size,
bool target)
{
- struct spi_controller **ptr, *ctlr;
+ struct spi_controller *ctlr;
+ int ret;
- ptr = devres_alloc(devm_spi_release_controller, sizeof(*ptr),
- GFP_KERNEL);
- if (!ptr)
+ ctlr = __spi_alloc_controller(dev, size, target);
+ if (!ctlr)
return NULL;
- ctlr = __spi_alloc_controller(dev, size, target);
- if (ctlr) {
- ctlr->devm_allocated = true;
- *ptr = ctlr;
- devres_add(dev, ptr);
- } else {
- devres_free(ptr);
- }
+ ret = devm_add_action_or_reset(dev, devm_spi_release_controller, ctlr);
+ if (ret)
+ return NULL;
+
+ ctlr->devm_allocated = true;
return ctlr;
}
}
EXPORT_SYMBOL_GPL(spi_register_controller);
-static void devm_spi_unregister(struct device *dev, void *res)
+static void devm_spi_unregister_controller(void *ctlr)
{
- spi_unregister_controller(*(struct spi_controller **)res);
+ spi_unregister_controller(ctlr);
}
/**
int devm_spi_register_controller(struct device *dev,
struct spi_controller *ctlr)
{
- struct spi_controller **ptr;
int ret;
- ptr = devres_alloc(devm_spi_unregister, sizeof(*ptr), GFP_KERNEL);
- if (!ptr)
- return -ENOMEM;
-
ret = spi_register_controller(ctlr);
- if (!ret) {
- *ptr = ctlr;
- devres_add(dev, ptr);
- } else {
- devres_free(ptr);
- }
+ if (ret)
+ return ret;
+
+ return devm_add_action_or_reset(dev, devm_spi_unregister_controller, ctlr);
- return ret;
}
EXPORT_SYMBOL_GPL(devm_spi_register_controller);