1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * FCI FC2580 silicon tuner driver 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2012 Antti Palosaari <crope@iki.fi> 6*4882a593Smuzhiyun */ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #ifndef FC2580_PRIV_H 9*4882a593Smuzhiyun #define FC2580_PRIV_H 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #include "fc2580.h" 12*4882a593Smuzhiyun #include <media/v4l2-ctrls.h> 13*4882a593Smuzhiyun #include <media/v4l2-subdev.h> 14*4882a593Smuzhiyun #include <linux/regmap.h> 15*4882a593Smuzhiyun #include <linux/math64.h> 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun struct fc2580_reg_val { 18*4882a593Smuzhiyun u8 reg; 19*4882a593Smuzhiyun u8 val; 20*4882a593Smuzhiyun }; 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun static const struct fc2580_reg_val fc2580_init_reg_vals[] = { 23*4882a593Smuzhiyun {0x00, 0x00}, 24*4882a593Smuzhiyun {0x12, 0x86}, 25*4882a593Smuzhiyun {0x14, 0x5c}, 26*4882a593Smuzhiyun {0x16, 0x3c}, 27*4882a593Smuzhiyun {0x1f, 0xd2}, 28*4882a593Smuzhiyun {0x09, 0xd7}, 29*4882a593Smuzhiyun {0x0b, 0xd5}, 30*4882a593Smuzhiyun {0x0c, 0x32}, 31*4882a593Smuzhiyun {0x0e, 0x43}, 32*4882a593Smuzhiyun {0x21, 0x0a}, 33*4882a593Smuzhiyun {0x22, 0x82}, 34*4882a593Smuzhiyun {0x45, 0x10}, 35*4882a593Smuzhiyun {0x4c, 0x00}, 36*4882a593Smuzhiyun {0x3f, 0x88}, 37*4882a593Smuzhiyun {0x02, 0x0e}, 38*4882a593Smuzhiyun {0x58, 0x14}, 39*4882a593Smuzhiyun }; 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun struct fc2580_pll { 42*4882a593Smuzhiyun u32 freq; 43*4882a593Smuzhiyun u8 div_out; 44*4882a593Smuzhiyun u8 band; 45*4882a593Smuzhiyun }; 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun static const struct fc2580_pll fc2580_pll_lut[] = { 48*4882a593Smuzhiyun /* VCO min VCO max */ 49*4882a593Smuzhiyun { 400000000, 12, 0x80}, /* .......... 4800000000 */ 50*4882a593Smuzhiyun {1000000000, 4, 0x00}, /* 1600000000 4000000000 */ 51*4882a593Smuzhiyun {0xffffffff, 2, 0x40}, /* 2000000000 .......... */ 52*4882a593Smuzhiyun }; 53*4882a593Smuzhiyun 54*4882a593Smuzhiyun struct fc2580_if_filter { 55*4882a593Smuzhiyun u32 freq; 56*4882a593Smuzhiyun u8 r36_val; 57*4882a593Smuzhiyun u8 r39_val; 58*4882a593Smuzhiyun }; 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun static const struct fc2580_if_filter fc2580_if_filter_lut[] = { 61*4882a593Smuzhiyun { 6000000, 0x18, 0x00}, 62*4882a593Smuzhiyun { 7000000, 0x18, 0x80}, 63*4882a593Smuzhiyun { 8000000, 0x18, 0x80}, 64*4882a593Smuzhiyun {0xffffffff, 0x18, 0x80}, 65*4882a593Smuzhiyun }; 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun struct fc2580_freq_regs { 68*4882a593Smuzhiyun u32 freq; 69*4882a593Smuzhiyun u8 r25_val; 70*4882a593Smuzhiyun u8 r27_val; 71*4882a593Smuzhiyun u8 r28_val; 72*4882a593Smuzhiyun u8 r29_val; 73*4882a593Smuzhiyun u8 r2b_val; 74*4882a593Smuzhiyun u8 r2c_val; 75*4882a593Smuzhiyun u8 r2d_val; 76*4882a593Smuzhiyun u8 r30_val; 77*4882a593Smuzhiyun u8 r44_val; 78*4882a593Smuzhiyun u8 r50_val; 79*4882a593Smuzhiyun u8 r53_val; 80*4882a593Smuzhiyun u8 r5f_val; 81*4882a593Smuzhiyun u8 r61_val; 82*4882a593Smuzhiyun u8 r62_val; 83*4882a593Smuzhiyun u8 r63_val; 84*4882a593Smuzhiyun u8 r67_val; 85*4882a593Smuzhiyun u8 r68_val; 86*4882a593Smuzhiyun u8 r69_val; 87*4882a593Smuzhiyun u8 r6a_val; 88*4882a593Smuzhiyun u8 r6b_val; 89*4882a593Smuzhiyun u8 r6c_val; 90*4882a593Smuzhiyun u8 r6d_val; 91*4882a593Smuzhiyun u8 r6e_val; 92*4882a593Smuzhiyun u8 r6f_val; 93*4882a593Smuzhiyun }; 94*4882a593Smuzhiyun 95*4882a593Smuzhiyun /* XXX: 0xff is used for don't-care! */ 96*4882a593Smuzhiyun static const struct fc2580_freq_regs fc2580_freq_regs_lut[] = { 97*4882a593Smuzhiyun { 400000000, 98*4882a593Smuzhiyun 0xff, 0x77, 0x33, 0x40, 0xff, 0xff, 0xff, 0x09, 0xff, 0x8c, 99*4882a593Smuzhiyun 0x50, 0x0f, 0x07, 0x00, 0x15, 0x03, 0x05, 0x10, 0x12, 0x08, 100*4882a593Smuzhiyun 0x0a, 0x78, 0x32, 0x54}, 101*4882a593Smuzhiyun { 538000000, 102*4882a593Smuzhiyun 0xf0, 0x77, 0x53, 0x60, 0xff, 0xff, 0x9f, 0x09, 0xff, 0x8c, 103*4882a593Smuzhiyun 0x50, 0x13, 0x07, 0x06, 0x15, 0x06, 0x08, 0x10, 0x12, 0x0b, 104*4882a593Smuzhiyun 0x0c, 0x78, 0x32, 0x14}, 105*4882a593Smuzhiyun { 794000000, 106*4882a593Smuzhiyun 0xf0, 0x77, 0x53, 0x60, 0xff, 0xff, 0x9f, 0x09, 0xff, 0x8c, 107*4882a593Smuzhiyun 0x50, 0x15, 0x03, 0x03, 0x15, 0x03, 0x05, 0x0c, 0x0e, 0x0b, 108*4882a593Smuzhiyun 0x0c, 0x78, 0x32, 0x14}, 109*4882a593Smuzhiyun {1000000000, 110*4882a593Smuzhiyun 0xf0, 0x77, 0x53, 0x60, 0xff, 0xff, 0x8f, 0x09, 0xff, 0x8c, 111*4882a593Smuzhiyun 0x50, 0x15, 0x07, 0x06, 0x15, 0x07, 0x09, 0x10, 0x12, 0x0b, 112*4882a593Smuzhiyun 0x0c, 0x78, 0x32, 0x14}, 113*4882a593Smuzhiyun {0xffffffff, 114*4882a593Smuzhiyun 0xff, 0xff, 0xff, 0xff, 0x70, 0x37, 0xe7, 0x09, 0x20, 0x8c, 115*4882a593Smuzhiyun 0x50, 0x0f, 0x0f, 0x00, 0x13, 0x00, 0x02, 0x0c, 0x0e, 0x08, 116*4882a593Smuzhiyun 0x0a, 0xa0, 0x50, 0x14}, 117*4882a593Smuzhiyun }; 118*4882a593Smuzhiyun 119*4882a593Smuzhiyun struct fc2580_dev { 120*4882a593Smuzhiyun u32 clk; 121*4882a593Smuzhiyun struct i2c_client *client; 122*4882a593Smuzhiyun struct regmap *regmap; 123*4882a593Smuzhiyun struct v4l2_subdev subdev; 124*4882a593Smuzhiyun bool active; 125*4882a593Smuzhiyun unsigned int f_frequency; 126*4882a593Smuzhiyun unsigned int f_bandwidth; 127*4882a593Smuzhiyun 128*4882a593Smuzhiyun /* Controls */ 129*4882a593Smuzhiyun struct v4l2_ctrl_handler hdl; 130*4882a593Smuzhiyun struct v4l2_ctrl *bandwidth_auto; 131*4882a593Smuzhiyun struct v4l2_ctrl *bandwidth; 132*4882a593Smuzhiyun }; 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun #endif 135