1. 08 Apr, 2013 24 commits
  2. 05 Apr, 2013 16 commits
    • Valentin Ilie's avatar
      staging: speakup: selection.c fix typo in comment · c6ac992b
      Valentin Ilie authored
      Replace disallocated with deallocated
      Signed-off-by: default avatarValentin Ilie <valentin.ilie@gmail.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c6ac992b
    • Ian Abbott's avatar
      staging: comedi: add comedi_clear_board_dev() · db210da2
      Ian Abbott authored
      Add local function `comedi_clear_board_dev()` as a safer alternative to
      `comedi_clear_board_minor()` when we already have a pointer to a `struct
      comedi_device`.  It uses the board minor device number stored in the
      `struct comedi_device` (which must have already been initialized) and
      only clears the entry in `comedi_board_minor_table[]` if it points to
      the specified `struct comedi_device`.  Rather than returning the old
      table entry, it returns `true` if the entry matched (and so has just
      been cleared) and returns `false` otherwise.
      
      Call `comedi_clear_board_dev()` instead of `comedi_clear_board_minor()`
      in `comedi_unlocked_ioctl()` (in the code that frees a dynamically
      allocated comedi device detached by the `COMEDI_DEVCONFIG` ioctl).  That
      ought to return `true` but check it just in case before freeing the
      device.  There is still a race condition here which needs to be dealt
      with once we've implemented reference counting for `struct
      comedi_device`s.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      db210da2
    • Ian Abbott's avatar
      staging: comedi: remove struct comedi_file_info · c6f5b4d5
      Ian Abbott authored
      `struct comedi_file_info` is no longer used so remove it.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c6f5b4d5
    • Ian Abbott's avatar
      staging: comedi: simplify comedi_board_minor_table[] · cb6b79de
      Ian Abbott authored
      `comedi_alloc_board_minor()` allocates and initializes a `struct
      comedi_file_info` and a `struct comedi_device`, and assigns a board
      minor device number (if there are any available), storing a pointer to
      the allocated `struct comedi_file_info` in
      `comedi_board_minor_table[minor]` where `minor` is the board minor
      device number.
      
      There is no longer anything useful in the `struct comedi_file_info`
      apart from the pointer to the `struct comedi_device` that was allocated,
      so the `struct comedi_file_info` is superfluous.
      
      Change `comedi_board_minor_table[]` to hold pointers to the actual
      `struct comedi_device`'s.  `comedi_alloc_board_minor()` no longer needs
      to allocate a `struct comedi_file_info`.  Replace
      `comedi_free_board_file_info()` with `comedi_free_board_dev()` with its
      parameter pointing to the `struct comedi_device` to be freed (there is
      no longer a `struct comedi_file_info` to be freed).
      
      There are consequential changes to `comedi_dev_from_board_minor()`,
      `comedi_clear_board_minor()` (which now returns a `struct comedi_device
      *`), `comedi_free_board_minor()`, `comedi_release_hardware_device()` and
      `comedi_unlocked_ioctl()` (when dealing with detachment of a dynamically
      allocated comedi device by the `COMEDI_DEVCONFIG` ioctl).
      
      `comedi_dev_from_file_info()` is no longer used as a result of the above
      changes so remove it.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      cb6b79de
    • Ian Abbott's avatar
      staging: comedi: simplify comedi_subdevice_minor_table[] · bd5b4173
      Ian Abbott authored
      `comedi_alloc_subdevice_minor()` allocates and initializes a `struct
      comedi_file_info` and assigns a subdevice minor device number (if there
      are any available), storing a pointer to the allocated `struct
      comedi_file_info` in `comedi_subdevice_minor_table[i]` where `i` is the
      array index corresponding to the subdevice minor device number (indexed
      by subdevice minor device number minus `COMEDI_NUM_BOARD_MINORS`).
      
      The information stored in the `struct comedi_file_info` can be derived
      from the subdevice structure (`struct comedi_subdevice`) itself, so the
      `struct comedi_file_info` is superfluous.
      
      Change `comedi_subdevice_minor_table[]` to hold pointers to the actual
      `struct comedi_subdevice`'s.  `comedi_alloc_subdevice_minor()` no longer
      needs to allocate a `struct comedi_file_info` and
      `comedi_free_subdevice_info()` no longer has a `struct comedi_file_info`
      to free.
      
      Replace `comedi_file_info_from_minor()` with
      `comedi_subdevice_from_minor()`, returning a (possibly NULL) pointer to
      a `struct comedi_subdevice` from the table.  This has knock-on effects
      for `comedi_dev_from_subdevice_minor()`, `comedi_read_subdevice()` and
      `comedi_write_subdevice()`.  In particular, `comedi_read_subdevice()`
      and `comedi_write_subdevice()` now need to check the subdevice flags to
      see if the determine whether to override the comedi device's default
      read/write subdevice.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      bd5b4173
    • Ian Abbott's avatar
      staging: comedi: remove comedi_file_info_from_board_minor() · dac59de2
      Ian Abbott authored
      Merge the code from `comedi_file_info_from_board_minor()` into
      `comedi_dev_from_board_minor()` and remove it since nothing else calls
      it.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      dac59de2
    • Ian Abbott's avatar
      staging: comedi: remove comedi_clear_subdevice_minor() · 0fcc9d48
      Ian Abbott authored
      Merge the code from `comedi_clear_subdevice_minor()` into
      `comedi_free_subdevice_minor()` and remove it since nothing else calls
      it.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      0fcc9d48
    • Ian Abbott's avatar
      staging: comedi: refactor comedi_dev_from_minor() · f3abc831
      Ian Abbott authored
      Refactor `comedi_dev_from_minor()` to call one of two new functions
      `comedi_dev_from_board_minor()` (for minor device numbers less than
      `COMEDI_NUM_BOARD_MINORS`) or `comedi_dev_from_subdevice_minor()` (for
      minor device numbers greater than or equal to `COMEDI_NUM_BOARD_MINORS`,
      which are subdevice minor device numbers).
      
      Remove `comedi_file_info_from_minor()` as it is no longer used.
      
      This is a step towards removing `struct comedi_file_info`.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      f3abc831
    • Ian Abbott's avatar
      staging: comedi: reduce use of struct comedi_file_info · 5e04c254
      Ian Abbott authored
      Since the parameters of `comedi_read_subdevice()` and
      `comedi_write_subdevice()` have changed, there is no longer a need to
      keep a local variable `struct comedi_file_info *info` hanging around in
      the file operation functions and device attribute access functions.
      Remove the variable from those function and replace the call sequence
      `info = comedi_file_info_from_minor(minor)`,  `dev =
      comedi_dev_from_file_info(info)` with the simpler `dev =
      comedi_dev_from_minor(minor)`.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      5e04c254
    • Ian Abbott's avatar
      staging: comedi: change comedi_read/write_subdevice() parameters · da56fdc6
      Ian Abbott authored
      `comedi_read_subdevice()` and `comedi_write_subdevice()` currently take
      a single parameter pointing to a `struct comedi_file_info`.  I'm trying
      to get rid of `struct comedi_file_info` so as part of that plan,
      `comedi_read_subdevice()` and `comedi_write_subdevice()` need to change.
      Change them to take two parameters: a pointer to a `struct
      comedi_device` and a minor device number.  If the minor device number is
      a "board" minor device number (`minor < COMEDI_NUM_BOARD_MINORS`) we'll
      always return the default read or write subdevice.  If the minor device
      number if a "subdevice" minor device number a different read or write
      subdevice may be returned.  In that case, use the subdevice minor device
      number to look up the information about whether the default read or
      write subdevice needs to be overridden.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      da56fdc6
    • Ian Abbott's avatar
      staging: comedi: use minor device number in attribute functions · c88db469
      Ian Abbott authored
      The comedi device attribute functions such as
      `show_max_read_buffer_kb()` call `dev_get_drvdata()` to get a pointer to
      a `struct comedi_file_info` from the private driver data field of class
      device.  Change them to use the minor device number to look up this
      pointer value so they behave more like the file operation functions.
      Check the pointer is non-NULL as the entry in the minor device table
      could have been set to NULL.  Note that there is still a race condition
      in the use of this pointer value after acquiring the mutex which needs
      to be dealt with once reference counting has been implemented for comedi
      devices.
      
      The calls to `dev_set_drvdata()` from `comedi_alloc_board_minor()` and
      `comedi_alloc_subdevice_minor()` are no longer needed so remove them.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c88db469
    • Ian Abbott's avatar
      staging: comedi: get mutex before subdevice in attribute functions · 7f4656c5
      Ian Abbott authored
      The comedi device attribute functions such as
      `show_read_buffer_kb()` or `show_write_buffer_kb()` call
      `comedi_read_subdevice()` or `comedi_write_subdevice()` without
      acquiring the comedi device's mutex first, although the functions do
      acquire the mutex afterwards.  Change them to acquire the mutex first.
      This is consistent with most of the comedi device file operation
      functions (apart from `comedi_read()` and `comedi_write()` which
      probably need looking at).
      
      Despite the use of the mutex, there are still race conditions as the
      `struct comedi_file_info *info` variable value set before acquiring the
      mutex could be stale after acquiring the mutex.  This problem will be
      dealt with once reference counting has been implemented for the comedi
      devices.
      
      This patch also adds local variable `struct comedi_device *dev` to the
      functions to reduce the use of the `info` variable a little bit.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      7f4656c5
    • Ian Abbott's avatar
      staging: comedi: rename dev parameter of device attribute functions · 7a4e5a9f
      Ian Abbott authored
      Most of the comedi core uses the identifier `dev` to point to a `struct
      comedi_device`.  The device sysfs attribute functions such as
      `show_max_read_buffer_kb()` use the parameter id `dev` to point to a
      `struct device`.  Rename the parameter to `csdev` for "class device" for
      consistency with the functions that call `device_create()` to create
      these class devices (`comedi_alloc_board_minor()` and
      `comedi_alloc_subdevice_minor()`).
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      7a4e5a9f
    • Ian Abbott's avatar
      staging: comedi: remove hardware_device from struct comedi_device_info · 0918e595
      Ian Abbott authored
      The `hardware_device` member of `struct comedi_device_info` is only set
      to point to a hardware device by the auto-configuration code (specifically
      `comedi_alloc_board_minor() with a non-NULL `hardware_device` parameter)
      so that it can be found again by the auto-unconfiguration code
      (specifically `comedi_release_hardware_device()`).  However, as
      `info->device->hw_dev` (where `info` is a pointer to the `struct
      comedi_device_info`) is set to the same value as `info->hardware_device`
      (by calling `comedi_set_hw_dev()` with the same hardware device pointer)
      we can look for that instead, so there is no need for the
      `hardware_device` member any more.  Get rid of it.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      0918e595
    • Ian Abbott's avatar
      staging: comedi: remove comedi_clear_minor() · ea1cc397
      Ian Abbott authored
      `comedi_clear_minor()` calls either `comedi_clear_board_minor()` or
      `comedi_clear_subdevice_minor()` depending on its minor device number
      parameter.  The one it calls only depends on where it is called from, so
      bypass the calls to `comedi_clear_minor()` and remove it.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      ea1cc397
    • Ian Abbott's avatar
      staging: comedi: separate board and subdevice minor tables · 5b7dba1b
      Ian Abbott authored
      The comedi core reserves minor device numbers from 0 to
      `COMEDI_NUM_BOARD_MINORS - 1` (0 to 0x30 - 1) for the main comedi
      "board" devices and reserves minor device numbers from
      `COMEDI_NUM_BOARD_MINORS` to `COMEDI_NUM_MINORS - 1` (0x30 to 0x100 - 1)
      for comedi subdevices (or at least those that claim to support
      asynchronous comedi commands).  There is an array
      `comedi_file_info_table[COMEDI_NUM_MINORS]` used to hold pointers to
      information for each board minor device number and subdevice minor
      device number that has been allocated (with NULL pointers for those not
      allocated), along with a protective lock `comedi_file_info_table_lock`.
      
      Since the ranges of board minor device numbers and subdevice minor
      device numbers do not overlap, we can use separate tables and separate
      locks for the different types of minor device numbers.  This will allow
      us to use different pointer types for the elements of each table in the
      future without just using a generic `void *`.  (At the moment, the table
      elements point to a `struct comedi_file_info` allocated dynamically for
      each allocated board minor device or subdevice minor device, but I plan
      to get rid of that data structure.)
      
      Replace `comedi_file_info_table[COMEDI_NUM_MINORS]` with two new arrays
      of the same type, `comedi_board_minor_table[COMEDI_NUM_BOARD_MINORS]`
      for board minors, and
      `comedi_subdevice_minor_table[COMEDI_NUM_SUBDEVICE_MINORS]` for
      subdevice minors (where `COMEDI_NUM_SUBDEVICE_MINORS` is
      `COMEDI_NUM_MINORS - COMEDI_NUM_BOARD_MINORS`).
      `comedi_subdevice_minor_table[]` is indexed by the subdevice minor
      number minus `COMEDI_NUM_BOARD_MINORS` since `COMEDI_NUM_BOARD_MINORS`
      is the first valid subdevice minor number.
      
      Replace `comedi_file_info_table_lock` with
      `comedi_board_minor_table_lock` for board minors and
      `comedi_subdevice_minor_table_lock` for subdevice minors.
      
      Refactor `comedi_clear_minor()` to call one of two new functions
      `comedi_clear_board_minor()` and `comedi_clear_subdevice_minor()`
      depending on the minor device number passed as a parameter.  Similarly,
      refactor `comedi_file_info_from_minor()` to call one of two new
      functions `comedi_file_info_from_board_minor()` and
      `comedi_file_info_from_subdevice_minor()` depending on the minor device
      number parameter.
      Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
      Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      5b7dba1b