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