2013-01-12 00:45:10 +00:00
|
|
|
#ifndef __EPM_ADC_H
|
|
|
|
#define __EPM_ADC_H
|
|
|
|
|
|
|
|
#include <linux/i2c.h>
|
|
|
|
|
|
|
|
struct epm_chan_request {
|
|
|
|
/* EPM ADC device index. 0 - ADC1, 1 - ADC2 */
|
|
|
|
uint32_t device_idx;
|
|
|
|
/* Channel number within the EPM ADC device */
|
|
|
|
uint32_t channel_idx;
|
|
|
|
/* The data meaningful for each individual channel whether it is
|
|
|
|
* voltage, current etc. */
|
|
|
|
int32_t physical;
|
|
|
|
};
|
|
|
|
|
2012-09-04 15:23:43 +00:00
|
|
|
struct epm_psoc_init_resp {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t version;
|
|
|
|
uint8_t compatible_ver;
|
|
|
|
uint8_t firm_ver[3];
|
|
|
|
uint8_t num_dev;
|
|
|
|
uint8_t num_channel;
|
2012-09-04 15:23:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_channel_configure {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t device_num;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t channel_num;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_set_avg {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t avg_period;
|
|
|
|
uint8_t return_code;
|
2012-09-04 15:23:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_get_data {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t dev_num;
|
|
|
|
uint8_t chan_num;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t timestamp_resp_value;
|
|
|
|
uint32_t reading_value;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_get_buffered_data {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t dev_num;
|
|
|
|
uint8_t status_mask;
|
|
|
|
uint8_t chan_idx;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t chan_mask;
|
|
|
|
uint32_t timestamp_start;
|
|
|
|
uint32_t timestamp_end;
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t buff_data[48];
|
2012-09-04 15:23:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_system_time_stamp {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t timestamp;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_set_channel {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t dev_num;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t channel_mask;
|
|
|
|
};
|
|
|
|
|
2012-12-06 22:51:27 +00:00
|
|
|
struct result_buffer {
|
|
|
|
uint32_t channel;
|
|
|
|
uint32_t avg_buffer_sample;
|
|
|
|
uint32_t result;
|
|
|
|
};
|
|
|
|
|
2012-09-04 15:23:43 +00:00
|
|
|
struct epm_psoc_get_avg_buffered_switch_data {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t status;
|
|
|
|
uint32_t timestamp_start;
|
|
|
|
uint32_t channel_mask;
|
|
|
|
uint8_t avg_data[54];
|
|
|
|
struct result_buffer data[54];
|
2012-09-04 15:23:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_set_channel_switch {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t dev;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t delay;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct epm_psoc_set_vadc {
|
2012-12-06 22:51:27 +00:00
|
|
|
uint8_t cmd;
|
|
|
|
uint8_t vadc_dev;
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t vadc_voltage;
|
|
|
|
};
|
|
|
|
|
2013-01-12 00:45:10 +00:00
|
|
|
struct epm_chan_properties {
|
2012-09-04 15:23:43 +00:00
|
|
|
uint32_t resistorvalue;
|
2013-01-12 00:45:10 +00:00
|
|
|
uint32_t gain;
|
|
|
|
};
|
|
|
|
|
2012-12-06 22:51:27 +00:00
|
|
|
#ifdef __KERNEL__
|
2013-01-12 00:45:10 +00:00
|
|
|
struct epm_adc_platform_data {
|
|
|
|
struct epm_chan_properties *channel;
|
|
|
|
uint32_t num_channels;
|
|
|
|
uint32_t num_adc;
|
|
|
|
uint32_t chan_per_adc;
|
|
|
|
uint32_t chan_per_mux;
|
|
|
|
struct i2c_board_info epm_i2c_board_info;
|
|
|
|
uint32_t bus_id;
|
|
|
|
uint32_t gpio_expander_base_addr;
|
|
|
|
};
|
2012-07-11 17:13:30 +00:00
|
|
|
#endif
|
2013-01-12 00:45:10 +00:00
|
|
|
|
|
|
|
#define EPM_ADC_IOCTL_CODE 0x91
|
|
|
|
|
|
|
|
#define EPM_ADC_REQUEST _IOWR(EPM_ADC_IOCTL_CODE, 1, \
|
|
|
|
struct epm_chan_request)
|
|
|
|
|
|
|
|
#define EPM_ADC_INIT _IOR(EPM_ADC_IOCTL_CODE, 2, \
|
|
|
|
uint32_t)
|
|
|
|
|
|
|
|
#define EPM_ADC_DEINIT _IOR(EPM_ADC_IOCTL_CODE, 3, \
|
|
|
|
uint32_t)
|
2012-09-04 15:23:43 +00:00
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_INIT _IOR(EPM_ADC_IOCTL_CODE, 4, \
|
|
|
|
struct epm_psoc_init_resp)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_CHANNEL_ENABLE _IOWR(EPM_ADC_IOCTL_CODE, 5, \
|
|
|
|
struct epm_psoc_channel_configure)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_CHANNEL_DISABLE _IOWR(EPM_ADC_IOCTL_CODE, 6, \
|
|
|
|
struct epm_psoc_channel_configure)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_SET_AVERAGING _IOWR(EPM_ADC_IOCTL_CODE, 7, \
|
|
|
|
struct epm_psoc_set_avg)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_GET_LAST_MEASUREMENT _IOWR(EPM_ADC_IOCTL_CODE, 8, \
|
|
|
|
struct epm_psoc_get_data)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_GET_BUFFERED_DATA _IOWR(EPM_ADC_IOCTL_CODE, 9, \
|
|
|
|
struct epm_psoc_get_buffered_data)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_GET_SYSTEM_TIMESTAMP _IOWR(EPM_ADC_IOCTL_CODE, 10, \
|
|
|
|
struct epm_psoc_system_time_stamp)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_SET_SYSTEM_TIMESTAMP _IOWR(EPM_ADC_IOCTL_CODE, 11, \
|
|
|
|
struct epm_psoc_system_time_stamp)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_GET_AVERAGE_DATA _IOWR(EPM_ADC_IOCTL_CODE, 12, \
|
|
|
|
struct epm_psoc_get_avg_buffered_switch_data)
|
|
|
|
|
|
|
|
#define EPM_PSOC_SET_CHANNEL_SWITCH _IOWR(EPM_ADC_IOCTL_CODE, 13, \
|
|
|
|
struct epm_psoc_set_channel_switch)
|
|
|
|
|
|
|
|
#define EPM_PSOC_CLEAR_BUFFER _IOWR(EPM_ADC_IOCTL_CODE, 14, \
|
|
|
|
uint32_t)
|
|
|
|
|
|
|
|
#define EPM_PSOC_ADC_SET_VADC_REFERENCE _IOWR(EPM_ADC_IOCTL_CODE, 15, \
|
|
|
|
struct epm_psoc_set_vadc)
|
|
|
|
|
2013-01-12 00:45:10 +00:00
|
|
|
#endif /* __EPM_ADC_H */
|