summaryrefslogtreecommitdiff
path: root/v4l2-apps/util/v4l-board-dbg.c
diff options
context:
space:
mode:
Diffstat (limited to 'v4l2-apps/util/v4l-board-dbg.c')
-rw-r--r--v4l2-apps/util/v4l-board-dbg.c82
1 files changed, 53 insertions, 29 deletions
diff --git a/v4l2-apps/util/v4l-board-dbg.c b/v4l2-apps/util/v4l-board-dbg.c
index 9d27ed8e1..468b03089 100644
--- a/v4l2-apps/util/v4l-board-dbg.c
+++ b/v4l2-apps/util/v4l-board-dbg.c
@@ -30,6 +30,26 @@
#define ARRAY_SIZE(arr) ((int)(sizeof(arr) / sizeof((arr)[0])))
+struct board_list {
+ char *queryname;
+ int prefix; /* Register prefix size */
+ struct board_regs *regs;
+ int regs_size;
+ struct board_regs *alt_regs;
+ int alt_regs_size;
+};
+
+struct board_list boards[] = {
+ [0] = { /* From bttv-dbg.h */
+ .queryname = BTTV_IDENT,
+ .prefix = sizeof (BTTV_PREFIX),
+ .regs = bt8xx_regs,
+ .regs_size = ARRAY_SIZE(bt8xx_regs),
+ .alt_regs = bt8xx_regs_other,
+ .alt_regs_size = ARRAY_SIZE(bt8xx_regs_other),
+ },
+};
+
static int is_get=0, is_set=0;
static int doioctl(int fd, int request, void *parm, const char *name)
@@ -86,6 +106,8 @@ int main(int argc, char **argv)
int i;
int fd = -1;
struct v4l2_register reg;
+ struct board_list *curr_bd;
+ int board = 0;
struct option long_options[] = {
/* Please keep in alphabetical order of the short option.
That makes it easier to see which options are still free. */
@@ -95,6 +117,9 @@ int main(int argc, char **argv)
{0, 0, 0, 0}
};
+ /* FIXME: need to check for 'board' */
+ curr_bd = &boards[board];
+
/* command args */
if (argc == 1) {
usage();
@@ -147,16 +172,16 @@ int main(int argc, char **argv)
reg.match_chip = 0;
if (is_get) {
- for (i = 0; i < ARRAY_SIZE(bt8xx_regs); i++) {
+ for (i = 0; i < curr_bd->regs_size; i++) {
char name[256];
- reg.reg = bt8xx_regs[i].reg;
+ reg.reg = curr_bd->regs[i].reg;
if (ioctl(fd, VIDIOC_DBG_G_REGISTER, &reg) < 0) {
printf("Error while reading\n");
continue;
}
- sprintf(name, "%s:", bt8xx_regs[i].name);
+ sprintf(name, "%s:", curr_bd->regs[i].name);
- switch (bt8xx_regs[i].size) {
+ switch (curr_bd->regs[i].size) {
case 1:
printf("%-32s %02llx ", name, reg.val & 0xff);
break;
@@ -167,7 +192,7 @@ int main(int argc, char **argv)
printf("%-32s %08llx ", name, reg.val & 0xffffffff);
break;
}
- print_bin (reg.val, bt8xx_regs[i].size);
+ print_bin (reg.val, curr_bd->regs[i].size);
printf("\n");
}
return 0;
@@ -178,7 +203,7 @@ int main(int argc, char **argv)
int val;
int r, size;
unsigned prev;
- struct board_regs *bt_reg;
+ struct board_regs *bd_reg;
reg_name = strtok(reg_set, "=:");
val = strtol(strtok(NULL, "=:"), 0L, 0);
@@ -189,43 +214,43 @@ int main(int argc, char **argv)
}
- for (i = ARRAY_SIZE(bt8xx_regs) - 1; i >=0 ; i--) {
- if (!strcasecmp(reg_name, bt8xx_regs[i].name)) {
- bt_reg = &bt8xx_regs[i];
- r = bt8xx_regs[i].reg;
- size = bt8xx_regs[i].size;
+ for (i = curr_bd->regs_size - 1; i >=0 ; i--) {
+ if (!strcasecmp(reg_name, curr_bd->regs[i].name)) {
+ bd_reg = &curr_bd->regs[i];
+ r = bd_reg->reg;
+ size = bd_reg->size;
break;
}
}
if (i < 0) {
- for (i = ARRAY_SIZE(bt8xx_regs_other) - 1; i >=0 ; i--) {
- if (!strcasecmp(reg_name, bt8xx_regs_other[i].name)) {
- bt_reg = &bt8xx_regs_other[i];
- r = bt8xx_regs_other[i].reg;
- size = bt8xx_regs_other[i].size;
+ for (i = curr_bd->alt_regs_size - 1; i >=0 ; i--) {
+ if (!strcasecmp(reg_name, curr_bd->alt_regs[i].name)) {
+ bd_reg = &curr_bd->alt_regs[i];
+ r = bd_reg->reg;
+ size = bd_reg->size;
break;
}
}
}
if (i < 0) {
- for (i = ARRAY_SIZE(bt8xx_regs) - 1; i >=0 ; i--) {
- if (!strcasecmp(reg_name, bt8xx_regs[i].name+6)) {
- bt_reg = &bt8xx_regs[i];
- r = bt8xx_regs[i].reg;
- size = bt8xx_regs[i].size;
+ for (i = curr_bd->regs_size - 1; i >=0 ; i--) {
+ if (!strcasecmp(reg_name, curr_bd->regs[i].name + curr_bd->prefix)) {
+ bd_reg = &curr_bd->regs[i];
+ r = bd_reg->reg;
+ size = bd_reg->size;
break;
}
}
}
if (i < 0) {
- for (i = ARRAY_SIZE(bt8xx_regs_other) - 1; i >=0 ; i--) {
- if (!strcasecmp(reg_name, bt8xx_regs_other[i].name+6)) {
- bt_reg = &bt8xx_regs_other[i];
- r = bt8xx_regs_other[i].reg;
- size = bt8xx_regs_other[i].size;
+ for (i = curr_bd->alt_regs_size - 1; i >=0 ; i--) {
+ if (!strcasecmp(reg_name, curr_bd->alt_regs[i].name + curr_bd->prefix)) {
+ bd_reg = &curr_bd->regs[i];
+ r = bd_reg->reg;
+ size = bd_reg->size;
break;
}
}
@@ -257,7 +282,7 @@ int main(int argc, char **argv)
}
printf("Changing value of register %s(0x%x) from 0x%02x to 0x%02x\n",
- bt_reg->name, r, prev, (unsigned int)reg.val);
+ bd_reg->name, r, prev, (unsigned int)reg.val);
prev = reg.val;
@@ -271,9 +296,8 @@ int main(int argc, char **argv)
}
if (reg.val != prev) {
printf("Value of register %s(0x%x) is now 0x%02x\n",
- bt_reg->name, r, (unsigned int)reg.val);
+ bd_reg->name, r, (unsigned int)reg.val);
}
-
}
close(fd);