162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
262306a36Sopenharmony_ci/* Subdriver for the GL860 chip with the MI1320 sensor
362306a36Sopenharmony_ci * Author Olivier LORIN from own logs
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci/* Sensor : MI1320 */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#include "gl860.h"
962306a36Sopenharmony_ci
1062306a36Sopenharmony_cistatic struct validx tbl_common[] = {
1162306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba00, 0x00f1}, {0xba51, 0x0066}, {0xba02, 0x00f1},
1262306a36Sopenharmony_ci	{0xba05, 0x0067}, {0xba05, 0x00f1}, {0xbaa0, 0x0065}, {0xba00, 0x00f1},
1362306a36Sopenharmony_ci	{0xffff, 0xffff},
1462306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba02, 0x00f1}, {0xbafa, 0x0028}, {0xba02, 0x00f1},
1562306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba01, 0x00f1}, {0xbaf0, 0x0006}, {0xba0e, 0x00f1},
1662306a36Sopenharmony_ci	{0xba70, 0x0006}, {0xba0e, 0x00f1},
1762306a36Sopenharmony_ci	{0xffff, 0xffff},
1862306a36Sopenharmony_ci	{0xba74, 0x0006}, {0xba0e, 0x00f1},
1962306a36Sopenharmony_ci	{0xffff, 0xffff},
2062306a36Sopenharmony_ci	{0x0061, 0x0000}, {0x0068, 0x000d},
2162306a36Sopenharmony_ci};
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_cistatic struct validx tbl_init_at_startup[] = {
2462306a36Sopenharmony_ci	{0x0000, 0x0000}, {0x0010, 0x0010},
2562306a36Sopenharmony_ci	{35, 0xffff},
2662306a36Sopenharmony_ci	{0x0008, 0x00c0}, {0x0001, 0x00c1}, {0x0001, 0x00c2}, {0x0020, 0x0006},
2762306a36Sopenharmony_ci	{0x006a, 0x000d},
2862306a36Sopenharmony_ci};
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_cistatic struct validx tbl_sensor_settings_common[] = {
3162306a36Sopenharmony_ci	{0x0010, 0x0010}, {0x0003, 0x00c1}, {0x0042, 0x00c2}, {0x0040, 0x0000},
3262306a36Sopenharmony_ci	{0x006a, 0x0007}, {0x006a, 0x000d}, {0x0063, 0x0006},
3362306a36Sopenharmony_ci};
3462306a36Sopenharmony_cistatic struct validx tbl_sensor_settings_1280[] = {
3562306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba00, 0x00f1}, {0xba5a, 0x0066}, {0xba02, 0x00f1},
3662306a36Sopenharmony_ci	{0xba05, 0x0067}, {0xba05, 0x00f1}, {0xba20, 0x0065}, {0xba00, 0x00f1},
3762306a36Sopenharmony_ci};
3862306a36Sopenharmony_cistatic struct validx tbl_sensor_settings_800[] = {
3962306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba00, 0x00f1}, {0xba5a, 0x0066}, {0xba02, 0x00f1},
4062306a36Sopenharmony_ci	{0xba05, 0x0067}, {0xba05, 0x00f1}, {0xba20, 0x0065}, {0xba00, 0x00f1},
4162306a36Sopenharmony_ci};
4262306a36Sopenharmony_cistatic struct validx tbl_sensor_settings_640[] = {
4362306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba00, 0x00f1}, {0xbaa0, 0x0065}, {0xba00, 0x00f1},
4462306a36Sopenharmony_ci	{0xba51, 0x0066}, {0xba02, 0x00f1}, {0xba05, 0x0067}, {0xba05, 0x00f1},
4562306a36Sopenharmony_ci	{0xba20, 0x0065}, {0xba00, 0x00f1},
4662306a36Sopenharmony_ci};
4762306a36Sopenharmony_cistatic struct validx tbl_post_unset_alt[] = {
4862306a36Sopenharmony_ci	{0xba00, 0x00f0}, {0xba00, 0x00f1}, {0xbaa0, 0x0065}, {0xba00, 0x00f1},
4962306a36Sopenharmony_ci	{0x0061, 0x0000}, {0x0068, 0x000d},
5062306a36Sopenharmony_ci};
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_cistatic u8 *tbl_1280[] = {
5362306a36Sopenharmony_ci	(u8[]){
5462306a36Sopenharmony_ci		0x0d, 0x80, 0xf1, 0x08, 0x03, 0x04, 0xf1, 0x00,
5562306a36Sopenharmony_ci		0x04, 0x05, 0xf1, 0x02, 0x05, 0x00, 0xf1, 0xf1,
5662306a36Sopenharmony_ci		0x06, 0x00, 0xf1, 0x0d, 0x20, 0x01, 0xf1, 0x00,
5762306a36Sopenharmony_ci		0x21, 0x84, 0xf1, 0x00, 0x0d, 0x00, 0xf1, 0x08,
5862306a36Sopenharmony_ci		0xf0, 0x00, 0xf1, 0x01, 0x34, 0x00, 0xf1, 0x00,
5962306a36Sopenharmony_ci		0x9b, 0x43, 0xf1, 0x00, 0xa6, 0x05, 0xf1, 0x00,
6062306a36Sopenharmony_ci		0xa9, 0x04, 0xf1, 0x00, 0xa1, 0x05, 0xf1, 0x00,
6162306a36Sopenharmony_ci		0xa4, 0x04, 0xf1, 0x00, 0xae, 0x0a, 0xf1, 0x08
6262306a36Sopenharmony_ci	}, (u8[]){
6362306a36Sopenharmony_ci		0xf0, 0x00, 0xf1, 0x02, 0x3a, 0x05, 0xf1, 0xf1,
6462306a36Sopenharmony_ci		0x3c, 0x05, 0xf1, 0xf1, 0x59, 0x01, 0xf1, 0x47,
6562306a36Sopenharmony_ci		0x5a, 0x01, 0xf1, 0x88, 0x5c, 0x0a, 0xf1, 0x06,
6662306a36Sopenharmony_ci		0x5d, 0x0e, 0xf1, 0x0a, 0x64, 0x5e, 0xf1, 0x1c,
6762306a36Sopenharmony_ci		0xd2, 0x00, 0xf1, 0xcf, 0xcb, 0x00, 0xf1, 0x01
6862306a36Sopenharmony_ci	}, (u8[]){
6962306a36Sopenharmony_ci		0xd3, 0x02, 0xd4, 0x28, 0xd5, 0x01, 0xd0, 0x02,
7062306a36Sopenharmony_ci		0xd1, 0x18, 0xd2, 0xc1
7162306a36Sopenharmony_ci	}
7262306a36Sopenharmony_ci};
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_cistatic u8 *tbl_800[] = {
7562306a36Sopenharmony_ci	(u8[]){
7662306a36Sopenharmony_ci		0x0d, 0x80, 0xf1, 0x08, 0x03, 0x03, 0xf1, 0xc0,
7762306a36Sopenharmony_ci		0x04, 0x05, 0xf1, 0x02, 0x05, 0x00, 0xf1, 0xf1,
7862306a36Sopenharmony_ci		0x06, 0x00, 0xf1, 0x0d, 0x20, 0x01, 0xf1, 0x00,
7962306a36Sopenharmony_ci		0x21, 0x84, 0xf1, 0x00, 0x0d, 0x00, 0xf1, 0x08,
8062306a36Sopenharmony_ci		0xf0, 0x00, 0xf1, 0x01, 0x34, 0x00, 0xf1, 0x00,
8162306a36Sopenharmony_ci		0x9b, 0x43, 0xf1, 0x00, 0xa6, 0x05, 0xf1, 0x00,
8262306a36Sopenharmony_ci		0xa9, 0x03, 0xf1, 0xc0, 0xa1, 0x03, 0xf1, 0x20,
8362306a36Sopenharmony_ci		0xa4, 0x02, 0xf1, 0x5a, 0xae, 0x0a, 0xf1, 0x08
8462306a36Sopenharmony_ci	}, (u8[]){
8562306a36Sopenharmony_ci		0xf0, 0x00, 0xf1, 0x02, 0x3a, 0x05, 0xf1, 0xf1,
8662306a36Sopenharmony_ci		0x3c, 0x05, 0xf1, 0xf1, 0x59, 0x01, 0xf1, 0x47,
8762306a36Sopenharmony_ci		0x5a, 0x01, 0xf1, 0x88, 0x5c, 0x0a, 0xf1, 0x06,
8862306a36Sopenharmony_ci		0x5d, 0x0e, 0xf1, 0x0a, 0x64, 0x5e, 0xf1, 0x1c,
8962306a36Sopenharmony_ci		0xd2, 0x00, 0xf1, 0xcf, 0xcb, 0x00, 0xf1, 0x01
9062306a36Sopenharmony_ci	}, (u8[]){
9162306a36Sopenharmony_ci		0xd3, 0x02, 0xd4, 0x18, 0xd5, 0x21, 0xd0, 0x02,
9262306a36Sopenharmony_ci		0xd1, 0x10, 0xd2, 0x59
9362306a36Sopenharmony_ci	}
9462306a36Sopenharmony_ci};
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_cistatic u8 *tbl_640[] = {
9762306a36Sopenharmony_ci	(u8[]){
9862306a36Sopenharmony_ci		0x0d, 0x80, 0xf1, 0x08, 0x03, 0x04, 0xf1, 0x04,
9962306a36Sopenharmony_ci		0x04, 0x05, 0xf1, 0x02, 0x07, 0x01, 0xf1, 0x7c,
10062306a36Sopenharmony_ci		0x08, 0x00, 0xf1, 0x0e, 0x21, 0x80, 0xf1, 0x00,
10162306a36Sopenharmony_ci		0x0d, 0x00, 0xf1, 0x08, 0xf0, 0x00, 0xf1, 0x01,
10262306a36Sopenharmony_ci		0x34, 0x10, 0xf1, 0x10, 0x3a, 0x43, 0xf1, 0x00,
10362306a36Sopenharmony_ci		0xa6, 0x05, 0xf1, 0x02, 0xa9, 0x04, 0xf1, 0x04,
10462306a36Sopenharmony_ci		0xa7, 0x02, 0xf1, 0x81, 0xaa, 0x01, 0xf1, 0xe2,
10562306a36Sopenharmony_ci		0xae, 0x0c, 0xf1, 0x09
10662306a36Sopenharmony_ci	}, (u8[]){
10762306a36Sopenharmony_ci		0xf0, 0x00, 0xf1, 0x02, 0x39, 0x03, 0xf1, 0xfc,
10862306a36Sopenharmony_ci		0x3b, 0x04, 0xf1, 0x04, 0x57, 0x01, 0xf1, 0xb6,
10962306a36Sopenharmony_ci		0x58, 0x02, 0xf1, 0x0d, 0x5c, 0x1f, 0xf1, 0x19,
11062306a36Sopenharmony_ci		0x5d, 0x24, 0xf1, 0x1e, 0x64, 0x5e, 0xf1, 0x1c,
11162306a36Sopenharmony_ci		0xd2, 0x00, 0xf1, 0x00, 0xcb, 0x00, 0xf1, 0x01
11262306a36Sopenharmony_ci	}, (u8[]){
11362306a36Sopenharmony_ci		0xd3, 0x02, 0xd4, 0x10, 0xd5, 0x81, 0xd0, 0x02,
11462306a36Sopenharmony_ci		0xd1, 0x08, 0xd2, 0xe1
11562306a36Sopenharmony_ci	}
11662306a36Sopenharmony_ci};
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_cistatic s32 tbl_sat[] = {0x25, 0x1d, 0x15, 0x0d, 0x05, 0x4d, 0x55, 0x5d, 0x2d};
11962306a36Sopenharmony_cistatic s32 tbl_bright[] = {0, 8, 0x10, 0x20, 0x30, 0x40, 0x50, 0x60, 0x70};
12062306a36Sopenharmony_cistatic s32 tbl_backlight[] = {0x0e, 0x06, 0x02};
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_cistatic s32 tbl_cntr1[] = {
12362306a36Sopenharmony_ci	0x90, 0x98, 0xa0, 0xa8, 0xb0, 0xb8, 0xc0, 0xc8, 0xd0, 0xe0, 0xf0};
12462306a36Sopenharmony_cistatic s32 tbl_cntr2[] = {
12562306a36Sopenharmony_ci	0x70, 0x68, 0x60, 0x58, 0x50, 0x48, 0x40, 0x38, 0x30, 0x20, 0x10};
12662306a36Sopenharmony_ci
12762306a36Sopenharmony_cistatic u8 dat_wbalNL[] =
12862306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x05\x00\xf1\x06" "\x3b\x04\xf1\x2a\x47\x10\xf1\x10"
12962306a36Sopenharmony_ci	"\x9d\x3c\xf1\xae\xaf\x10\xf1\x00" "\xf0\x00\xf1\x02\x2f\x91\xf1\x20"
13062306a36Sopenharmony_ci	"\x9c\x91\xf1\x20\x37\x03\xf1\x00" "\x9d\xc5\xf1\x0f\xf0\x00\xf1\x00";
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_cistatic u8 dat_wbalLL[] =
13362306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x05\x00\xf1\x0c" "\x3b\x04\xf1\x2a\x47\x40\xf1\x40"
13462306a36Sopenharmony_ci	"\x9d\x20\xf1\xae\xaf\x10\xf1\x00" "\xf0\x00\xf1\x02\x2f\xd1\xf1\x00"
13562306a36Sopenharmony_ci	"\x9c\xd1\xf1\x00\x37\x03\xf1\x00" "\x9d\xc5\xf1\x3f\xf0\x00\xf1\x00";
13662306a36Sopenharmony_ci
13762306a36Sopenharmony_cistatic u8 dat_wbalBL[] =
13862306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x05\x00\xf1\x06" "\x47\x10\xf1\x30\x9d\x3c\xf1\xae"
13962306a36Sopenharmony_ci	"\xaf\x10\xf1\x00\xf0\x00\xf1\x02" "\x2f\x91\xf1\x20\x9c\x91\xf1\x20"
14062306a36Sopenharmony_ci	"\x37\x03\xf1\x00\x9d\xc5\xf1\x2f" "\xf0\x00\xf1\x00";
14162306a36Sopenharmony_ci
14262306a36Sopenharmony_cistatic u8 dat_hvflip1[] = {0xf0, 0x00, 0xf1, 0x00};
14362306a36Sopenharmony_ci
14462306a36Sopenharmony_cistatic u8 dat_common00[] =
14562306a36Sopenharmony_ci	"\x00\x01\x07\x6a\x06\x63\x0d\x6a" "\xc0\x00\x10\x10\xc1\x03\xc2\x42"
14662306a36Sopenharmony_ci	"\xd8\x04\x58\x00\x04\x02";
14762306a36Sopenharmony_cistatic u8 dat_common01[] =
14862306a36Sopenharmony_ci	"\x0d\x00\xf1\x0b\x0d\x00\xf1\x08" "\x35\x00\xf1\x22\x68\x00\xf1\x5d"
14962306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x06\x70\xf1\x0e" "\xf0\x00\xf1\x02\xdd\x18\xf1\xe0";
15062306a36Sopenharmony_cistatic u8 dat_common02[] =
15162306a36Sopenharmony_ci	"\x05\x01\xf1\x84\x06\x00\xf1\x44" "\x07\x00\xf1\xbe\x08\x00\xf1\x1e"
15262306a36Sopenharmony_ci	"\x20\x01\xf1\x03\x21\x84\xf1\x00" "\x22\x0d\xf1\x0f\x24\x80\xf1\x00"
15362306a36Sopenharmony_ci	"\x34\x18\xf1\x2d\x35\x00\xf1\x22" "\x43\x83\xf1\x83\x59\x00\xf1\xff";
15462306a36Sopenharmony_cistatic u8 dat_common03[] =
15562306a36Sopenharmony_ci	"\xf0\x00\xf1\x02\x39\x06\xf1\x8c" "\x3a\x06\xf1\x8c\x3b\x03\xf1\xda"
15662306a36Sopenharmony_ci	"\x3c\x05\xf1\x30\x57\x01\xf1\x0c" "\x58\x01\xf1\x42\x59\x01\xf1\x0c"
15762306a36Sopenharmony_ci	"\x5a\x01\xf1\x42\x5c\x13\xf1\x0e" "\x5d\x17\xf1\x12\x64\x1e\xf1\x1c";
15862306a36Sopenharmony_cistatic u8 dat_common04[] =
15962306a36Sopenharmony_ci	"\xf0\x00\xf1\x02\x24\x5f\xf1\x20" "\x28\xea\xf1\x02\x5f\x41\xf1\x43";
16062306a36Sopenharmony_cistatic u8 dat_common05[] =
16162306a36Sopenharmony_ci	"\x02\x00\xf1\xee\x03\x29\xf1\x1a" "\x04\x02\xf1\xa4\x09\x00\xf1\x68"
16262306a36Sopenharmony_ci	"\x0a\x00\xf1\x2a\x0b\x00\xf1\x04" "\x0c\x00\xf1\x93\x0d\x00\xf1\x82"
16362306a36Sopenharmony_ci	"\x0e\x00\xf1\x40\x0f\x00\xf1\x5f" "\x10\x00\xf1\x4e\x11\x00\xf1\x5b";
16462306a36Sopenharmony_cistatic u8 dat_common06[] =
16562306a36Sopenharmony_ci	"\x15\x00\xf1\xc9\x16\x00\xf1\x5e" "\x17\x00\xf1\x9d\x18\x00\xf1\x06"
16662306a36Sopenharmony_ci	"\x19\x00\xf1\x89\x1a\x00\xf1\x12" "\x1b\x00\xf1\xa1\x1c\x00\xf1\xe4"
16762306a36Sopenharmony_ci	"\x1d\x00\xf1\x7a\x1e\x00\xf1\x64" "\xf6\x00\xf1\x5f";
16862306a36Sopenharmony_cistatic u8 dat_common07[] =
16962306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x53\x09\xf1\x03" "\x54\x3d\xf1\x1c\x55\x99\xf1\x72"
17062306a36Sopenharmony_ci	"\x56\xc1\xf1\xb1\x57\xd8\xf1\xce" "\x58\xe0\xf1\x00\xdc\x0a\xf1\x03"
17162306a36Sopenharmony_ci	"\xdd\x45\xf1\x20\xde\xae\xf1\x82" "\xdf\xdc\xf1\xc9\xe0\xf6\xf1\xea"
17262306a36Sopenharmony_ci	"\xe1\xff\xf1\x00";
17362306a36Sopenharmony_cistatic u8 dat_common08[] =
17462306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x80\x00\xf1\x06" "\x81\xf6\xf1\x08\x82\xfb\xf1\xf7"
17562306a36Sopenharmony_ci	"\x83\x00\xf1\xfe\xb6\x07\xf1\x03" "\xb7\x18\xf1\x0c\x84\xfb\xf1\x06"
17662306a36Sopenharmony_ci	"\x85\xfb\xf1\xf9\x86\x00\xf1\xff" "\xb8\x07\xf1\x04\xb9\x16\xf1\x0a";
17762306a36Sopenharmony_cistatic u8 dat_common09[] =
17862306a36Sopenharmony_ci	"\x87\xfa\xf1\x05\x88\xfc\xf1\xf9" "\x89\x00\xf1\xff\xba\x06\xf1\x03"
17962306a36Sopenharmony_ci	"\xbb\x17\xf1\x09\x8a\xe8\xf1\x14" "\x8b\xf7\xf1\xf0\x8c\xfd\xf1\xfa"
18062306a36Sopenharmony_ci	"\x8d\x00\xf1\x00\xbc\x05\xf1\x01" "\xbd\x0c\xf1\x08\xbe\x00\xf1\x14";
18162306a36Sopenharmony_cistatic u8 dat_common10[] =
18262306a36Sopenharmony_ci	"\x8e\xea\xf1\x13\x8f\xf7\xf1\xf2" "\x90\xfd\xf1\xfa\x91\x00\xf1\x00"
18362306a36Sopenharmony_ci	"\xbf\x05\xf1\x01\xc0\x0a\xf1\x08" "\xc1\x00\xf1\x0c\x92\xed\xf1\x0f"
18462306a36Sopenharmony_ci	"\x93\xf9\xf1\xf4\x94\xfe\xf1\xfb" "\x95\x00\xf1\x00\xc2\x04\xf1\x01"
18562306a36Sopenharmony_ci	"\xc3\x0a\xf1\x07\xc4\x00\xf1\x10";
18662306a36Sopenharmony_cistatic u8 dat_common11[] =
18762306a36Sopenharmony_ci	"\xf0\x00\xf1\x01\x05\x00\xf1\x06" "\x25\x00\xf1\x55\x34\x10\xf1\x10"
18862306a36Sopenharmony_ci	"\x35\xf0\xf1\x10\x3a\x02\xf1\x03" "\x3b\x04\xf1\x2a\x9b\x43\xf1\x00"
18962306a36Sopenharmony_ci	"\xa4\x03\xf1\xc0\xa7\x02\xf1\x81";
19062306a36Sopenharmony_ci
19162306a36Sopenharmony_cistatic int  mi1320_init_at_startup(struct gspca_dev *gspca_dev);
19262306a36Sopenharmony_cistatic int  mi1320_configure_alt(struct gspca_dev *gspca_dev);
19362306a36Sopenharmony_cistatic int  mi1320_init_pre_alt(struct gspca_dev *gspca_dev);
19462306a36Sopenharmony_cistatic int  mi1320_init_post_alt(struct gspca_dev *gspca_dev);
19562306a36Sopenharmony_cistatic void mi1320_post_unset_alt(struct gspca_dev *gspca_dev);
19662306a36Sopenharmony_cistatic int  mi1320_sensor_settings(struct gspca_dev *gspca_dev);
19762306a36Sopenharmony_cistatic int  mi1320_camera_settings(struct gspca_dev *gspca_dev);
19862306a36Sopenharmony_ci/*==========================================================================*/
19962306a36Sopenharmony_ci
20062306a36Sopenharmony_civoid mi1320_init_settings(struct gspca_dev *gspca_dev)
20162306a36Sopenharmony_ci{
20262306a36Sopenharmony_ci	struct sd *sd = (struct sd *) gspca_dev;
20362306a36Sopenharmony_ci
20462306a36Sopenharmony_ci	sd->vcur.backlight  =  0;
20562306a36Sopenharmony_ci	sd->vcur.brightness =  0;
20662306a36Sopenharmony_ci	sd->vcur.sharpness  =  6;
20762306a36Sopenharmony_ci	sd->vcur.contrast   = 10;
20862306a36Sopenharmony_ci	sd->vcur.gamma      = 20;
20962306a36Sopenharmony_ci	sd->vcur.hue        =  0;
21062306a36Sopenharmony_ci	sd->vcur.saturation =  6;
21162306a36Sopenharmony_ci	sd->vcur.whitebal   =  0;
21262306a36Sopenharmony_ci	sd->vcur.mirror     = 0;
21362306a36Sopenharmony_ci	sd->vcur.flip       = 0;
21462306a36Sopenharmony_ci	sd->vcur.AC50Hz     = 1;
21562306a36Sopenharmony_ci
21662306a36Sopenharmony_ci	sd->vmax.backlight  =  2;
21762306a36Sopenharmony_ci	sd->vmax.brightness =  8;
21862306a36Sopenharmony_ci	sd->vmax.sharpness  =  7;
21962306a36Sopenharmony_ci	sd->vmax.contrast   =  0; /* 10 but not working with this driver */
22062306a36Sopenharmony_ci	sd->vmax.gamma      = 40;
22162306a36Sopenharmony_ci	sd->vmax.hue        =  5 + 1;
22262306a36Sopenharmony_ci	sd->vmax.saturation =  8;
22362306a36Sopenharmony_ci	sd->vmax.whitebal   =  2;
22462306a36Sopenharmony_ci	sd->vmax.mirror     = 1;
22562306a36Sopenharmony_ci	sd->vmax.flip       = 1;
22662306a36Sopenharmony_ci	sd->vmax.AC50Hz     = 1;
22762306a36Sopenharmony_ci
22862306a36Sopenharmony_ci	sd->dev_camera_settings = mi1320_camera_settings;
22962306a36Sopenharmony_ci	sd->dev_init_at_startup = mi1320_init_at_startup;
23062306a36Sopenharmony_ci	sd->dev_configure_alt   = mi1320_configure_alt;
23162306a36Sopenharmony_ci	sd->dev_init_pre_alt    = mi1320_init_pre_alt;
23262306a36Sopenharmony_ci	sd->dev_post_unset_alt  = mi1320_post_unset_alt;
23362306a36Sopenharmony_ci}
23462306a36Sopenharmony_ci
23562306a36Sopenharmony_ci/*==========================================================================*/
23662306a36Sopenharmony_ci
23762306a36Sopenharmony_cistatic void common(struct gspca_dev *gspca_dev)
23862306a36Sopenharmony_ci{
23962306a36Sopenharmony_ci	s32 n; /* reserved for FETCH functions */
24062306a36Sopenharmony_ci
24162306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0x0000, 0x0200, 22, dat_common00);
24262306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 1, 0x0041, 0x0000, 0, NULL);
24362306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 32, dat_common01);
24462306a36Sopenharmony_ci	n = fetch_validx(gspca_dev, tbl_common, ARRAY_SIZE(tbl_common));
24562306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 48, dat_common02);
24662306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 48, dat_common03);
24762306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 16, dat_common04);
24862306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 48, dat_common05);
24962306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 44, dat_common06);
25062306a36Sopenharmony_ci	keep_on_fetching_validx(gspca_dev, tbl_common,
25162306a36Sopenharmony_ci					ARRAY_SIZE(tbl_common), n);
25262306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 52, dat_common07);
25362306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 48, dat_common08);
25462306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 48, dat_common09);
25562306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 56, dat_common10);
25662306a36Sopenharmony_ci	keep_on_fetching_validx(gspca_dev, tbl_common,
25762306a36Sopenharmony_ci					ARRAY_SIZE(tbl_common), n);
25862306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 40, dat_common11);
25962306a36Sopenharmony_ci	keep_on_fetching_validx(gspca_dev, tbl_common,
26062306a36Sopenharmony_ci					ARRAY_SIZE(tbl_common), n);
26162306a36Sopenharmony_ci}
26262306a36Sopenharmony_ci
26362306a36Sopenharmony_cistatic int mi1320_init_at_startup(struct gspca_dev *gspca_dev)
26462306a36Sopenharmony_ci{
26562306a36Sopenharmony_ci	fetch_validx(gspca_dev, tbl_init_at_startup,
26662306a36Sopenharmony_ci				ARRAY_SIZE(tbl_init_at_startup));
26762306a36Sopenharmony_ci
26862306a36Sopenharmony_ci	common(gspca_dev);
26962306a36Sopenharmony_ci
27062306a36Sopenharmony_ci/*	ctrl_out(gspca_dev, 0x40, 11, 0x0000, 0x0000, 0, NULL); */
27162306a36Sopenharmony_ci
27262306a36Sopenharmony_ci	return 0;
27362306a36Sopenharmony_ci}
27462306a36Sopenharmony_ci
27562306a36Sopenharmony_cistatic int mi1320_init_pre_alt(struct gspca_dev *gspca_dev)
27662306a36Sopenharmony_ci{
27762306a36Sopenharmony_ci	struct sd *sd = (struct sd *) gspca_dev;
27862306a36Sopenharmony_ci
27962306a36Sopenharmony_ci	sd->mirrorMask = 0;
28062306a36Sopenharmony_ci
28162306a36Sopenharmony_ci	sd->vold.backlight  = -1;
28262306a36Sopenharmony_ci	sd->vold.brightness = -1;
28362306a36Sopenharmony_ci	sd->vold.sharpness  = -1;
28462306a36Sopenharmony_ci	sd->vold.contrast   = -1;
28562306a36Sopenharmony_ci	sd->vold.saturation = -1;
28662306a36Sopenharmony_ci	sd->vold.gamma    = -1;
28762306a36Sopenharmony_ci	sd->vold.hue      = -1;
28862306a36Sopenharmony_ci	sd->vold.whitebal = -1;
28962306a36Sopenharmony_ci	sd->vold.mirror   = -1;
29062306a36Sopenharmony_ci	sd->vold.flip     = -1;
29162306a36Sopenharmony_ci	sd->vold.AC50Hz   = -1;
29262306a36Sopenharmony_ci
29362306a36Sopenharmony_ci	common(gspca_dev);
29462306a36Sopenharmony_ci
29562306a36Sopenharmony_ci	mi1320_sensor_settings(gspca_dev);
29662306a36Sopenharmony_ci
29762306a36Sopenharmony_ci	mi1320_init_post_alt(gspca_dev);
29862306a36Sopenharmony_ci
29962306a36Sopenharmony_ci	return 0;
30062306a36Sopenharmony_ci}
30162306a36Sopenharmony_ci
30262306a36Sopenharmony_cistatic int mi1320_init_post_alt(struct gspca_dev *gspca_dev)
30362306a36Sopenharmony_ci{
30462306a36Sopenharmony_ci	mi1320_camera_settings(gspca_dev);
30562306a36Sopenharmony_ci
30662306a36Sopenharmony_ci	return 0;
30762306a36Sopenharmony_ci}
30862306a36Sopenharmony_ci
30962306a36Sopenharmony_cistatic int mi1320_sensor_settings(struct gspca_dev *gspca_dev)
31062306a36Sopenharmony_ci{
31162306a36Sopenharmony_ci	s32 reso = gspca_dev->cam.cam_mode[(s32) gspca_dev->curr_mode].priv;
31262306a36Sopenharmony_ci
31362306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 5, 0x0001, 0x0000, 0, NULL);
31462306a36Sopenharmony_ci
31562306a36Sopenharmony_ci	fetch_validx(gspca_dev, tbl_sensor_settings_common,
31662306a36Sopenharmony_ci				ARRAY_SIZE(tbl_sensor_settings_common));
31762306a36Sopenharmony_ci
31862306a36Sopenharmony_ci	switch (reso) {
31962306a36Sopenharmony_ci	case IMAGE_1280:
32062306a36Sopenharmony_ci		fetch_validx(gspca_dev, tbl_sensor_settings_1280,
32162306a36Sopenharmony_ci					ARRAY_SIZE(tbl_sensor_settings_1280));
32262306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 64, tbl_1280[0]);
32362306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 40, tbl_1280[1]);
32462306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0x0000, 0x0200, 12, tbl_1280[2]);
32562306a36Sopenharmony_ci		break;
32662306a36Sopenharmony_ci
32762306a36Sopenharmony_ci	case IMAGE_800:
32862306a36Sopenharmony_ci		fetch_validx(gspca_dev, tbl_sensor_settings_800,
32962306a36Sopenharmony_ci					ARRAY_SIZE(tbl_sensor_settings_800));
33062306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 64, tbl_800[0]);
33162306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 40, tbl_800[1]);
33262306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0x0000, 0x0200, 12, tbl_800[2]);
33362306a36Sopenharmony_ci		break;
33462306a36Sopenharmony_ci
33562306a36Sopenharmony_ci	default:
33662306a36Sopenharmony_ci		fetch_validx(gspca_dev, tbl_sensor_settings_640,
33762306a36Sopenharmony_ci					ARRAY_SIZE(tbl_sensor_settings_640));
33862306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 60, tbl_640[0]);
33962306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 40, tbl_640[1]);
34062306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0x0000, 0x0200, 12, tbl_640[2]);
34162306a36Sopenharmony_ci		break;
34262306a36Sopenharmony_ci	}
34362306a36Sopenharmony_ci	return 0;
34462306a36Sopenharmony_ci}
34562306a36Sopenharmony_ci
34662306a36Sopenharmony_cistatic int mi1320_configure_alt(struct gspca_dev *gspca_dev)
34762306a36Sopenharmony_ci{
34862306a36Sopenharmony_ci	s32 reso = gspca_dev->cam.cam_mode[(s32) gspca_dev->curr_mode].priv;
34962306a36Sopenharmony_ci
35062306a36Sopenharmony_ci	switch (reso) {
35162306a36Sopenharmony_ci	case IMAGE_640:
35262306a36Sopenharmony_ci		gspca_dev->alt = 3 + 1;
35362306a36Sopenharmony_ci		break;
35462306a36Sopenharmony_ci
35562306a36Sopenharmony_ci	case IMAGE_800:
35662306a36Sopenharmony_ci	case IMAGE_1280:
35762306a36Sopenharmony_ci		gspca_dev->alt = 1 + 1;
35862306a36Sopenharmony_ci		break;
35962306a36Sopenharmony_ci	}
36062306a36Sopenharmony_ci	return 0;
36162306a36Sopenharmony_ci}
36262306a36Sopenharmony_ci
36362306a36Sopenharmony_cistatic int mi1320_camera_settings(struct gspca_dev *gspca_dev)
36462306a36Sopenharmony_ci{
36562306a36Sopenharmony_ci	struct sd *sd = (struct sd *) gspca_dev;
36662306a36Sopenharmony_ci
36762306a36Sopenharmony_ci	s32 backlight = sd->vcur.backlight;
36862306a36Sopenharmony_ci	s32 bright = sd->vcur.brightness;
36962306a36Sopenharmony_ci	s32 sharp  = sd->vcur.sharpness;
37062306a36Sopenharmony_ci	s32 cntr   = sd->vcur.contrast;
37162306a36Sopenharmony_ci	s32 gam	   = sd->vcur.gamma;
37262306a36Sopenharmony_ci	s32 hue    = sd->vcur.hue;
37362306a36Sopenharmony_ci	s32 sat	   = sd->vcur.saturation;
37462306a36Sopenharmony_ci	s32 wbal   = sd->vcur.whitebal;
37562306a36Sopenharmony_ci	s32 mirror = (((sd->vcur.mirror > 0) ^ sd->mirrorMask) > 0);
37662306a36Sopenharmony_ci	s32 flip   = (((sd->vcur.flip   > 0) ^ sd->mirrorMask) > 0);
37762306a36Sopenharmony_ci	s32 freq   = (sd->vcur.AC50Hz > 0);
37862306a36Sopenharmony_ci	s32 i;
37962306a36Sopenharmony_ci
38062306a36Sopenharmony_ci	if (freq != sd->vold.AC50Hz) {
38162306a36Sopenharmony_ci		sd->vold.AC50Hz = freq;
38262306a36Sopenharmony_ci
38362306a36Sopenharmony_ci		freq = 2 * (freq == 0);
38462306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
38562306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba02, 0x00f1, 0, NULL);
38662306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00       , 0x005b, 0, NULL);
38762306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01 + freq, 0x00f1, 0, NULL);
38862306a36Sopenharmony_ci	}
38962306a36Sopenharmony_ci
39062306a36Sopenharmony_ci	if (wbal != sd->vold.whitebal) {
39162306a36Sopenharmony_ci		sd->vold.whitebal = wbal;
39262306a36Sopenharmony_ci		if (wbal < 0 || wbal > sd->vmax.whitebal)
39362306a36Sopenharmony_ci			wbal = 0;
39462306a36Sopenharmony_ci
39562306a36Sopenharmony_ci		for (i = 0; i < 2; i++) {
39662306a36Sopenharmony_ci			if (wbal == 0) { /* Normal light */
39762306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
39862306a36Sopenharmony_ci						0x0010, 0x0010, 0, NULL);
39962306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
40062306a36Sopenharmony_ci						0x0003, 0x00c1, 0, NULL);
40162306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
40262306a36Sopenharmony_ci						0x0042, 0x00c2, 0, NULL);
40362306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 3,
40462306a36Sopenharmony_ci						0xba00, 0x0200, 48, dat_wbalNL);
40562306a36Sopenharmony_ci			}
40662306a36Sopenharmony_ci
40762306a36Sopenharmony_ci			if (wbal == 1) { /* Low light */
40862306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
40962306a36Sopenharmony_ci						0x0010, 0x0010, 0, NULL);
41062306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
41162306a36Sopenharmony_ci						0x0004, 0x00c1, 0, NULL);
41262306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
41362306a36Sopenharmony_ci						0x0043, 0x00c2, 0, NULL);
41462306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 3,
41562306a36Sopenharmony_ci						0xba00, 0x0200, 48, dat_wbalLL);
41662306a36Sopenharmony_ci			}
41762306a36Sopenharmony_ci
41862306a36Sopenharmony_ci			if (wbal == 2) { /* Back light */
41962306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
42062306a36Sopenharmony_ci						0x0010, 0x0010, 0, NULL);
42162306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
42262306a36Sopenharmony_ci						0x0003, 0x00c1, 0, NULL);
42362306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 1,
42462306a36Sopenharmony_ci						0x0042, 0x00c2, 0, NULL);
42562306a36Sopenharmony_ci				ctrl_out(gspca_dev, 0x40, 3,
42662306a36Sopenharmony_ci						0xba00, 0x0200, 44, dat_wbalBL);
42762306a36Sopenharmony_ci			}
42862306a36Sopenharmony_ci		}
42962306a36Sopenharmony_ci	}
43062306a36Sopenharmony_ci
43162306a36Sopenharmony_ci	if (bright != sd->vold.brightness) {
43262306a36Sopenharmony_ci		sd->vold.brightness = bright;
43362306a36Sopenharmony_ci		if (bright < 0 || bright > sd->vmax.brightness)
43462306a36Sopenharmony_ci			bright = 0;
43562306a36Sopenharmony_ci
43662306a36Sopenharmony_ci		bright = tbl_bright[bright];
43762306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
43862306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
43962306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + bright, 0x0034, 0, NULL);
44062306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + bright, 0x00f1, 0, NULL);
44162306a36Sopenharmony_ci	}
44262306a36Sopenharmony_ci
44362306a36Sopenharmony_ci	if (sat != sd->vold.saturation) {
44462306a36Sopenharmony_ci		sd->vold.saturation = sat;
44562306a36Sopenharmony_ci		if (sat < 0 || sat > sd->vmax.saturation)
44662306a36Sopenharmony_ci			sat = 0;
44762306a36Sopenharmony_ci
44862306a36Sopenharmony_ci		sat = tbl_sat[sat];
44962306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
45062306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
45162306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00      , 0x0025, 0, NULL);
45262306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + sat, 0x00f1, 0, NULL);
45362306a36Sopenharmony_ci	}
45462306a36Sopenharmony_ci
45562306a36Sopenharmony_ci	if (sharp != sd->vold.sharpness) {
45662306a36Sopenharmony_ci		sd->vold.sharpness = sharp;
45762306a36Sopenharmony_ci		if (sharp < 0 || sharp > sd->vmax.sharpness)
45862306a36Sopenharmony_ci			sharp = 0;
45962306a36Sopenharmony_ci
46062306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
46162306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
46262306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00        , 0x0005, 0, NULL);
46362306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + sharp, 0x00f1, 0, NULL);
46462306a36Sopenharmony_ci	}
46562306a36Sopenharmony_ci
46662306a36Sopenharmony_ci	if (hue != sd->vold.hue) {
46762306a36Sopenharmony_ci		/* 0=normal  1=NB  2="sepia"  3=negative  4=other  5=other2 */
46862306a36Sopenharmony_ci		if (hue < 0 || hue > sd->vmax.hue)
46962306a36Sopenharmony_ci			hue = 0;
47062306a36Sopenharmony_ci		if (hue == sd->vmax.hue)
47162306a36Sopenharmony_ci			sd->swapRB = 1;
47262306a36Sopenharmony_ci		else
47362306a36Sopenharmony_ci			sd->swapRB = 0;
47462306a36Sopenharmony_ci
47562306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
47662306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
47762306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba70, 0x00e2, 0, NULL);
47862306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + hue * (hue < 6), 0x00f1,
47962306a36Sopenharmony_ci							0, NULL);
48062306a36Sopenharmony_ci	}
48162306a36Sopenharmony_ci
48262306a36Sopenharmony_ci	if (backlight != sd->vold.backlight) {
48362306a36Sopenharmony_ci		sd->vold.backlight = backlight;
48462306a36Sopenharmony_ci		if (backlight < 0 || backlight > sd->vmax.backlight)
48562306a36Sopenharmony_ci			backlight = 0;
48662306a36Sopenharmony_ci
48762306a36Sopenharmony_ci		backlight = tbl_backlight[backlight];
48862306a36Sopenharmony_ci		for (i = 0; i < 2; i++) {
48962306a36Sopenharmony_ci			ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
49062306a36Sopenharmony_ci			ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
49162306a36Sopenharmony_ci			ctrl_out(gspca_dev, 0x40, 1, 0xba74, 0x0006, 0, NULL);
49262306a36Sopenharmony_ci			ctrl_out(gspca_dev, 0x40, 1, 0xba80 + backlight, 0x00f1,
49362306a36Sopenharmony_ci								0, NULL);
49462306a36Sopenharmony_ci		}
49562306a36Sopenharmony_ci	}
49662306a36Sopenharmony_ci
49762306a36Sopenharmony_ci	if (hue != sd->vold.hue) {
49862306a36Sopenharmony_ci		sd->vold.hue = hue;
49962306a36Sopenharmony_ci
50062306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
50162306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
50262306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba70, 0x00e2, 0, NULL);
50362306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + hue * (hue < 6), 0x00f1,
50462306a36Sopenharmony_ci							0, NULL);
50562306a36Sopenharmony_ci	}
50662306a36Sopenharmony_ci
50762306a36Sopenharmony_ci	if (mirror != sd->vold.mirror || flip != sd->vold.flip) {
50862306a36Sopenharmony_ci		u8 dat_hvflip2[4] = {0x20, 0x01, 0xf1, 0x00};
50962306a36Sopenharmony_ci		sd->vold.mirror = mirror;
51062306a36Sopenharmony_ci		sd->vold.flip = flip;
51162306a36Sopenharmony_ci
51262306a36Sopenharmony_ci		dat_hvflip2[3] = flip + 2 * mirror;
51362306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 4, dat_hvflip1);
51462306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 3, 0xba00, 0x0200, 4, dat_hvflip2);
51562306a36Sopenharmony_ci	}
51662306a36Sopenharmony_ci
51762306a36Sopenharmony_ci	if (gam != sd->vold.gamma) {
51862306a36Sopenharmony_ci		sd->vold.gamma = gam;
51962306a36Sopenharmony_ci		if (gam < 0 || gam > sd->vmax.gamma)
52062306a36Sopenharmony_ci			gam = 0;
52162306a36Sopenharmony_ci
52262306a36Sopenharmony_ci		gam = 2 * gam;
52362306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
52462306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
52562306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba04      , 0x003b, 0, NULL);
52662306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba02 + gam, 0x00f1, 0, NULL);
52762306a36Sopenharmony_ci	}
52862306a36Sopenharmony_ci
52962306a36Sopenharmony_ci	if (cntr != sd->vold.contrast) {
53062306a36Sopenharmony_ci		sd->vold.contrast = cntr;
53162306a36Sopenharmony_ci		if (cntr < 0 || cntr > sd->vmax.contrast)
53262306a36Sopenharmony_ci			cntr = 0;
53362306a36Sopenharmony_ci
53462306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00, 0x00f0, 0, NULL);
53562306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba01, 0x00f1, 0, NULL);
53662306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + tbl_cntr1[cntr], 0x0035,
53762306a36Sopenharmony_ci							0, NULL);
53862306a36Sopenharmony_ci		ctrl_out(gspca_dev, 0x40, 1, 0xba00 + tbl_cntr2[cntr], 0x00f1,
53962306a36Sopenharmony_ci							0, NULL);
54062306a36Sopenharmony_ci	}
54162306a36Sopenharmony_ci
54262306a36Sopenharmony_ci	return 0;
54362306a36Sopenharmony_ci}
54462306a36Sopenharmony_ci
54562306a36Sopenharmony_cistatic void mi1320_post_unset_alt(struct gspca_dev *gspca_dev)
54662306a36Sopenharmony_ci{
54762306a36Sopenharmony_ci	ctrl_out(gspca_dev, 0x40, 5, 0x0000, 0x0000, 0, NULL);
54862306a36Sopenharmony_ci
54962306a36Sopenharmony_ci	fetch_validx(gspca_dev, tbl_post_unset_alt,
55062306a36Sopenharmony_ci				ARRAY_SIZE(tbl_post_unset_alt));
55162306a36Sopenharmony_ci}
552