2 * This file is part of linux driver the digital TV devices equipped with B2C2 FlexcopII(b)/III
4 * flexcop-eeprom.c - eeprom access methods (currently only MAC address reading is used)
6 * see flexcop.c for copyright information.
11 /*EEPROM (Skystar2 has one "24LC08B" chip on board) */
12 static int eeprom_write(struct adapter
*adapter
, u16 addr
, u8
*buf
, u16 len
)
14 return flex_i2c_write(adapter
, 0x20000000, 0x50, addr
, buf
, len
);
17 static int eeprom_lrc_write(struct adapter
*adapter
, u32 addr
, u32 len
, u8
*wbuf
, u8
*rbuf
, int retries
)
21 for (i
= 0; i
< retries
; i
++) {
22 if (eeprom_write(adapter
, addr
, wbuf
, len
) == len
) {
23 if (eeprom_lrc_read(adapter
, addr
, len
, rbuf
, retries
) == 1)
31 /* These functions could be used to unlock SkyStar2 cards. */
33 static int eeprom_writeKey(struct adapter
*adapter
, u8
*key
, u32 len
)
41 memcpy(wbuf
, key
, len
);
46 wbuf
[19] = calc_lrc(wbuf
, 19);
48 return eeprom_lrc_write(adapter
, 0x3e4, 20, wbuf
, rbuf
, 4);
51 static int eeprom_readKey(struct adapter
*adapter
, u8
*key
, u32 len
)
58 if (eeprom_lrc_read(adapter
, 0x3e4, 20, buf
, 4) == 0)
61 memcpy(key
, buf
, len
);
66 static char eeprom_set_mac_addr(struct adapter
*adapter
, char type
, u8
*mac
)
89 tmp
[7] = calc_lrc(tmp
, 7);
91 if (eeprom_write(adapter
, 0x3f8, tmp
, 8) == 8)
97 static int flexcop_eeprom_read(struct flexcop_device
*fc
, u16 addr
, u8
*buf
, u16 len
)
99 return fc
->i2c_request(fc
,FC_READ
,FC_I2C_PORT_EEPROM
,0x50,addr
,buf
,len
);
104 static u8
calc_lrc(u8
*buf
, int len
)
108 for (i
= 0; i
< len
; i
++)
113 static int flexcop_eeprom_request(struct flexcop_device
*fc
, flexcop_access_op_t op
, u16 addr
, u8
*buf
, u16 len
, int retries
)
116 u8 chipaddr
= 0x50 | ((addr
>> 8) & 3);
117 for (i
= 0; i
< retries
; i
++)
118 if ((ret
= fc
->i2c_request(fc
,op
,FC_I2C_PORT_EEPROM
,chipaddr
,addr
& 0xff,buf
,len
)) == 0)
123 static int flexcop_eeprom_lrc_read(struct flexcop_device
*fc
, u16 addr
, u8
*buf
, u16 len
, int retries
)
125 int ret
= flexcop_eeprom_request(fc
,FC_READ
,addr
,buf
,len
,retries
);
127 if (calc_lrc(buf
, len
- 1) != buf
[len
- 1])
132 /* JJ's comment about extended == 1: it is not presently used anywhere but was
133 * added to the low-level functions for possible support of EUI64
135 int flexcop_eeprom_check_mac_addr(struct flexcop_device
*fc
, int extended
)
140 if ((ret
= flexcop_eeprom_lrc_read(fc
,0x3f8,buf
,8,4)) == 0) {
142 err("TODO: extended (EUI64) MAC addresses aren't completely supported yet");
144 /* memcpy(fc->dvb_adapter.proposed_mac,buf,3);
147 memcpy(&fc->dvb_adapter.proposed_mac[3],&buf[5],3); */
149 memcpy(fc
->dvb_adapter
.proposed_mac
,buf
,6);
153 EXPORT_SYMBOL(flexcop_eeprom_check_mac_addr
);