The patch titled request_firmware examples and MODULE_FIRMWARE has been added to the -mm tree. Its filename is request_firmware-examples-and-module_firmware.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: request_firmware examples and MODULE_FIRMWARE From: Victor Hugo <victor@xxxxxxxxx> Update the incomplete example driver under Documentaion/firmware_class/. The example (firmware_sample_driver.c) doesn't work out of box and needs tweaking just to get it to compile. I've added two files which use request_firmware and the asynchronous request_firmware_nowait. Cc: Jon Masters <jonathan@xxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- Documentation/firmware_class/firmware_example.c | 69 ++++++ Documentation/firmware_class/firmware_nowait_example.c | 84 +++++++ Documentation/firmware_class/firmware_sample_driver.c | 115 ---------- 3 files changed, 153 insertions(+), 115 deletions(-) diff -puN /dev/null Documentation/firmware_class/firmware_example.c --- /dev/null +++ a/Documentation/firmware_class/firmware_example.c @@ -0,0 +1,69 @@ +/* + * firmware_example.c - + * + * Copyright (c) 2006 Victor Hugo <victor@xxxxxxxxx> + * Based on firmware_sample_driver.c by Manuel Estrada Sainz + * Sample code on how to use request_firmware() from drivers. + * + */ + +#include <linux/module.h> +#include <linux/kernel.h> +#include <linux/init.h> +#include <linux/device.h> +#include <linux/string.h> +#include <linux/firmware.h> + +static void sample_firmware_load(char *firmware, int size) +{ + u8 buf[size + 1]; + memcpy(buf, firmware, size); + buf[size] = '\0'; + printk(KERN_INFO "firmware_example: Firmware: %s\n", buf); +} + +static void sample_probe(struct device *dev) +{ + /* uses the default method to get the firmware */ + const struct firmware *fw_entry; + printk(KERN_INFO + "firmware_example: ghost device inserted\n"); + + if (request_firmware(&fw_entry, "sample_firware.bin", dev) != 0) { + printk(KERN_ERR + "firmware_example: Firmware not available\n"); + return; + } + + sample_firmware_load(fw_entry->data, fw_entry->size); + + release_firmware(fw_entry); + + /* finish setting up the device */ +} + +static void ghost_release(struct device *dev) +{ + printk(KERN_DEBUG "firmware_example : ghost device released\n"); +} + +static struct device ghost_device = { + .bus_id = "ghost0", + .release = ghost_release +}; + +static int __init sample_init(void) +{ + device_register(&ghost_device); + sample_probe(&ghost_device); + return 0; +} +static void __exit sample_exit(void) +{ + device_unregister(&ghost_device); +} + +module_init(sample_init); +module_exit(sample_exit); + +MODULE_LICENSE("GPL"); diff -puN /dev/null Documentation/firmware_class/firmware_nowait_example.c --- /dev/null +++ a/Documentation/firmware_class/firmware_nowait_example.c @@ -0,0 +1,84 @@ +/* + * firmware_nowait_example.c - + * + * Copyright (c) 2006 Victor Hugo <victor@xxxxxxxxx> + * Based on firmware_sample_driver.c by Manuel Estrada Sainz + * Sample code on how to use request_firmware() from drivers. + * + */ + +#include <linux/module.h> +#include <linux/kernel.h> +#include <linux/init.h> +#include <linux/device.h> +#include <linux/string.h> +#include <linux/firmware.h> + +static void sample_firmware_load(char *firmware, int size) +{ + u8 buf[size+1]; + memcpy(buf, firmware, size); + buf[size] = '\0'; + printk(KERN_INFO "firmware_nowait_example: Firmware: %s\n", buf); +} + +static void sample_probe_async_cont(const struct firmware *fw, void *context) +{ + if(!fw) + { + printk(KERN_ERR "firmware_nowait_example: Firmware not available\n"); + return; + } + + + printk(KERN_INFO "firmware_nowait_example: Device Pointer \"%s\"\n", + (char *)context); + sample_firmware_load(fw->data, fw->size); + +} + +static void sample_probe_async(struct device *dev) +{ + /* Let's say I can't sleep */ + int error; + + printk(KERN_INFO + "firmware_example: ghost device inserted\n"); + + error = request_firmware_nowait(THIS_MODULE, FW_ACTION_NOHOTPLUG, + "sample_firmware.bin", dev, + "my device pointer",sample_probe_async_cont); + + if(error) + { + printk(KERN_ERR + "firmware_nowait_example: request_firmware_nowait Failed\n"); + } + +} + +static void ghost_release(struct device *dev) +{ + printk(KERN_DEBUG "firmware_nowait_example: ghost device released\n"); +} + +static struct device ghost_device = { + .bus_id = "ghost0", + .release = ghost_release +}; + +static int __init sample_init(void) +{ + device_register(&ghost_device); + sample_probe_async(&ghost_device); +return 0; +} +static void __exit sample_exit(void) +{ + device_unregister(&ghost_device); +} + +module_init (sample_init); +module_exit (sample_exit); + +MODULE_LICENSE("GPL"); diff -puN Documentation/firmware_class/firmware_sample_driver.c~request_firmware-examples-and-module_firmware /dev/null --- a/Documentation/firmware_class/firmware_sample_driver.c +++ /dev/null @@ -1,115 +0,0 @@ -/* - * firmware_sample_driver.c - - * - * Copyright (c) 2003 Manuel Estrada Sainz <ranty@xxxxxxxxxx> - * - * Sample code on how to use request_firmware() from drivers. - * - */ - -#include <linux/module.h> -#include <linux/kernel.h> -#include <linux/init.h> -#include <linux/device.h> -#include <linux/string.h> - -#include "linux/firmware.h" - -static struct device ghost_device = { - .bus_id = "ghost0", -}; - - -static void sample_firmware_load(char *firmware, int size) -{ - u8 buf[size+1]; - memcpy(buf, firmware, size); - buf[size] = '\0'; - printk(KERN_INFO "firmware_sample_driver: firmware: %s\n", buf); -} - -static void sample_probe_default(void) -{ - /* uses the default method to get the firmware */ - const struct firmware *fw_entry; - printk(KERN_INFO "firmware_sample_driver: a ghost device got inserted :)\n"); - - if(request_firmware(&fw_entry, "sample_driver_fw", &ghost_device)!=0) - { - printk(KERN_ERR - "firmware_sample_driver: Firmware not available\n"); - return; - } - - sample_firmware_load(fw_entry->data, fw_entry->size); - - release_firmware(fw_entry); - - /* finish setting up the device */ -} -static void sample_probe_specific(void) -{ - /* Uses some specific hotplug support to get the firmware from - * userspace directly into the hardware, or via some sysfs file */ - - /* NOTE: This currently doesn't work */ - - printk(KERN_INFO "firmware_sample_driver: a ghost device got inserted :)\n"); - - if(request_firmware(NULL, "sample_driver_fw", &ghost_device)!=0) - { - printk(KERN_ERR - "firmware_sample_driver: Firmware load failed\n"); - return; - } - - /* request_firmware blocks until userspace finished, so at - * this point the firmware should be already in the device */ - - /* finish setting up the device */ -} -static void sample_probe_async_cont(const struct firmware *fw, void *context) -{ - if(!fw){ - printk(KERN_ERR - "firmware_sample_driver: firmware load failed\n"); - return; - } - - printk(KERN_INFO "firmware_sample_driver: device pointer \"%s\"\n", - (char *)context); - sample_firmware_load(fw->data, fw->size); -} -static void sample_probe_async(void) -{ - /* Let's say that I can't sleep */ - int error; - error = request_firmware_nowait (THIS_MODULE, FW_ACTION_NOHOTPLUG, - "sample_driver_fw", &ghost_device, - "my device pointer", - sample_probe_async_cont); - if(error){ - printk(KERN_ERR - "firmware_sample_driver:" - " request_firmware_nowait failed\n"); - } -} - -static int sample_init(void) -{ - device_initialize(&ghost_device); - /* since there is no real hardware insertion I just call the - * sample probe functions here */ - sample_probe_specific(); - sample_probe_default(); - sample_probe_async(); - return 0; -} -static void __exit sample_exit(void) -{ -} - -module_init (sample_init); -module_exit (sample_exit); - -MODULE_LICENSE("GPL"); _ Patches currently in -mm which might be from victor@xxxxxxxxx are request_firmware-examples-and-module_firmware.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html