| /* |
| * Copyright (C) 2011 Free Electrons |
| * |
| * Licensed under the GPLv2 or later. |
| */ |
| |
| #ifndef _AT91_ADC_H_ |
| #define _AT91_ADC_H_ |
| |
| /** |
| * struct at91_adc_reg_desc - Various informations relative to registers |
| * @channel_base: Base offset for the channel data registers |
| * @drdy_mask: Mask of the DRDY field in the relevant registers |
| (Interruptions registers mostly) |
| * @status_register: Offset of the Interrupt Status Register |
| * @trigger_register: Offset of the Trigger setup register |
| */ |
| struct at91_adc_reg_desc { |
| u8 channel_base; |
| u32 drdy_mask; |
| u8 status_register; |
| u8 trigger_register; |
| }; |
| |
| /** |
| * struct at91_adc_trigger - description of triggers |
| * @name: name of the trigger advertised to the user |
| * @value: value to set in the ADC's trigger setup register |
| to enable the trigger |
| * @is_external: Does the trigger rely on an external pin? |
| */ |
| struct at91_adc_trigger { |
| const char *name; |
| u8 value; |
| bool is_external; |
| }; |
| |
| /** |
| * struct at91_adc_data - platform data for ADC driver |
| * @channels_used: channels in use on the board as a bitmask |
| * @num_channels: global number of channels available on the board |
| * @registers: Registers definition on the board |
| * @startup_time: startup time of the ADC in microseconds |
| * @trigger_list: Triggers available in the ADC |
| * @trigger_number: Number of triggers available in the ADC |
| * @use_external_triggers: does the board has external triggers availables |
| * @vref: Reference voltage for the ADC in millivolts |
| */ |
| struct at91_adc_data { |
| unsigned long channels_used; |
| u8 num_channels; |
| struct at91_adc_reg_desc *registers; |
| u8 startup_time; |
| struct at91_adc_trigger *trigger_list; |
| u8 trigger_number; |
| bool use_external_triggers; |
| u16 vref; |
| }; |
| |
| extern void __init at91_add_device_adc(struct at91_adc_data *data); |
| #endif |