Commit 23fbee6f authored by Marton Nemeth's avatar Marton Nemeth Committed by Mauro Carvalho Chehab

V4L/DVB (13388): gspca - pac7302: Add white balance control.

Signed-off-by: default avatarMarton Nemeth <nm127@freemail.hu>
Signed-off-by: default avatarJean-Francois Moine <moinejf@free.fr>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent b760812e
...@@ -57,6 +57,7 @@ ...@@ -57,6 +57,7 @@
0 | 0x0f..0x20 | setcolors() 0 | 0x0f..0x20 | setcolors()
0 | 0xa2..0xab | setbrightcont() 0 | 0xa2..0xab | setbrightcont()
0 | 0xc5 | setredbalance() 0 | 0xc5 | setredbalance()
0 | 0xc6 | setwhitebalance()
0 | 0xc7 | setbluebalance() 0 | 0xc7 | setbluebalance()
0 | 0xdc | setbrightcont(), setcolors() 0 | 0xdc | setbrightcont(), setcolors()
3 | 0x02 | setexposure() 3 | 0x02 | setexposure()
...@@ -80,6 +81,7 @@ struct sd { ...@@ -80,6 +81,7 @@ struct sd {
unsigned char brightness; unsigned char brightness;
unsigned char contrast; unsigned char contrast;
unsigned char colors; unsigned char colors;
unsigned char white_balance;
unsigned char red_balance; unsigned char red_balance;
unsigned char blue_balance; unsigned char blue_balance;
unsigned char gain; unsigned char gain;
...@@ -101,6 +103,8 @@ static int sd_setcontrast(struct gspca_dev *gspca_dev, __s32 val); ...@@ -101,6 +103,8 @@ static int sd_setcontrast(struct gspca_dev *gspca_dev, __s32 val);
static int sd_getcontrast(struct gspca_dev *gspca_dev, __s32 *val); static int sd_getcontrast(struct gspca_dev *gspca_dev, __s32 *val);
static int sd_setcolors(struct gspca_dev *gspca_dev, __s32 val); static int sd_setcolors(struct gspca_dev *gspca_dev, __s32 val);
static int sd_getcolors(struct gspca_dev *gspca_dev, __s32 *val); static int sd_getcolors(struct gspca_dev *gspca_dev, __s32 *val);
static int sd_setwhitebalance(struct gspca_dev *gspca_dev, __s32 val);
static int sd_getwhitebalance(struct gspca_dev *gspca_dev, __s32 *val);
static int sd_setredbalance(struct gspca_dev *gspca_dev, __s32 val); static int sd_setredbalance(struct gspca_dev *gspca_dev, __s32 val);
static int sd_getredbalance(struct gspca_dev *gspca_dev, __s32 *val); static int sd_getredbalance(struct gspca_dev *gspca_dev, __s32 *val);
static int sd_setbluebalance(struct gspca_dev *gspca_dev, __s32 val); static int sd_setbluebalance(struct gspca_dev *gspca_dev, __s32 val);
...@@ -165,6 +169,20 @@ static struct ctrl sd_ctrls[] = { ...@@ -165,6 +169,20 @@ static struct ctrl sd_ctrls[] = {
.set = sd_setcolors, .set = sd_setcolors,
.get = sd_getcolors, .get = sd_getcolors,
}, },
{
{
.id = V4L2_CID_WHITE_BALANCE_TEMPERATURE,
.type = V4L2_CTRL_TYPE_INTEGER,
.name = "White Balance",
.minimum = 0,
.maximum = 255,
.step = 1,
#define WHITEBALANCE_DEF 4
.default_value = WHITEBALANCE_DEF,
},
.set = sd_setwhitebalance,
.get = sd_getwhitebalance,
},
{ {
{ {
.id = V4L2_CID_RED_BALANCE, .id = V4L2_CID_RED_BALANCE,
...@@ -525,6 +543,7 @@ static int sd_config(struct gspca_dev *gspca_dev, ...@@ -525,6 +543,7 @@ static int sd_config(struct gspca_dev *gspca_dev,
sd->brightness = BRIGHTNESS_DEF; sd->brightness = BRIGHTNESS_DEF;
sd->contrast = CONTRAST_DEF; sd->contrast = CONTRAST_DEF;
sd->colors = COLOR_DEF; sd->colors = COLOR_DEF;
sd->white_balance = WHITEBALANCE_DEF;
sd->red_balance = REDBALANCE_DEF; sd->red_balance = REDBALANCE_DEF;
sd->blue_balance = BLUEBALANCE_DEF; sd->blue_balance = BLUEBALANCE_DEF;
sd->gain = GAIN_DEF; sd->gain = GAIN_DEF;
...@@ -595,6 +614,21 @@ static int setcolors(struct gspca_dev *gspca_dev) ...@@ -595,6 +614,21 @@ static int setcolors(struct gspca_dev *gspca_dev)
return ret; return ret;
} }
static int setwhitebalance(struct gspca_dev *gspca_dev)
{
struct sd *sd = (struct sd *) gspca_dev;
int ret;
ret = reg_w(gspca_dev, 0xff, 0x00); /* page 0 */
if (0 <= ret)
ret = reg_w(gspca_dev, 0xc6, sd->white_balance);
if (0 <= ret)
ret = reg_w(gspca_dev, 0xdc, 0x01);
PDEBUG(D_CONF|D_STREAM, "white_balance: %i", sd->white_balance);
return ret;
}
static int setredbalance(struct gspca_dev *gspca_dev) static int setredbalance(struct gspca_dev *gspca_dev)
{ {
struct sd *sd = (struct sd *) gspca_dev; struct sd *sd = (struct sd *) gspca_dev;
...@@ -705,6 +739,8 @@ static int sd_start(struct gspca_dev *gspca_dev) ...@@ -705,6 +739,8 @@ static int sd_start(struct gspca_dev *gspca_dev)
ret = setbrightcont(gspca_dev); ret = setbrightcont(gspca_dev);
if (0 <= ret) if (0 <= ret)
ret = setcolors(gspca_dev); ret = setcolors(gspca_dev);
if (0 <= ret)
ret = setwhitebalance(gspca_dev);
if (0 <= ret) if (0 <= ret)
ret = setredbalance(gspca_dev); ret = setredbalance(gspca_dev);
if (0 <= ret) if (0 <= ret)
...@@ -941,6 +977,27 @@ static int sd_getcolors(struct gspca_dev *gspca_dev, __s32 *val) ...@@ -941,6 +977,27 @@ static int sd_getcolors(struct gspca_dev *gspca_dev, __s32 *val)
return 0; return 0;
} }
static int sd_setwhitebalance(struct gspca_dev *gspca_dev, __s32 val)
{
struct sd *sd = (struct sd *) gspca_dev;
int ret = 0;
sd->white_balance = val;
if (gspca_dev->streaming)
ret = setwhitebalance(gspca_dev);
if (0 <= ret)
ret = 0;
return ret;
}
static int sd_getwhitebalance(struct gspca_dev *gspca_dev, __s32 *val)
{
struct sd *sd = (struct sd *) gspca_dev;
*val = sd->white_balance;
return 0;
}
static int sd_setredbalance(struct gspca_dev *gspca_dev, __s32 val) static int sd_setredbalance(struct gspca_dev *gspca_dev, __s32 val)
{ {
struct sd *sd = (struct sd *) gspca_dev; struct sd *sd = (struct sd *) gspca_dev;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment