162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2010-2013 Bluecherry, LLC <https://www.bluecherrydvr.com> 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Original author: 662306a36Sopenharmony_ci * Ben Collins <bcollins@ubuntu.com> 762306a36Sopenharmony_ci * 862306a36Sopenharmony_ci * Additional work by: 962306a36Sopenharmony_ci * John Brooks <john.brooks@bluecherry.net> 1062306a36Sopenharmony_ci */ 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#ifndef __SOLO6X10_TW28_H 1362306a36Sopenharmony_ci#define __SOLO6X10_TW28_H 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include "solo6x10.h" 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#define TW_NUM_CHIP 4 1862306a36Sopenharmony_ci#define TW_BASE_ADDR 0x28 1962306a36Sopenharmony_ci#define TW_CHIP_OFFSET_ADDR(n) (TW_BASE_ADDR + (n)) 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci/* tw2815 */ 2262306a36Sopenharmony_ci#define TW_AV_STAT_ADDR 0x5a 2362306a36Sopenharmony_ci#define TW_HUE_ADDR(n) (0x07 | ((n) << 4)) 2462306a36Sopenharmony_ci#define TW_SATURATION_ADDR(n) (0x08 | ((n) << 4)) 2562306a36Sopenharmony_ci#define TW_CONTRAST_ADDR(n) (0x09 | ((n) << 4)) 2662306a36Sopenharmony_ci#define TW_BRIGHTNESS_ADDR(n) (0x0a | ((n) << 4)) 2762306a36Sopenharmony_ci#define TW_AUDIO_OUTPUT_VOL_ADDR 0x70 2862306a36Sopenharmony_ci#define TW_AUDIO_INPUT_GAIN_ADDR(n) (0x60 + ((n > 1) ? 1 : 0)) 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci/* tw286x */ 3162306a36Sopenharmony_ci#define TW286x_AV_STAT_ADDR 0xfd 3262306a36Sopenharmony_ci#define TW286x_HUE_ADDR(n) (0x06 | ((n) << 4)) 3362306a36Sopenharmony_ci#define TW286x_SATURATIONU_ADDR(n) (0x04 | ((n) << 4)) 3462306a36Sopenharmony_ci#define TW286x_SATURATIONV_ADDR(n) (0x05 | ((n) << 4)) 3562306a36Sopenharmony_ci#define TW286x_CONTRAST_ADDR(n) (0x02 | ((n) << 4)) 3662306a36Sopenharmony_ci#define TW286x_BRIGHTNESS_ADDR(n) (0x01 | ((n) << 4)) 3762306a36Sopenharmony_ci#define TW286x_SHARPNESS(n) (0x03 | ((n) << 4)) 3862306a36Sopenharmony_ci#define TW286x_AUDIO_OUTPUT_VOL_ADDR 0xdf 3962306a36Sopenharmony_ci#define TW286x_AUDIO_INPUT_GAIN_ADDR(n) (0xD0 + ((n > 1) ? 1 : 0)) 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ciint solo_tw28_init(struct solo_dev *solo_dev); 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ciint tw28_set_ctrl_val(struct solo_dev *solo_dev, u32 ctrl, u8 ch, s32 val); 4462306a36Sopenharmony_ciint tw28_get_ctrl_val(struct solo_dev *solo_dev, u32 ctrl, u8 ch, s32 *val); 4562306a36Sopenharmony_cibool tw28_has_sharpness(struct solo_dev *solo_dev, u8 ch); 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ciu8 tw28_get_audio_gain(struct solo_dev *solo_dev, u8 ch); 4862306a36Sopenharmony_civoid tw28_set_audio_gain(struct solo_dev *solo_dev, u8 ch, u8 val); 4962306a36Sopenharmony_ciint tw28_get_video_status(struct solo_dev *solo_dev, u8 ch); 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci#if 0 5262306a36Sopenharmony_ciunsigned int tw2815_get_audio_status(struct SOLO *solo); 5362306a36Sopenharmony_civoid tw2815_Set_AudioOutVol(struct SOLO *solo, unsigned int u_val); 5462306a36Sopenharmony_ci#endif 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci#endif /* __SOLO6X10_TW28_H */ 57