summaryrefslogtreecommitdiff
path: root/v4l2-apps/util
diff options
context:
space:
mode:
Diffstat (limited to 'v4l2-apps/util')
-rw-r--r--v4l2-apps/util/xc3028-firmware/firmware-tool.c80
1 files changed, 47 insertions, 33 deletions
diff --git a/v4l2-apps/util/xc3028-firmware/firmware-tool.c b/v4l2-apps/util/xc3028-firmware/firmware-tool.c
index 03063c21f..a8e6d0c01 100644
--- a/v4l2-apps/util/xc3028-firmware/firmware-tool.c
+++ b/v4l2-apps/util/xc3028-firmware/firmware-tool.c
@@ -43,6 +43,7 @@ struct firmware_description {
__u32 type;
__u64 id;
unsigned char *data;
+ __u16 int_freq;
__u32 size;
};
@@ -150,6 +151,12 @@ int read_firmware(unsigned char* data, off_t size, struct firmware** f_res) {
p += sizeof(f->desc[i].type);
f->desc[i].id = __le64_to_cpu(*(__u64*) p);
p += sizeof(f->desc[i].id);
+
+ if (f->desc[i].type & HAS_IF) {
+ f->desc[i].int_freq = __le16_to_cpu(*(__u16 *) p);
+ p += sizeof(f->desc[i].int_freq);
+ }
+
f->desc[i].size = __le32_to_cpu(*(__u32*) p);
p += sizeof(f->desc[i].size);
@@ -282,64 +289,69 @@ void write_firmware_file(const char* filename, struct firmware *f) {
void dump_firm_type(unsigned int type)
{
- if (type & BASE)
- printf("BASE ");
- if (type & F8MHZ)
+ if (type & SCODE)
+ printf("SCODE FW ");
+ else if (type & BASE)
+ printf("BASE FW ");
+ else
+ printf("STD FW ");
+
+ if (type & F8MHZ)
printf("F8MHZ ");
- if (type & MTS)
+ if (type & MTS)
printf("MTS ");
- if (type & D2620)
+ if (type & D2620)
printf("D2620 ");
- if (type & D2633)
+ if (type & D2633)
printf("D2633 ");
- if (type & DTV6)
+ if (type & DTV6)
printf("DTV6 ");
- if (type & QAM)
+ if (type & QAM)
printf("QAM ");
- if (type & DTV7)
+ if (type & DTV7)
printf("DTV7 ");
- if (type & DTV78)
+ if (type & DTV78)
printf("DTV78 ");
- if (type & DTV8)
+ if (type & DTV8)
printf("DTV8 ");
- if (type & FM)
+ if (type & FM)
printf("FM ");
- if (type & INPUT1)
+ if (type & INPUT1)
printf("INPUT1 ");
- if (type & LCD)
+ if (type & LCD)
printf("LCD ");
- if (type & NOGD)
+ if (type & NOGD)
printf("NOGD ");
- if (type & MONO)
+ if (type & MONO)
printf("MONO ");
- if (type & ATSC)
+ if (type & ATSC)
printf("ATSC ");
- if (type & IF)
+ if (type & IF)
printf("IF ");
- if (type & LG60)
+ if (type & LG60)
printf("LG60 ");
- if (type & ATI638)
+ if (type & ATI638)
printf("ATI638 ");
- if (type & OREN538)
+ if (type & OREN538)
printf("OREN538 ");
- if (type & OREN36)
+ if (type & OREN36)
printf("OREN36 ");
- if (type & TOYOTA388)
+ if (type & TOYOTA388)
printf("TOYOTA388 ");
- if (type & TOYOTA794)
+ if (type & TOYOTA794)
printf("TOYOTA794 ");
- if (type & DIBCOM52)
+ if (type & DIBCOM52)
printf("DIBCOM52 ");
- if (type & ZARLINK456)
+ if (type & ZARLINK456)
printf("ZARLINK456 ");
- if (type & CHINA)
+ if (type & CHINA)
printf("CHINA ");
- if (type & F6MHZ)
+ if (type & F6MHZ)
printf("F6MHZ ");
- if (type & INPUT2)
+ if (type & INPUT2)
printf("INPUT2 ");
- if (type & SCODE)
- printf("SCODE ");
+ if (type & HAS_IF)
+ printf("HAS IF ");
}
void dump_firm_std(v4l2_std_id id)
@@ -452,7 +464,7 @@ void dump_firm_std(v4l2_std_id id)
printf ("A2/A ");
curr_id = V4L2_STD_A2_A;
} else if ( (id & V4L2_STD_A2_B) == V4L2_STD_A2_B) {
- printf ("A2/A ");
+ printf ("A2/B ");
curr_id = V4L2_STD_A2_B;
} else if ( (id & V4L2_STD_NICAM) == V4L2_STD_NICAM) {
printf ("NICAM ");
@@ -488,10 +500,12 @@ void list_firmware(struct firmware *f) {
f->version);
printf("standards:\t%u\n", f->nr_desc);
for(i = 0; i < f->nr_desc; ++i) {
- printf("Firmware %u, ", i);
+ printf("Firmware %2u, ", i);
printf("type: ");
dump_firm_type(f->desc[i].type);
printf("(0x%08x), ", f->desc[i].type);
+ if (f->desc[i].type & HAS_IF)
+ printf("IF = %.2f MHz ", f->desc[i].int_freq/1000.0);
printf("id: ");
dump_firm_std(f->desc[i].id);
printf("(%016llx), ", f->desc[i].id);