4  * @brief Meilhaus ME-1600 analog output subdevice class.
 
   5  * @note Copyright (C) 2007 Meilhaus Electronic GmbH (support@meilhaus.de)
 
   6  * @author Guenter Gebhardt
 
  10  * Copyright (C) 2007 Meilhaus Electronic GmbH (support@meilhaus.de)
 
  12  * This file is free software; you can redistribute it and/or modify
 
  13  * it under the terms of the GNU General Public License as published by
 
  14  * the Free Software Foundation; either version 2 of the License, or
 
  15  * (at your option) any later version.
 
  17  * This program is distributed in the hope that it will be useful,
 
  18  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  20  * GNU General Public License for more details.
 
  22  * You should have received a copy of the GNU General Public License
 
  23  * along with this program; if not, write to the Free Software
 
  24  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
  30 # include <linux/version.h>
 
  31 # include "mesubdevice.h"
 
  35 #  define ME1600_MAX_RANGES     2       /**< Specifies the maximum number of ranges in me1600_ao_subdevice_t::u_ranges und me1600_ao_subdevice_t::i_ranges. */
 
  38  * @brief Defines a entry in the range table.
 
  40 typedef struct me1600_ao_range_entry {
 
  43 } me1600_ao_range_entry_t;
 
  45 typedef struct me1600_ao_timeout {
 
  46         unsigned long start_time;
 
  48 } me1600_ao_timeout_t;
 
  50 typedef struct me1600_ao_shadow {
 
  52         unsigned long *registry;
 
  55         uint16_t synchronous;                                                                   /**< Synchronization list. */
 
  56         uint16_t trigger;                                                                               /**< Synchronization flag. */
 
  59 typedef enum ME1600_AO_STATUS {
 
  61         ao_status_single_configured,
 
  68  * @brief The ME-1600 analog output subdevice class.
 
  70 typedef struct me1600_ao_subdevice {
 
  72         me_subdevice_t base;                                                                    /**< The subdevice base class. */
 
  75         int ao_idx;                                                                                             /**< The index of the analog output subdevice on the device. */
 
  77         spinlock_t subdevice_lock;                                                              /**< Spin lock to protect the subdevice from concurrent access. */
 
  78         spinlock_t *config_regs_lock;                                                   /**< Spin lock to protect configuration registers from concurrent access. */
 
  80         int u_ranges_count;                                                                             /**< The number of voltage ranges available on this subdevice. */
 
  81         me1600_ao_range_entry_t u_ranges[ME1600_MAX_RANGES];    /**< Array holding the voltage ranges on this subdevice. */
 
  82         int i_ranges_count;                                                                             /**< The number of current ranges available on this subdevice. */
 
  83         me1600_ao_range_entry_t i_ranges[ME1600_MAX_RANGES];    /**< Array holding the current ranges on this subdevice. */
 
  86         unsigned long uni_bi_reg;                                                               /**< Register for switching between unipoar and bipolar output mode. */
 
  87         unsigned long i_range_reg;                                                              /**< Register for switching between ranges. */
 
  88         unsigned long sim_output_reg;                                                   /**< Register used in order to update all channels simultaneously. */
 
  89         unsigned long current_on_reg;                                                   /**< Register enabling current output on the fourth subdevice. */
 
  91         unsigned long reg_base;
 
  94         ME1600_AO_STATUS status;
 
  95         me1600_ao_shadow_t *ao_regs_shadows;                                    /**< Addresses and shadows of output's registers. */
 
  96         spinlock_t *ao_shadows_lock;                                                    /**< Protects the shadow's struct. */
 
  97         int mode;                                                                                               /**< Mode in witch output should works. */
 
  98         wait_queue_head_t wait_queue;                                                   /**< Wait queue to put on tasks waiting for data to arrive. */
 
  99         me1600_ao_timeout_t timeout;                                                    /**< The timeout for start in blocking and non-blocking mode. */
 
 100         struct workqueue_struct *me1600_workqueue;
 
 101         struct delayed_work ao_control_task;
 
 103         volatile int ao_control_task_flag;                                              /**< Flag controling reexecuting of control task */
 
 104 } me1600_ao_subdevice_t;
 
 107  * @brief The constructor to generate a subdevice template instance.
 
 109  * @param reg_base The register base address of the device as returned by the PCI BIOS.
 
 110  * @param ao_idx The index of the analog output subdevice on the device.
 
 111  * @param current Flag indicating that analog output with #ao_idx of 3 is capable of current output.
 
 112  * @param config_regs_lock Pointer to spin lock protecting the configuration registers and from concurrent access.
 
 114  * @return Pointer to new instance on success.\n
 
 117 me1600_ao_subdevice_t *me1600_ao_constructor(uint32_t reg_base,
 
 120                                              spinlock_t * config_regs_lock,
 
 121                                              spinlock_t * ao_shadows_lock,
 
 124                                              struct workqueue_struct
 
 128 #endif //_ME1600_AO_H_