aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohannes Stezenbach <js@linuxtv.org>2005-05-17 00:54:14 -0400
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-05-17 10:59:25 -0400
commit778241313819e17de3bdf91523c724b4704402c6 (patch)
treeb0638104fbf6de5a6bfec9ed28d55c33f43e3320
parent3ed8a31cb387b2ae3e4ca508f973931b61e6f6bd (diff)
[PATCH] dvb: flexcop: fix MAC address reading
read MAC address directly into dvb_adapter->proposed_mac Signed-off-by: Patrick Boettcher <pb@linuxtv.org> Signed-off-by: Johannes Stezenbach <js@linuxtv.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--drivers/media/dvb/b2c2/flexcop-common.h1
-rw-r--r--drivers/media/dvb/b2c2/flexcop-eeprom.c10
-rw-r--r--drivers/media/dvb/b2c2/flexcop-usb.c3
-rw-r--r--drivers/media/dvb/b2c2/flexcop.c10
4 files changed, 11 insertions, 13 deletions
diff --git a/drivers/media/dvb/b2c2/flexcop-common.h b/drivers/media/dvb/b2c2/flexcop-common.h
index 82b7f8fa7b9c..534876d616b8 100644
--- a/drivers/media/dvb/b2c2/flexcop-common.h
+++ b/drivers/media/dvb/b2c2/flexcop-common.h
@@ -57,7 +57,6 @@ struct flexcop_device {
57 int init_state; 57 int init_state;
58 58
59 /* device information */ 59 /* device information */
60 u8 mac_address[6];
61 int has_32_hw_pid_filter; 60 int has_32_hw_pid_filter;
62 flexcop_revision_t rev; 61 flexcop_revision_t rev;
63 flexcop_device_type_t dev_type; 62 flexcop_device_type_t dev_type;
diff --git a/drivers/media/dvb/b2c2/flexcop-eeprom.c b/drivers/media/dvb/b2c2/flexcop-eeprom.c
index 4dbedd819734..bbcf070a178d 100644
--- a/drivers/media/dvb/b2c2/flexcop-eeprom.c
+++ b/drivers/media/dvb/b2c2/flexcop-eeprom.c
@@ -129,8 +129,6 @@ static int flexcop_eeprom_lrc_read(struct flexcop_device *fc, u16 addr, u8 *buf,
129 return ret; 129 return ret;
130} 130}
131 131
132/* TODO how is it handled in USB */
133
134/* JJ's comment about extended == 1: it is not presently used anywhere but was 132/* JJ's comment about extended == 1: it is not presently used anywhere but was
135 * added to the low-level functions for possible support of EUI64 133 * added to the low-level functions for possible support of EUI64
136 */ 134 */
@@ -139,18 +137,16 @@ int flexcop_eeprom_check_mac_addr(struct flexcop_device *fc, int extended)
139 u8 buf[8]; 137 u8 buf[8];
140 int ret = 0; 138 int ret = 0;
141 139
142 memset(fc->mac_address,0,6);
143
144 if ((ret = flexcop_eeprom_lrc_read(fc,0x3f8,buf,8,4)) == 0) { 140 if ((ret = flexcop_eeprom_lrc_read(fc,0x3f8,buf,8,4)) == 0) {
145 if (extended != 0) { 141 if (extended != 0) {
146 err("TODO: extended (EUI64) MAC addresses aren't completely supported yet"); 142 err("TODO: extended (EUI64) MAC addresses aren't completely supported yet");
147 ret = -EINVAL; 143 ret = -EINVAL;
148/* memcpy(fc->mac_address,buf,3); 144/* memcpy(fc->dvb_adapter.proposed_mac,buf,3);
149 mac[3] = 0xfe; 145 mac[3] = 0xfe;
150 mac[4] = 0xff; 146 mac[4] = 0xff;
151 memcpy(&fc->mac_address[3],&buf[5],3); */ 147 memcpy(&fc->dvb_adapter.proposed_mac[3],&buf[5],3); */
152 } else 148 } else
153 memcpy(fc->mac_address,buf,6); 149 memcpy(fc->dvb_adapter.proposed_mac,buf,6);
154 } 150 }
155 return ret; 151 return ret;
156} 152}
diff --git a/drivers/media/dvb/b2c2/flexcop-usb.c b/drivers/media/dvb/b2c2/flexcop-usb.c
index 98470ce9a054..20db6329a686 100644
--- a/drivers/media/dvb/b2c2/flexcop-usb.c
+++ b/drivers/media/dvb/b2c2/flexcop-usb.c
@@ -180,7 +180,8 @@ static int flexcop_usb_memory_req(struct flexcop_usb *fc_usb,flexcop_usb_request
180 180
181static int flexcop_usb_get_mac_addr(struct flexcop_device *fc, int extended) 181static int flexcop_usb_get_mac_addr(struct flexcop_device *fc, int extended)
182{ 182{
183 return flexcop_usb_memory_req(fc->bus_specific,B2C2_USB_READ_V8_MEM,V8_MEMORY_PAGE_FLASH,0x1f010,1,fc->mac_address,6); 183 return flexcop_usb_memory_req(fc->bus_specific,B2C2_USB_READ_V8_MEM,
184 V8_MEMORY_PAGE_FLASH,0x1f010,1,fc->dvb_adapter.proposed_mac,6);
184} 185}
185 186
186#if 0 187#if 0
diff --git a/drivers/media/dvb/b2c2/flexcop.c b/drivers/media/dvb/b2c2/flexcop.c
index 1998267207fb..ad590875064b 100644
--- a/drivers/media/dvb/b2c2/flexcop.c
+++ b/drivers/media/dvb/b2c2/flexcop.c
@@ -233,16 +233,18 @@ int flexcop_device_initialize(struct flexcop_device *fc)
233 233
234 flexcop_smc_ctrl(fc, 0); 234 flexcop_smc_ctrl(fc, 0);
235 235
236 if ((ret = flexcop_dvb_init(fc)))
237 goto error;
238
239 /* do the MAC address reading after initializing the dvb_adapter */
236 if (fc->get_mac_addr(fc, 0) == 0) { 240 if (fc->get_mac_addr(fc, 0) == 0) {
237 u8 *b = fc->mac_address; 241 u8 *b = fc->dvb_adapter.proposed_mac;
238 info("MAC address = %02x:%02x:%02x:%02x:%02x:%02x", b[0],b[1],b[2],b[3],b[4],b[5]); 242 info("MAC address = %02x:%02x:%02x:%02x:%02x:%02x", b[0],b[1],b[2],b[3],b[4],b[5]);
239 flexcop_set_mac_filter(fc,fc->mac_address); 243 flexcop_set_mac_filter(fc,b);
240 flexcop_mac_filter_ctrl(fc,1); 244 flexcop_mac_filter_ctrl(fc,1);
241 } else 245 } else
242 warn("reading of MAC address failed.\n"); 246 warn("reading of MAC address failed.\n");
243 247
244 if ((ret = flexcop_dvb_init(fc)))
245 goto error;
246 248
247 if ((ret = flexcop_i2c_init(fc))) 249 if ((ret = flexcop_i2c_init(fc)))
248 goto error; 250 goto error;