summaryrefslogtreecommitdiff
path: root/v4l2-apps/util/v4l2-dbg.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'v4l2-apps/util/v4l2-dbg.cpp')
-rw-r--r--v4l2-apps/util/v4l2-dbg.cpp73
1 files changed, 49 insertions, 24 deletions
diff --git a/v4l2-apps/util/v4l2-dbg.cpp b/v4l2-apps/util/v4l2-dbg.cpp
index 70d465dea..6f373281e 100644
--- a/v4l2-apps/util/v4l2-dbg.cpp
+++ b/v4l2-apps/util/v4l2-dbg.cpp
@@ -34,12 +34,27 @@
#include <sys/klog.h>
#include <linux/videodev2.h>
+#include <linux/i2c-id.h>
#include <list>
#include <vector>
#include <map>
#include <string>
+struct driverid {
+ const char *name;
+ unsigned id;
+};
+
+extern struct driverid driverids[];
+
+struct chipid {
+ const char *name;
+ unsigned id;
+};
+
+extern struct chipid chipids[];
+
/* Short option list
Please keep in alphabetical order.
@@ -53,12 +68,13 @@ enum Option {
OptSetSlicedVbiFormat = 'b',
OptSetDevice = 'd',
OptGetDriverInfo = 'D',
- OptListChipIdents = 'C',
+ OptScanChipIdents = 'C',
OptGetChipIdent = 'c',
OptHelp = 'h',
OptLogStatus = 128,
OptVerbose,
+ OptListDriverIDs,
OptLast = 256
};
@@ -71,11 +87,12 @@ static struct option long_options[] = {
{"help", no_argument, 0, OptHelp},
{"list-registers", required_argument, 0, OptListRegisters},
{"set-register", required_argument, 0, OptSetRegister},
- {"list-chip-idents", no_argument, 0, OptListChipIdents},
+ {"scan-chip-idents", no_argument, 0, OptScanChipIdents},
{"get-chip-ident", required_argument, 0, OptGetChipIdent},
{"info", no_argument, 0, OptGetDriverInfo},
{"verbose", no_argument, 0, OptVerbose},
{"log-status", no_argument, 0, OptLogStatus},
+ {"list-driverids", no_argument, 0, OptListDriverIDs},
{0, 0, 0, 0}
};
@@ -91,11 +108,12 @@ static void usage(void)
printf(" dump registers from <min> to <max> [VIDIOC_DBG_G_REGISTER]\n");
printf(" -r, --set-register=type=<host/i2cdrv/i2caddr>,chip=<chip>,reg=<addr>,val=<val>\n");
printf(" set the register [VIDIOC_DBG_S_REGISTER]\n");
- printf(" -C, --list-chip-idents\n");
- printf(" List the available host and i2c chips [VIDIOC_G_CHIP_IDENT]\n");
+ printf(" -C, --scan-chip-idents\n");
+ printf(" Scan the available host and i2c chips [VIDIOC_G_CHIP_IDENT]\n");
printf(" -c, --get-chip-ident=type=<host/i2cdrv/i2caddr>,chip=<chip>\n");
printf(" Get the chip identifier [VIDIOC_G_CHIP_IDENT]\n");
printf(" --log-status log the board status in the kernel log [VIDIOC_LOG_STATUS]\n");
+ printf(" --list-driverids list the known I2C driver IDs for use with the i2cdrv type\n");
printf("\n");
printf(" if type == host, then <chip> is the host's chip ID (default 0)\n");
printf(" if type == i2cdrv (default), then <chip> is the I2C driver name or ID\n");
@@ -110,24 +128,13 @@ static unsigned parse_type(const std::string &s)
return V4L2_CHIP_MATCH_I2C_DRIVER;
}
-/* Copied from <linux/i2c-id.h> */
-#define I2C_DRIVERID_SAA711X 73 /* saa711x video encoders */
-#define I2C_DRIVERID_SAA717X 80 /* saa717x video encoder */
-#define I2C_DRIVERID_SAA7127 72 /* saa7124 video encoder */
-#define I2C_DRIVERID_CX25840 71 /* cx2584x video encoder */
-
static unsigned parse_chip(int type, const std::string &s)
{
if (type == V4L2_CHIP_MATCH_HOST || type == V4L2_CHIP_MATCH_I2C_ADDR || isdigit(s[0]))
return strtoul(s.c_str(), 0, 0);
- if (s == "saa711x")
- return I2C_DRIVERID_SAA711X;
- if (s == "saa717x")
- return I2C_DRIVERID_SAA717X;
- if (s == "saa7127")
- return I2C_DRIVERID_SAA7127;
- if (s == "cx2584x")
- return I2C_DRIVERID_CX25840;
+ for (int i = 0; driverids[i].name; i++)
+ if (!strcasecmp(s.c_str(), driverids[i].name))
+ return driverids[i].id;
return 0;
}
@@ -206,7 +213,18 @@ static void print_regs(int fd, struct v4l2_register *reg, unsigned long min, uns
static void print_chip(struct v4l2_chip_ident *chip)
{
- printf("Chip %d, revision 0x%08x\n", chip->ident, chip->revision);
+ const char *name = NULL;
+
+ for (int i = 0; chipids[i].name; i++) {
+ if (chipids[i].id == chip->ident) {
+ name = chipids[i].name;
+ break;
+ }
+ }
+ if (name)
+ printf("%-10s revision 0x%08x\n", name, chip->revision);
+ else
+ printf("%-10d revision 0x%08x\n", chip->ident, chip->revision);
}
static int doioctl(int fd, int request, void *parm, const char *name)
@@ -429,22 +447,23 @@ int main(int argc, char **argv)
print_chip(&chip_id);
}
- if (options[OptListChipIdents]) {
+ if (options[OptScanChipIdents]) {
int i;
chip_id.match_type = V4L2_CHIP_MATCH_HOST;
chip_id.match_chip = 0;
- chip_id.ident = 0;
- if (doioctl(fd, VIDIOC_G_CHIP_IDENT, &chip_id, "VIDIOC_G_CHIP_IDENT") == 0 && chip_id.ident)
+ while (doioctl(fd, VIDIOC_G_CHIP_IDENT, &chip_id, "VIDIOC_G_CHIP_IDENT") == 0 && chip_id.ident) {
+ printf("host 0x%x: ", chip_id.match_chip);
print_chip(&chip_id);
+ chip_id.match_chip++;
+ }
chip_id.match_type = V4L2_CHIP_MATCH_I2C_ADDR;
for (i = 0; i < 128; i++) {
chip_id.match_chip = i;
- chip_id.ident = 0;
if (doioctl(fd, VIDIOC_G_CHIP_IDENT, &chip_id, "VIDIOC_G_CHIP_IDENT") == 0 && chip_id.ident) {
- printf("0x%02x: ", i);
+ printf("i2c 0x%02x: ", i);
print_chip(&chip_id);
}
}
@@ -511,6 +530,12 @@ int main(int argc, char **argv)
}
}
+ if (options[OptListDriverIDs]) {
+ printf("Known I2C driver IDs:\n");
+ for (int i = 0; driverids[i].name; i++)
+ printf("%s\n", driverids[i].name);
+ }
+
close(fd);
exit(0);
}