mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 09:19:34 +07:00
9120c0bea9
For at91 boards, there are different IPs for adc. Different IPs has different STARTUP & PRESCAL mask in ADC_MR. Signed-off-by: Josh Wu <josh.wu@atmel.com> Acked-by: Maxime Ripard <maxime.ripard@free-electrons.com> Signed-off-by: Jonathan Cameron <jic23@kernel.org>
66 lines
1.9 KiB
C
66 lines
1.9 KiB
C
/*
|
|
* 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
|
|
* @mr_prescal_mask: Mask of the PRESCAL field in the adc MR register
|
|
* @mr_startup_mask: Mask of the STARTUP field in the adc MR register
|
|
*/
|
|
struct at91_adc_reg_desc {
|
|
u8 channel_base;
|
|
u32 drdy_mask;
|
|
u8 status_register;
|
|
u8 trigger_register;
|
|
u32 mr_prescal_mask;
|
|
u32 mr_startup_mask;
|
|
};
|
|
|
|
/**
|
|
* 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
|