summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@infradead.org>2007-11-15 11:16:48 -0200
committerMauro Carvalho Chehab <mchehab@infradead.org>2007-11-15 11:16:48 -0200
commitb0405db8cb1195cd7049ab455362dc0f6a0ec3af (patch)
tree731452fd9282235eb4ac80be850373d27d8ffb41
parent7a898d5e0fce82c7a6c726f3a49ee5a3b4268f93 (diff)
downloadmediapointer-dvb-s2-b0405db8cb1195cd7049ab455362dc0f6a0ec3af.tar.gz
mediapointer-dvb-s2-b0405db8cb1195cd7049ab455362dc0f6a0ec3af.tar.bz2
Improve --list commant to show the firmware type
From: Mauro Carvalho Chehab <mchehab@infradead.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
-rw-r--r--v4l2-apps/util/xc3028-firmware/firmware-tool.c69
1 files changed, 67 insertions, 2 deletions
diff --git a/v4l2-apps/util/xc3028-firmware/firmware-tool.c b/v4l2-apps/util/xc3028-firmware/firmware-tool.c
index 46be5b833..f4c4c912c 100644
--- a/v4l2-apps/util/xc3028-firmware/firmware-tool.c
+++ b/v4l2-apps/util/xc3028-firmware/firmware-tool.c
@@ -28,6 +28,8 @@
#include <asm/byteorder.h>
#include <asm/types.h>
+#include "../../../linux/drivers/media/video/tuner-xc2028-types.h"
+
#include "standards.h"
#define LIST_ACTION (1<<0)
@@ -277,6 +279,67 @@ void write_firmware_file(const char* filename, struct firmware *f) {
close(fd);
}
+void dump_firm_type(unsigned int type)
+{
+ if (type & BASE)
+ printf("BASE ");
+ if (type & F8MHZ)
+ printf("F8MHZ ");
+ if (type & MTS)
+ printf("MTS ");
+ if (type & D2620)
+ printf("D2620 ");
+ if (type & D2633)
+ printf("D2633 ");
+ if (type & DTV6)
+ printf("DTV6 ");
+ if (type & QAM)
+ printf("QAM ");
+ if (type & DTV7)
+ printf("DTV7 ");
+ if (type & DTV78)
+ printf("DTV78 ");
+ if (type & DTV8)
+ printf("DTV8 ");
+ if (type & FM)
+ printf("FM ");
+ if (type & INPUT1)
+ printf("INPUT1 ");
+ if (type & LCD)
+ printf("LCD ");
+ if (type & NOGD)
+ printf("NOGD ");
+ if (type & MONO)
+ printf("MONO ");
+ if (type & ATSC)
+ printf("ATSC ");
+ if (type & IF)
+ printf("IF ");
+ if (type & LG60)
+ printf("LG60 ");
+ if (type & ATI638)
+ printf("ATI638 ");
+ if (type & OREN538)
+ printf("OREN538 ");
+ if (type & OREN36)
+ printf("OREN36 ");
+ if (type & TOYOTA388)
+ printf("TOYOTA388 ");
+ if (type & TOYOTA794)
+ printf("TOYOTA794 ");
+ if (type & DIBCOM52)
+ printf("DIBCOM52 ");
+ if (type & ZARLINK456)
+ printf("ZARLINK456 ");
+ if (type & CHINA)
+ printf("CHINA ");
+ if (type & F6MHZ)
+ printf("F6MHZ ");
+ if (type & INPUT2)
+ printf("INPUT2 ");
+ if (type & SCODE)
+ printf("SCODE ");
+}
void list_firmware(struct firmware *f) {
unsigned int i = 0;
@@ -288,8 +351,10 @@ void list_firmware(struct firmware *f) {
for(i = 0; i < f->nr_desc; ++i) {
printf("\n");
printf("standard firmware %u\n", i);
- printf("type:\t%u\n", f->desc[i].type);
- printf("id:\t%llu\n", f->desc[i].id);
+ printf("type:\t");
+ dump_firm_type(f->desc[i].type);
+ printf("(0x%08x)\n", f->desc[i].type);
+ printf("id:\t%016llx\n", f->desc[i].id);
printf("size:\t%u\n", f->desc[i].size);
}
}