162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * FCI FC2580 silicon tuner driver 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2012 Antti Palosaari <crope@iki.fi> 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#ifndef FC2580_PRIV_H 962306a36Sopenharmony_ci#define FC2580_PRIV_H 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include "fc2580.h" 1262306a36Sopenharmony_ci#include <media/v4l2-ctrls.h> 1362306a36Sopenharmony_ci#include <media/v4l2-subdev.h> 1462306a36Sopenharmony_ci#include <linux/regmap.h> 1562306a36Sopenharmony_ci#include <linux/math64.h> 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_cistruct fc2580_reg_val { 1862306a36Sopenharmony_ci u8 reg; 1962306a36Sopenharmony_ci u8 val; 2062306a36Sopenharmony_ci}; 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_cistatic const struct fc2580_reg_val fc2580_init_reg_vals[] = { 2362306a36Sopenharmony_ci {0x00, 0x00}, 2462306a36Sopenharmony_ci {0x12, 0x86}, 2562306a36Sopenharmony_ci {0x14, 0x5c}, 2662306a36Sopenharmony_ci {0x16, 0x3c}, 2762306a36Sopenharmony_ci {0x1f, 0xd2}, 2862306a36Sopenharmony_ci {0x09, 0xd7}, 2962306a36Sopenharmony_ci {0x0b, 0xd5}, 3062306a36Sopenharmony_ci {0x0c, 0x32}, 3162306a36Sopenharmony_ci {0x0e, 0x43}, 3262306a36Sopenharmony_ci {0x21, 0x0a}, 3362306a36Sopenharmony_ci {0x22, 0x82}, 3462306a36Sopenharmony_ci {0x45, 0x10}, 3562306a36Sopenharmony_ci {0x4c, 0x00}, 3662306a36Sopenharmony_ci {0x3f, 0x88}, 3762306a36Sopenharmony_ci {0x02, 0x0e}, 3862306a36Sopenharmony_ci {0x58, 0x14}, 3962306a36Sopenharmony_ci}; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistruct fc2580_pll { 4262306a36Sopenharmony_ci u32 freq; 4362306a36Sopenharmony_ci u8 div_out; 4462306a36Sopenharmony_ci u8 band; 4562306a36Sopenharmony_ci}; 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_cistatic const struct fc2580_pll fc2580_pll_lut[] = { 4862306a36Sopenharmony_ci /* VCO min VCO max */ 4962306a36Sopenharmony_ci { 400000000, 12, 0x80}, /* .......... 4800000000 */ 5062306a36Sopenharmony_ci {1000000000, 4, 0x00}, /* 1600000000 4000000000 */ 5162306a36Sopenharmony_ci {0xffffffff, 2, 0x40}, /* 2000000000 .......... */ 5262306a36Sopenharmony_ci}; 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_cistruct fc2580_if_filter { 5562306a36Sopenharmony_ci u32 freq; 5662306a36Sopenharmony_ci u8 r36_val; 5762306a36Sopenharmony_ci u8 r39_val; 5862306a36Sopenharmony_ci}; 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_cistatic const struct fc2580_if_filter fc2580_if_filter_lut[] = { 6162306a36Sopenharmony_ci { 6000000, 0x18, 0x00}, 6262306a36Sopenharmony_ci { 7000000, 0x18, 0x80}, 6362306a36Sopenharmony_ci { 8000000, 0x18, 0x80}, 6462306a36Sopenharmony_ci {0xffffffff, 0x18, 0x80}, 6562306a36Sopenharmony_ci}; 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_cistruct fc2580_freq_regs { 6862306a36Sopenharmony_ci u32 freq; 6962306a36Sopenharmony_ci u8 r25_val; 7062306a36Sopenharmony_ci u8 r27_val; 7162306a36Sopenharmony_ci u8 r28_val; 7262306a36Sopenharmony_ci u8 r29_val; 7362306a36Sopenharmony_ci u8 r2b_val; 7462306a36Sopenharmony_ci u8 r2c_val; 7562306a36Sopenharmony_ci u8 r2d_val; 7662306a36Sopenharmony_ci u8 r30_val; 7762306a36Sopenharmony_ci u8 r44_val; 7862306a36Sopenharmony_ci u8 r50_val; 7962306a36Sopenharmony_ci u8 r53_val; 8062306a36Sopenharmony_ci u8 r5f_val; 8162306a36Sopenharmony_ci u8 r61_val; 8262306a36Sopenharmony_ci u8 r62_val; 8362306a36Sopenharmony_ci u8 r63_val; 8462306a36Sopenharmony_ci u8 r67_val; 8562306a36Sopenharmony_ci u8 r68_val; 8662306a36Sopenharmony_ci u8 r69_val; 8762306a36Sopenharmony_ci u8 r6a_val; 8862306a36Sopenharmony_ci u8 r6b_val; 8962306a36Sopenharmony_ci u8 r6c_val; 9062306a36Sopenharmony_ci u8 r6d_val; 9162306a36Sopenharmony_ci u8 r6e_val; 9262306a36Sopenharmony_ci u8 r6f_val; 9362306a36Sopenharmony_ci}; 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci/* XXX: 0xff is used for don't-care! */ 9662306a36Sopenharmony_cistatic const struct fc2580_freq_regs fc2580_freq_regs_lut[] = { 9762306a36Sopenharmony_ci { 400000000, 9862306a36Sopenharmony_ci 0xff, 0x77, 0x33, 0x40, 0xff, 0xff, 0xff, 0x09, 0xff, 0x8c, 9962306a36Sopenharmony_ci 0x50, 0x0f, 0x07, 0x00, 0x15, 0x03, 0x05, 0x10, 0x12, 0x08, 10062306a36Sopenharmony_ci 0x0a, 0x78, 0x32, 0x54}, 10162306a36Sopenharmony_ci { 538000000, 10262306a36Sopenharmony_ci 0xf0, 0x77, 0x53, 0x60, 0xff, 0xff, 0x9f, 0x09, 0xff, 0x8c, 10362306a36Sopenharmony_ci 0x50, 0x13, 0x07, 0x06, 0x15, 0x06, 0x08, 0x10, 0x12, 0x0b, 10462306a36Sopenharmony_ci 0x0c, 0x78, 0x32, 0x14}, 10562306a36Sopenharmony_ci { 794000000, 10662306a36Sopenharmony_ci 0xf0, 0x77, 0x53, 0x60, 0xff, 0xff, 0x9f, 0x09, 0xff, 0x8c, 10762306a36Sopenharmony_ci 0x50, 0x15, 0x03, 0x03, 0x15, 0x03, 0x05, 0x0c, 0x0e, 0x0b, 10862306a36Sopenharmony_ci 0x0c, 0x78, 0x32, 0x14}, 10962306a36Sopenharmony_ci {1000000000, 11062306a36Sopenharmony_ci 0xf0, 0x77, 0x53, 0x60, 0xff, 0xff, 0x8f, 0x09, 0xff, 0x8c, 11162306a36Sopenharmony_ci 0x50, 0x15, 0x07, 0x06, 0x15, 0x07, 0x09, 0x10, 0x12, 0x0b, 11262306a36Sopenharmony_ci 0x0c, 0x78, 0x32, 0x14}, 11362306a36Sopenharmony_ci {0xffffffff, 11462306a36Sopenharmony_ci 0xff, 0xff, 0xff, 0xff, 0x70, 0x37, 0xe7, 0x09, 0x20, 0x8c, 11562306a36Sopenharmony_ci 0x50, 0x0f, 0x0f, 0x00, 0x13, 0x00, 0x02, 0x0c, 0x0e, 0x08, 11662306a36Sopenharmony_ci 0x0a, 0xa0, 0x50, 0x14}, 11762306a36Sopenharmony_ci}; 11862306a36Sopenharmony_ci 11962306a36Sopenharmony_cistruct fc2580_dev { 12062306a36Sopenharmony_ci u32 clk; 12162306a36Sopenharmony_ci struct i2c_client *client; 12262306a36Sopenharmony_ci struct regmap *regmap; 12362306a36Sopenharmony_ci struct v4l2_subdev subdev; 12462306a36Sopenharmony_ci bool active; 12562306a36Sopenharmony_ci unsigned int f_frequency; 12662306a36Sopenharmony_ci unsigned int f_bandwidth; 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_ci /* Controls */ 12962306a36Sopenharmony_ci struct v4l2_ctrl_handler hdl; 13062306a36Sopenharmony_ci struct v4l2_ctrl *bandwidth_auto; 13162306a36Sopenharmony_ci struct v4l2_ctrl *bandwidth; 13262306a36Sopenharmony_ci}; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci#endif 135