staging: comedi: das_08: absorb i8254_struct into the private data
authorH Hartley Sweeten <hartleys@visionengravers.com>
Fri, 29 Jun 2012 18:02:59 +0000 (11:02 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 6 Jul 2012 22:46:08 +0000 (15:46 -0700)
The i8254_struct now only contains the iobase address used to
read/write the 8254 timer device. Move that variable into the
das08 private data struct and remove the i8254_struct.

Signed-off-by: H Hartley Sweeten <hsweeten@visionengravers.com>
Cc: Ian Abbott <abbotti@mev.co.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/comedi/drivers/das08.c
drivers/staging/comedi/drivers/das08.h

index 20f79b7b4efc2b2cada96c5188bdce88492e0795..874e02e47668e60a024b350a72822894be801f1a 100644 (file)
@@ -433,13 +433,14 @@ das08ao_ao_winsn(struct comedi_device *dev, struct comedi_subdevice *s,
        return n;
 }
 
-static void i8254_initialize(struct i8254_struct *st)
+static void i8254_initialize(struct comedi_device *dev)
 {
+       struct das08_private_struct *devpriv = dev->private;
        unsigned int mode = I8254_MODE0 | I8254_BINARY;
        int i;
 
        for (i = 0; i < 3; ++i)
-               i8254_set_mode(st->iobase, 0, i, mode);
+               i8254_set_mode(devpriv->i8254_iobase, 0, i, mode);
 }
 
 static int das08_counter_read(struct comedi_device *dev,
@@ -447,10 +448,9 @@ static int das08_counter_read(struct comedi_device *dev,
                              struct comedi_insn *insn, unsigned int *data)
 {
        struct das08_private_struct *devpriv = dev->private;
-       struct i8254_struct *st = &devpriv->i8254;
        int chan = insn->chanspec;
 
-       data[0] = i8254_read(st->iobase, 0, chan);
+       data[0] = i8254_read(devpriv->i8254_iobase, 0, chan);
        return 1;
 }
 
@@ -459,10 +459,9 @@ static int das08_counter_write(struct comedi_device *dev,
                               struct comedi_insn *insn, unsigned int *data)
 {
        struct das08_private_struct *devpriv = dev->private;
-       struct i8254_struct *st = &devpriv->i8254;
        int chan = insn->chanspec;
 
-       i8254_write(st->iobase, 0, chan, data[0]);
+       i8254_write(devpriv->i8254_iobase, 0, chan, data[0]);
        return 1;
 }
 
@@ -471,7 +470,6 @@ static int das08_counter_config(struct comedi_device *dev,
                                struct comedi_insn *insn, unsigned int *data)
 {
        struct das08_private_struct *devpriv = dev->private;
-       struct i8254_struct *st = &devpriv->i8254;
        int chan = insn->chanspec;
 
        if (insn->n != 2)
@@ -479,10 +477,10 @@ static int das08_counter_config(struct comedi_device *dev,
 
        switch (data[0]) {
        case INSN_CONFIG_SET_COUNTER_MODE:
-               i8254_set_mode(st->iobase, 0, chan, data[1]);
+               i8254_set_mode(devpriv->i8254_iobase, 0, chan, data[1]);
                break;
        case INSN_CONFIG_8254_READ_STATUS:
-               data[1] = i8254_status(st->iobase, 0, chan);
+               data[1] = i8254_status(devpriv->i8254_iobase, 0, chan);
                break;
        default:
                return -EINVAL;
@@ -846,9 +844,9 @@ int das08_common_attach(struct comedi_device *dev, unsigned long iobase)
                s->insn_read = das08_counter_read;
                s->insn_write = das08_counter_write;
                s->insn_config = das08_counter_config;
-               /* Set-up the 8254 structure */
-               devpriv->i8254.iobase = iobase + thisboard->i8254_offset;
-               i8254_initialize(&devpriv->i8254);
+
+               devpriv->i8254_iobase = iobase + thisboard->i8254_offset;
+               i8254_initialize(dev);
        } else {
                s->type = COMEDI_SUBD_UNUSED;
        }
index ee3cf4b9a9ada8e56c896c0ddc1a6c1823eb80f7..27b6d4ec9032fd4c283c9067f00cb1c0d6c16375 100644 (file)
@@ -49,17 +49,13 @@ struct das08_board_struct {
        unsigned int iosize;    /*  number of ioports used */
 };
 
-struct i8254_struct {
-       unsigned int iobase;
-};
-
 struct das08_private_struct {
        unsigned int do_mux_bits;       /*  bits for do/mux register on boards without separate do register */
        unsigned int do_bits;   /*  bits for do register on boards with register dedicated to digital out only */
        const unsigned int *pg_gainlist;
        struct pci_dev *pdev;   /*  struct for pci-das08 */
        unsigned int pci_iobase;        /*  additional base address for pci-das08 */
-       struct i8254_struct i8254;
+       unsigned int i8254_iobase;
 };
 
 #define NUM_DAS08_CS_BOARDS 2