2 * linux/drivers/mmc/core/sdio_bus.c
4 * Copyright 2007 Pierre Ossman
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or (at
9 * your option) any later version.
11 * SDIO function driver model
14 #include <linux/device.h>
15 #include <linux/err.h>
17 #include <linux/mmc/card.h>
18 #include <linux/mmc/sdio_func.h>
22 #define dev_to_sdio_func(d) container_of(d, struct sdio_func, dev)
25 * This currently matches any SDIO function to any driver in order
26 * to help initial development and testing.
28 static int sdio_bus_match(struct device *dev, struct device_driver *drv)
34 sdio_bus_uevent(struct device *dev, char **envp, int num_envp, char *buf,
42 static int sdio_bus_probe(struct device *dev)
47 static int sdio_bus_remove(struct device *dev)
52 static struct bus_type sdio_bus_type = {
54 .match = sdio_bus_match,
55 .uevent = sdio_bus_uevent,
56 .probe = sdio_bus_probe,
57 .remove = sdio_bus_remove,
60 int sdio_register_bus(void)
62 return bus_register(&sdio_bus_type);
65 void sdio_unregister_bus(void)
67 bus_unregister(&sdio_bus_type);
71 * sdio_register_driver - register a function driver
72 * @drv: SDIO function driver
74 int sdio_register_driver(struct sdio_driver *drv)
76 drv->drv.name = drv->name;
77 drv->drv.bus = &sdio_bus_type;
78 return driver_register(&drv->drv);
80 EXPORT_SYMBOL_GPL(sdio_register_driver);
83 * sdio_unregister_driver - unregister a function driver
84 * @drv: SDIO function driver
86 void sdio_unregister_driver(struct sdio_driver *drv)
88 drv->drv.bus = &sdio_bus_type;
89 driver_unregister(&drv->drv);
91 EXPORT_SYMBOL_GPL(sdio_unregister_driver);
93 static void sdio_release_func(struct device *dev)
95 struct sdio_func *func = dev_to_sdio_func(dev);
101 * Allocate and initialise a new SDIO function structure.
103 struct sdio_func *sdio_alloc_func(struct mmc_card *card)
105 struct sdio_func *func;
107 func = kmalloc(sizeof(struct sdio_func), GFP_KERNEL);
109 return ERR_PTR(-ENOMEM);
111 memset(func, 0, sizeof(struct sdio_func));
115 device_initialize(&func->dev);
117 func->dev.parent = &card->dev;
118 func->dev.bus = &sdio_bus_type;
119 func->dev.release = sdio_release_func;
125 * Register a new SDIO function with the driver model.
127 int sdio_add_func(struct sdio_func *func)
131 snprintf(func->dev.bus_id, sizeof(func->dev.bus_id),
132 "%s:%d", mmc_card_id(func->card), func->num);
134 ret = device_add(&func->dev);
136 sdio_func_set_present(func);
142 * Unregister a SDIO function with the driver model, and
143 * (eventually) free it.
145 void sdio_remove_func(struct sdio_func *func)
147 if (sdio_func_present(func))
148 device_del(&func->dev);
150 put_device(&func->dev);