1c942fddfSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-or-later */
228cae868SHans Verkuil /*
3cf293a4fSAlexander A. Klimov  * Copyright (C) 2010-2013 Bluecherry, LLC <https://www.bluecherrydvr.com>
428cae868SHans Verkuil  *
528cae868SHans Verkuil  * Original author:
628cae868SHans Verkuil  * Ben Collins <bcollins@ubuntu.com>
728cae868SHans Verkuil  *
828cae868SHans Verkuil  * Additional work by:
928cae868SHans Verkuil  * John Brooks <john.brooks@bluecherry.net>
1028cae868SHans Verkuil  */
1128cae868SHans Verkuil 
1228cae868SHans Verkuil #ifndef __SOLO6X10_TW28_H
1328cae868SHans Verkuil #define __SOLO6X10_TW28_H
1428cae868SHans Verkuil 
1528cae868SHans Verkuil #include "solo6x10.h"
1628cae868SHans Verkuil 
1728cae868SHans Verkuil #define TW_NUM_CHIP				4
1828cae868SHans Verkuil #define TW_BASE_ADDR				0x28
1928cae868SHans Verkuil #define TW_CHIP_OFFSET_ADDR(n)			(TW_BASE_ADDR + (n))
2028cae868SHans Verkuil 
2128cae868SHans Verkuil /* tw2815 */
2228cae868SHans Verkuil #define TW_AV_STAT_ADDR				0x5a
2328cae868SHans Verkuil #define TW_HUE_ADDR(n)				(0x07 | ((n) << 4))
2428cae868SHans Verkuil #define TW_SATURATION_ADDR(n)			(0x08 | ((n) << 4))
2528cae868SHans Verkuil #define TW_CONTRAST_ADDR(n)			(0x09 | ((n) << 4))
2628cae868SHans Verkuil #define TW_BRIGHTNESS_ADDR(n)			(0x0a | ((n) << 4))
2728cae868SHans Verkuil #define TW_AUDIO_OUTPUT_VOL_ADDR		0x70
2828cae868SHans Verkuil #define TW_AUDIO_INPUT_GAIN_ADDR(n)		(0x60 + ((n > 1) ? 1 : 0))
2928cae868SHans Verkuil 
3028cae868SHans Verkuil /* tw286x */
3128cae868SHans Verkuil #define TW286x_AV_STAT_ADDR			0xfd
3228cae868SHans Verkuil #define TW286x_HUE_ADDR(n)			(0x06 | ((n) << 4))
3328cae868SHans Verkuil #define TW286x_SATURATIONU_ADDR(n)		(0x04 | ((n) << 4))
3428cae868SHans Verkuil #define TW286x_SATURATIONV_ADDR(n)		(0x05 | ((n) << 4))
3528cae868SHans Verkuil #define TW286x_CONTRAST_ADDR(n)			(0x02 | ((n) << 4))
3628cae868SHans Verkuil #define TW286x_BRIGHTNESS_ADDR(n)		(0x01 | ((n) << 4))
3728cae868SHans Verkuil #define TW286x_SHARPNESS(n)			(0x03 | ((n) << 4))
3828cae868SHans Verkuil #define TW286x_AUDIO_OUTPUT_VOL_ADDR		0xdf
3928cae868SHans Verkuil #define TW286x_AUDIO_INPUT_GAIN_ADDR(n)		(0xD0 + ((n > 1) ? 1 : 0))
4028cae868SHans Verkuil 
4128cae868SHans Verkuil int solo_tw28_init(struct solo_dev *solo_dev);
4228cae868SHans Verkuil 
4328cae868SHans Verkuil int tw28_set_ctrl_val(struct solo_dev *solo_dev, u32 ctrl, u8 ch, s32 val);
4428cae868SHans Verkuil int tw28_get_ctrl_val(struct solo_dev *solo_dev, u32 ctrl, u8 ch, s32 *val);
4528cae868SHans Verkuil bool tw28_has_sharpness(struct solo_dev *solo_dev, u8 ch);
4628cae868SHans Verkuil 
4728cae868SHans Verkuil u8 tw28_get_audio_gain(struct solo_dev *solo_dev, u8 ch);
4828cae868SHans Verkuil void tw28_set_audio_gain(struct solo_dev *solo_dev, u8 ch, u8 val);
4928cae868SHans Verkuil int tw28_get_video_status(struct solo_dev *solo_dev, u8 ch);
5028cae868SHans Verkuil 
5128cae868SHans Verkuil #if 0
5228cae868SHans Verkuil unsigned int tw2815_get_audio_status(struct SOLO *solo);
5328cae868SHans Verkuil void tw2815_Set_AudioOutVol(struct SOLO *solo, unsigned int u_val);
5428cae868SHans Verkuil #endif
5528cae868SHans Verkuil 
5628cae868SHans Verkuil #endif /* __SOLO6X10_TW28_H */
57