]> err.no Git - linux-2.6/commitdiff
[PATCH] Input: convert sound/ppc/beep to dynamic input_dev allocation
authorDmitry Torokhov <dtor_core@ameritech.net>
Thu, 15 Sep 2005 07:01:49 +0000 (02:01 -0500)
committerGreg Kroah-Hartman <gregkh@suse.de>
Fri, 28 Oct 2005 16:52:54 +0000 (09:52 -0700)
Input: convert sound/ppc/beep to dynamic input_dev allocation

This is required for input_dev sysfs integration

Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
sound/ppc/beep.c

index 31ea7a4c069f3ddc68a56824786d918217436c44..1681ee13efbb81fdeae0e19aa73485daa08dc69b 100644 (file)
 #include "pmac.h"
 
 struct snd_pmac_beep {
-       int running;    /* boolean */
-       int volume;     /* mixer volume: 0-100 */
+       int running;            /* boolean */
+       int volume;             /* mixer volume: 0-100 */
        int volume_play;        /* currently playing volume */
        int hz;
        int nsamples;
        short *buf;             /* allocated wave buffer */
        dma_addr_t addr;        /* physical address of buffer */
-       struct input_dev dev;
+       struct input_dev *dev;
 };
 
 /*
@@ -212,47 +212,55 @@ static snd_kcontrol_new_t snd_pmac_beep_mixer = {
 int __init snd_pmac_attach_beep(pmac_t *chip)
 {
        pmac_beep_t *beep;
-       int err;
+       struct input_dev *input_dev;
+       void *dmabuf;
+       int err = -ENOMEM;
 
-       beep = kmalloc(sizeof(*beep), GFP_KERNEL);
-       if (! beep)
-               return -ENOMEM;
-
-       memset(beep, 0, sizeof(*beep));
-       beep->buf = dma_alloc_coherent(&chip->pdev->dev, BEEP_BUFLEN * 4,
-                                       &beep->addr, GFP_KERNEL);
-
-       beep->dev.evbit[0] = BIT(EV_SND);
-       beep->dev.sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-       beep->dev.event = snd_pmac_beep_event;
-       beep->dev.private = chip;
+       beep = kzalloc(sizeof(*beep), GFP_KERNEL);
+       dmabuf = dma_alloc_coherent(&chip->pdev->dev, BEEP_BUFLEN * 4,
+                                   &beep->addr, GFP_KERNEL);
+       input_dev = input_allocate_device();
+       if (!beep || !dmabuf || !input_dev)
+               goto fail;
 
        /* FIXME: set more better values */
-       beep->dev.name = "PowerMac Beep";
-       beep->dev.phys = "powermac/beep";
-       beep->dev.id.bustype = BUS_ADB;
-       beep->dev.id.vendor = 0x001f;
-       beep->dev.id.product = 0x0001;
-       beep->dev.id.version = 0x0100;
+       input_dev->name = "PowerMac Beep";
+       input_dev->phys = "powermac/beep";
+       input_dev->id.bustype = BUS_ADB;
+       input_dev->id.vendor = 0x001f;
+       input_dev->id.product = 0x0001;
+       input_dev->id.version = 0x0100;
+
+       input_dev->evbit[0] = BIT(EV_SND);
+       input_dev->sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
+       input_dev->event = snd_pmac_beep_event;
+       input_dev->private = chip;
+       input_dev->cdev.dev = &chip->pdev->dev;
 
+       beep->dev = input_dev;
+       beep->buf = dmabuf;
        beep->volume = BEEP_VOLUME;
        beep->running = 0;
-       if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_pmac_beep_mixer, chip))) < 0) {
-               kfree(beep->buf);
-               kfree(beep);
-               return err;
-       }
+
+       err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_pmac_beep_mixer, chip));
+       if (err < 0)
+               goto fail;
 
        chip->beep = beep;
-       input_register_device(&beep->dev);
+       input_register_device(beep->dev);
 
        return 0;
+
+ fail: input_free_device(input_dev);
+       kfree(dmabuf);
+       kfree(beep);
+       return err;
 }
 
 void snd_pmac_detach_beep(pmac_t *chip)
 {
        if (chip->beep) {
-               input_unregister_device(&chip->beep->dev);
+               input_unregister_device(chip->beep->dev);
                dma_free_coherent(&chip->pdev->dev, BEEP_BUFLEN * 4,
                                  chip->beep->buf, chip->beep->addr);
                kfree(chip->beep);