152 lines
4.5 KiB
C

/****************************************************************************
****************************************************************************
***
*** This header was automatically generated from a Linux kernel header
*** of the same name, to make information necessary for userspace to
*** call into the kernel available to libc. It contains only constants,
*** structures, and macros generated from the original header, and thus,
*** contains no copyrightable information.
***
****************************************************************************
****************************************************************************/
#ifndef __SPI_AIC3254_H__
#define __SPI_AIC3254_H__
#include <linux/ioctl.h>
typedef struct _CODEC_SPI_CMD {
unsigned char act;
unsigned char reg;
unsigned char data;
} CODEC_SPI_CMD;
typedef struct _CODEC_SPI_CMD_PARAM {
CODEC_SPI_CMD *data;
unsigned int len;
} CODEC_SPI_CMD_PARAM;
struct AIC3254_PARAM {
unsigned int row_num;
unsigned int col_num;
void *cmd_data;
};
struct CODEC_CFG {
unsigned char tb_idx;
unsigned char index;
};
#define AIC3254_IOCTL_MAGIC 's'
#define AIC3254_SET_TX_PARAM _IOW(AIC3254_IOCTL_MAGIC, 0x10, unsigned)
#define AIC3254_SET_RX_PARAM _IOW(AIC3254_IOCTL_MAGIC, 0x11, unsigned)
#define AIC3254_CONFIG_TX _IOW(AIC3254_IOCTL_MAGIC, 0x12, unsigned int)
#define AIC3254_CONFIG_RX _IOW(AIC3254_IOCTL_MAGIC, 0x13, unsigned int)
#define AIC3254_SET_DSP_PARAM _IOW(AIC3254_IOCTL_MAGIC, 0x20, unsigned)
#define AIC3254_CONFIG_MEDIA _IOW(AIC3254_IOCTL_MAGIC, 0x21, unsigned int)
#define AIC3254_CONFIG_VOICE _IOW(AIC3254_IOCTL_MAGIC, 0x22, unsigned int)
#define AIC3254_CONFIG_VOLUME_L _IOW(AIC3254_IOCTL_MAGIC, 0x23, unsigned int)
#define AIC3254_CONFIG_VOLUME_R _IOW(AIC3254_IOCTL_MAGIC, 0x24, unsigned int)
#define AIC3254_POWERDOWN _IOW(AIC3254_IOCTL_MAGIC, 0x25, unsigned int)
#define AIC3254_LOOPBACK _IOW(AIC3254_IOCTL_MAGIC, 0x26, unsigned int)
#define AIC3254_DUMP_PAGES _IOW(AIC3254_IOCTL_MAGIC, 0x30, unsigned int)
#define AIC3254_READ_REG _IOWR(AIC3254_IOCTL_MAGIC, 0x31, unsigned)
#define AIC3254_WRITE_REG _IOW(AIC3254_IOCTL_MAGIC, 0x32, unsigned)
#define AIC3254_RESET _IOW(AIC3254_IOCTL_MAGIC, 0x33, unsigned int)
#define AIC3254_MAX_PAGES 255
#define AIC3254_MAX_REGS 128
#define AIC3254_MAX_RETRY 10
#define IO_CTL_ROW_MAX 64
#define IO_CTL_COL_MAX 1024
#define MINIDSP_ROW_MAX 32
#define MINIDSP_COL_MAX 16384
enum aic3254_uplink_mode {
INITIAL = 0,
CALL_UPLINK_IMIC_RECEIVER = 1,
CALL_UPLINK_EMIC_HEADSET,
CALL_UPLINK_IMIC_HEADSET,
CALL_UPLINK_IMIC_SPEAKER,
CALL_UPLINK_IMIC_RECEIVER_DUALMIC,
CALL_UPLINK_EMIC_HEADSET_DUALMIC,
CALL_UPLINK_IMIC_SPEAKER_DUALMIC,
CALL_UPLINK_IMIC_RECIVER_TESTSIM,
CALL_UPLINK_EMIC_HEADSET_TESTSIM,
CALL_UPLINK_IMIC_SPEAKER_TESTSIM,
VOICERECORD_IMIC = 15,
VOICERECORD_EMIC,
VIDEORECORD_IMIC,
VIDEORECORD_EMIC,
VOICERECOGNITION_IMIC,
VOICERECOGNITION_EMIC,
FM_IN_SPEAKER,
FM_IN_HEADSET,
TTY_IN_HCO,
TTY_IN_VCO,
TTY_IN_FULL,
UPLINK_OFF = 29,
UPLINK_WAKEUP,
POWER_OFF,
SLEEP_WITH_HP_IN,
VOICERECORD_IMIC_PLAYBACK_SPEAKER,
VOICERECORD_EMIC_PLAYBACK_HEADSET,
VOICERECORD_IMIC_PLAYBACK_HEADSET,
};
enum aic3254_downlink_mode {
CALL_DOWNLINK_IMIC_RECEIVER = 1,
CALL_DOWNLINK_EMIC_HEADSET,
CALL_DOWNLINK_IMIC_HEADSET,
CALL_DOWNLINK_IMIC_SPEAKER,
CALL_DOWNLINK_IMIC_RECEIVER_DUALMIC,
CALL_DOWNLINK_EMIC_HEADSET_DUALMIC,
CALL_DOWNLINK_IMIC_SPEAKER_DUALMIC,
CALL_DOWNLINK_IMIC_RECIVER_TESTSIM,
CALL_DOWNLINK_EMIC_HEADSET_TESTSIM,
CALL_DOWNLINK_IMIC_SPEAKER_TESTSIM,
PLAYBACK_RECEIVER,
PLAYBACK_HEADSET,
PLAYBACK_SPEAKER = 13,
RING_HEADSET_SPEAKER,
PLAYBACK_SPEAKER_ALT,
USB_AUDIO,
FM_OUT_SPEAKER = 21,
FM_OUT_HEADSET,
TTY_OUT_HCO,
TTY_OUT_VCO,
TTY_OUT_FULL,
MUSE,
HAC,
LPM_IMIC_RECEIVER,
DOWNLINK_OFF = 29,
DOWNLINK_WAKEUP,
};
struct aic3254_ctl_ops {
void (*tx_amp_enable)(int en);
void (*rx_amp_enable)(int en);
int (*panel_sleep_in)(void);
void (*reset_3254)(void);
void (*spibus_enable)(int en);
CODEC_SPI_CMD_PARAM *downlink_off;
CODEC_SPI_CMD_PARAM *uplink_off;
CODEC_SPI_CMD_PARAM *downlink_on;
CODEC_SPI_CMD_PARAM *uplink_on;
CODEC_SPI_CMD_PARAM *lb_dsp_init;
CODEC_SPI_CMD_PARAM *lb_downlink_receiver;
CODEC_SPI_CMD_PARAM *lb_downlink_speaker;
CODEC_SPI_CMD_PARAM *lb_downlink_headset;
CODEC_SPI_CMD_PARAM *lb_uplink_imic;
CODEC_SPI_CMD_PARAM *lb_uplink_emic;
CODEC_SPI_CMD_PARAM *lb_receiver_imic;
CODEC_SPI_CMD_PARAM *lb_speaker_imic;
CODEC_SPI_CMD_PARAM *lb_headset_emic;
CODEC_SPI_CMD_PARAM *lb_receiver_bmic;
CODEC_SPI_CMD_PARAM *lb_speaker_bmic;
CODEC_SPI_CMD_PARAM *lb_headset_bmic;
};
#endif