include cleanup: Update gfp.h and slab.h includes to prepare for breaking implicit...
[safe/jmp/linux-2.6] / drivers / media / video / em28xx / em28xx-dvb.c
index 19f5156..bcd3c37 100644 (file)
@@ -20,6 +20,7 @@
  */
 
 #include <linux/kernel.h>
+#include <linux/slab.h>
 #include <linux/usb.h>
 
 #include "em28xx.h"
@@ -313,22 +314,20 @@ static int attach_xc3028(u8 addr, struct em28xx *dev)
        cfg.i2c_addr  = addr;
 
        if (!dev->dvb->frontend) {
-               printk(KERN_ERR "%s/2: dvb frontend not attached. "
-                               "Can't attach xc3028\n",
-                      dev->name);
+               em28xx_errdev("/2: dvb frontend not attached. "
+                               "Can't attach xc3028\n");
                return -EINVAL;
        }
 
        fe = dvb_attach(xc2028_attach, dev->dvb->frontend, &cfg);
        if (!fe) {
-               printk(KERN_ERR "%s/2: xc3028 attach failed\n",
-                      dev->name);
+               em28xx_errdev("/2: xc3028 attach failed\n");
                dvb_frontend_detach(dev->dvb->frontend);
                dev->dvb->frontend = NULL;
                return -EINVAL;
        }
 
-       printk(KERN_INFO "%s/2: xc3028 attached\n", dev->name);
+       em28xx_info("%s/2: xc3028 attached\n", dev->name);
 
        return 0;
 }
@@ -463,7 +462,7 @@ static int dvb_init(struct em28xx *dev)
        dvb = kzalloc(sizeof(struct em28xx_dvb), GFP_KERNEL);
 
        if (dvb == NULL) {
-               printk(KERN_INFO "em28xx_dvb: memory allocation failed\n");
+               em28xx_info("em28xx_dvb: memory allocation failed\n");
                return -ENOMEM;
        }
        dev->dvb = dvb;
@@ -504,7 +503,9 @@ static int dvb_init(struct em28xx *dev)
                }
                break;
        case EM2880_BOARD_TERRATEC_HYBRID_XS:
+       case EM2880_BOARD_TERRATEC_HYBRID_XS_FR:
        case EM2881_BOARD_PINNACLE_HYBRID_PRO:
+       case EM2882_BOARD_DIKOM_DK300:
                dvb->frontend = dvb_attach(zl10353_attach,
                                           &em28xx_zl10353_xc3028_no_i2c_gate,
                                           &dev->i2c_adap);
@@ -570,15 +571,12 @@ static int dvb_init(struct em28xx *dev)
                }
                break;
        default:
-               printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card"
-                               " isn't supported yet\n",
-                      dev->name);
+               em28xx_errdev("/2: The frontend of your DVB/ATSC card"
+                               " isn't supported yet\n");
                break;
        }
        if (NULL == dvb->frontend) {
-               printk(KERN_ERR
-                      "%s/2: frontend initialization failed\n",
-                      dev->name);
+               em28xx_errdev("/2: frontend initialization failed\n");
                result = -EINVAL;
                goto out_free;
        }
@@ -592,7 +590,7 @@ static int dvb_init(struct em28xx *dev)
                goto out_free;
 
        em28xx_set_mode(dev, EM28XX_SUSPEND);
-       printk(KERN_INFO "Successfully loaded em28xx-dvb\n");
+       em28xx_info("Successfully loaded em28xx-dvb\n");
        return 0;
 
 out_free:
@@ -611,6 +609,7 @@ static int dvb_fini(struct em28xx *dev)
 
        if (dev->dvb) {
                unregister_dvb(dev->dvb);
+               kfree(dev->dvb);
                dev->dvb = NULL;
        }