diff options
author | Michael Hunold <devnull@localhost> | 2003-07-14 10:08:24 +0000 |
---|---|---|
committer | Michael Hunold <devnull@localhost> | 2003-07-14 10:08:24 +0000 |
commit | 640091386272beac3e86f7c53732da6c69430160 (patch) | |
tree | fb8d93cd69dea446d13f1d7b235b0a61e99c4a28 /linux/drivers/media/dvb/b2c2/skystar2.c | |
parent | 532a8fde5c412450d7fd10ce3c2acd6c112de09b (diff) | |
download | mediapointer-dvb-s2-640091386272beac3e86f7c53732da6c69430160.tar.gz mediapointer-dvb-s2-640091386272beac3e86f7c53732da6c69430160.tar.bz2 |
- indented the source properly
- removed some bogus separation comments
- changed the default debug level to 0
Diffstat (limited to 'linux/drivers/media/dvb/b2c2/skystar2.c')
-rw-r--r-- | linux/drivers/media/dvb/b2c2/skystar2.c | 3183 |
1 files changed, 1512 insertions, 1671 deletions
diff --git a/linux/drivers/media/dvb/b2c2/skystar2.c b/linux/drivers/media/dvb/b2c2/skystar2.c index da117e8c9..64de94590 100644 --- a/linux/drivers/media/dvb/b2c2/skystar2.c +++ b/linux/drivers/media/dvb/b2c2/skystar2.c @@ -35,444 +35,425 @@ #include "demux.h" #include "dvb_net.h" - -int debug = 1; -#define dprintk if(debug == 1) printk +int debug = 0; +#define dprintk if(debug != 0) printk #define SizeOfBufDMA1 0x3AC00 #define SizeOfBufDMA2 0x758 struct DmaQ { - u32 bus_addr; - u32 head; - u32 tail; - u32 buffer_size; - u8 * buffer; + u32 bus_addr; + u32 head; + u32 tail; + u32 buffer_size; + u8 *buffer; }; struct packet_header_t { - u32 sync_byte; - u32 transport_error_indicator; - u32 payload_unit_start_indicator; - u32 transport_priority; - u32 pid; - u32 transport_scrambling_control; - u32 adaptation_field_control; - u32 continuity_counter; + u32 sync_byte; + u32 transport_error_indicator; + u32 payload_unit_start_indicator; + u32 transport_priority; + u32 pid; + u32 transport_scrambling_control; + u32 adaptation_field_control; + u32 continuity_counter; }; struct adapter { - struct pci_dev *pdev; + struct pci_dev *pdev; - u8 card_revision; - u32 B2C2_revision; - u32 PidFilterMax; - u32 MacFilterMax; - u32 irq; - u32 io_mem; - u32 io_port; - u8 mac_addr[8]; - u32 dwSramType; + u8 card_revision; + u32 B2C2_revision; + u32 PidFilterMax; + u32 MacFilterMax; + u32 irq; + u32 io_mem; + u32 io_port; + u8 mac_addr[8]; + u32 dwSramType; - struct dvb_adapter * dvb_adapter; - struct dvb_demux demux; - struct dmxdev dmxdev; - struct dmx_frontend hw_frontend; - struct dmx_frontend mem_frontend; - struct dvb_i2c_bus *i2c_bus; - struct dvb_net dvbnet; + struct dvb_adapter *dvb_adapter; + struct dvb_demux demux; + struct dmxdev dmxdev; + struct dmx_frontend hw_frontend; + struct dmx_frontend mem_frontend; + struct dvb_i2c_bus *i2c_bus; + struct dvb_net dvbnet; - struct semaphore i2c_sem; + struct semaphore i2c_sem; - struct DmaQ DmaQ1; - struct DmaQ DmaQ2; + struct DmaQ DmaQ1; + struct DmaQ DmaQ2; - u32 dma_ctrl; - u32 dma_status; + u32 dma_ctrl; + u32 dma_status; - u32 capturing; + u32 capturing; - spinlock_t lock; + spinlock_t lock; - u16 pids[0x27]; - u32 mac_filter; + u16 pids[0x27]; + u32 mac_filter; }; -//------------------------------------------------------------------- void linuxdelayms(u32 usecs) { - while ( usecs > 0) - { - udelay(1000); + while (usecs > 0) { + udelay(1000); - usecs--; - } + usecs--; + } } ///////////////////////////////////////////////////////////////////// -// register functions +// register functions ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -void WriteRegDW(struct adapter * adapter, u32 reg, u32 value) +void WriteRegDW(struct adapter *adapter, u32 reg, u32 value) { - u32 flags; + u32 flags; - save_flags(flags); - cli(); + save_flags(flags); + cli(); - writel(value, adapter->io_mem + reg); + writel(value, adapter->io_mem + reg); - restore_flags(flags); + restore_flags(flags); } -//------------------------------------------------------------------- -u32 ReadRegDW(struct adapter * adapter, u32 reg) +u32 ReadRegDW(struct adapter *adapter, u32 reg) { - return readl(adapter->io_mem + reg); + return readl(adapter->io_mem + reg); } -//------------------------------------------------------------------- u32 WriteRegOp(struct adapter * adapter, u32 reg, u32 operation, u32 andvalue, u32 orvalue) { - u32 tmp; + u32 tmp; - tmp = ReadRegDW(adapter, reg); + tmp = ReadRegDW(adapter, reg); - if ( operation == 1 ) tmp = tmp | orvalue; - if ( operation == 2 ) tmp = tmp & andvalue; - if ( operation == 3 ) tmp = (tmp & andvalue) | orvalue; + if (operation == 1) + tmp = tmp | orvalue; + if (operation == 2) + tmp = tmp & andvalue; + if (operation == 3) + tmp = (tmp & andvalue) | orvalue; - WriteRegDW(adapter, reg, tmp); + WriteRegDW(adapter, reg, tmp); - return tmp; + return tmp; } ///////////////////////////////////////////////////////////////////// -// I2C +// I2C //////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- u32 i2cMainWriteForFlex2(struct adapter * adapter, u32 command, u8 * buf, u32 retries) { - u32 i; - u32 value; + u32 i; + u32 value; - WriteRegDW(adapter, 0x100, 0); - WriteRegDW(adapter, 0x100, command); + WriteRegDW(adapter, 0x100, 0); + WriteRegDW(adapter, 0x100, command); - for ( i = 0; i < retries; i++ ) - { - value = ReadRegDW(adapter, 0x100); + for (i = 0; i < retries; i++) { + value = ReadRegDW(adapter, 0x100); - if ( ( value & 0x40000000) == 0 ) - { - if ( ( value & 0x81000000 ) == 0x80000000 ) - { - if ( buf != 0 ) *buf = ( value >> 0x10 ) & 0xff; + if ((value & 0x40000000) == 0) { + if ((value & 0x81000000) == 0x80000000) { + if (buf != 0) + *buf = (value >> 0x10) & 0xff; - return 1; - } + return 1; + } - } else { - - WriteRegDW(adapter, 0x100, 0); - WriteRegDW(adapter, 0x100, command); + } else { + + WriteRegDW(adapter, 0x100, 0); + WriteRegDW(adapter, 0x100, command); + } } - } - return 0; + return 0; } ///////////////////////////////////////////////////////////////////// -// device = 0x10000000 for tuner -// 0x20000000 for eeprom +// device = 0x10000000 for tuner +// 0x20000000 for eeprom ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- + u32 i2cMainSetup(u32 device, u32 chip_addr, u8 op, u8 addr, u32 value, u32 len) { - u32 command; + u32 command; - command = device | ( (len-1) << 26 ) | ( value << 16 ) | ( addr << 8 ) | chip_addr; + command = device | ((len - 1) << 26) | (value << 16) | (addr << 8) | chip_addr; - if ( op != 0 ) command = command | 0x03000000; else command = command | 0x01000000; - - return command; + if (op != 0) + command = command | 0x03000000; + else + command = command | 0x01000000; + + return command; } -//------------------------------------------------------------------- u32 FlexI2cRead4(struct adapter * adapter, u32 device, u32 chip_addr, u16 addr, u8 * buf, u8 len) { - u32 command; - u32 value; + u32 command; + u32 value; - int result, i; + int result, i; - command = i2cMainSetup(device, chip_addr, 1, addr, 0, len); + command = i2cMainSetup(device, chip_addr, 1, addr, 0, len); - result = i2cMainWriteForFlex2(adapter, command, buf, 100000); + result = i2cMainWriteForFlex2(adapter, command, buf, 100000); - if ( (result & 0xff) != 0 ) - { - if ( len > 1 ) - { - value = ReadRegDW(adapter, 0x104); + if ((result & 0xff) != 0) { + if (len > 1) { + value = ReadRegDW(adapter, 0x104); - for ( i = 1; i < len; i++ ) - { - buf[i] = value & 0xff; - value = value >> 8; - } + for (i = 1; i < len; i++) { + buf[i] = value & 0xff; + value = value >> 8; + } + } } - } - return result; + return result; } -//------------------------------------------------------------------- u32 FlexI2cWrite4(struct adapter * adapter, u32 device, u32 chip_addr, u32 addr, u8 * buf, u8 len) { - u32 command; - u32 value; - int i; + u32 command; + u32 value; + int i; - if ( len > 1) - { - value = 0; - - for ( i = len; i > 1; i--) - { - value = value << 8; - value = value | buf[i-1]; - } + if (len > 1) { + value = 0; + + for (i = len; i > 1; i--) { + value = value << 8; + value = value | buf[i - 1]; + } - WriteRegDW(adapter, 0x104, value); - } + WriteRegDW(adapter, 0x104, value); + } - command = i2cMainSetup(device, chip_addr, 0, addr, buf[0], len); + command = i2cMainSetup(device, chip_addr, 0, addr, buf[0], len); - return i2cMainWriteForFlex2(adapter, command, 0, 100000); + return i2cMainWriteForFlex2(adapter, command, 0, 100000); } -//------------------------------------------------------------------- u32 fixChipAddr(u32 device, u32 bus, u32 addr) { - if ( device == 0x20000000 ) return bus | ( ( addr >> 8 ) & 3 ); + if (device == 0x20000000) + return bus | ((addr >> 8) & 3); - return bus; + return bus; } -//------------------------------------------------------------------- u32 FLEXI2C_read(struct adapter * adapter, u32 device, u32 bus, u32 addr, u8 * buf, u32 len) { - u32 ChipAddr; - u32 bytes_to_transfer; - u8 * start; + u32 ChipAddr; + u32 bytes_to_transfer; + u8 *start; // dprintk("%s:\n", __FUNCTION__); - start = buf; + start = buf; + + while (len != 0) { + bytes_to_transfer = len; - while ( len != 0 ) - { - bytes_to_transfer = len; + if (bytes_to_transfer > 4) + bytes_to_transfer = 4; - if ( bytes_to_transfer > 4 ) bytes_to_transfer = 4; - - ChipAddr = fixChipAddr(device, bus, addr); + ChipAddr = fixChipAddr(device, bus, addr); - if ( FlexI2cRead4(adapter, device, ChipAddr, addr, buf, bytes_to_transfer) == 0 ) return buf - start; + if (FlexI2cRead4(adapter, device, ChipAddr, addr, buf, bytes_to_transfer) == 0) + return buf - start; - buf = buf + bytes_to_transfer; - addr = addr + bytes_to_transfer; - len = len - bytes_to_transfer; - }; + buf = buf + bytes_to_transfer; + addr = addr + bytes_to_transfer; + len = len - bytes_to_transfer; + }; - return buf - start; + return buf - start; } -//------------------------------------------------------------------- u32 FLEXI2C_write(struct adapter * adapter, u32 device, u32 bus, u32 addr, u8 * buf, u32 len) { - u32 ChipAddr; - u32 bytes_to_transfer; - u8 * start; - + u32 ChipAddr; + u32 bytes_to_transfer; + u8 *start; + // dprintk("%s:\n", __FUNCTION__); - start = buf; + start = buf; + + while (len != 0) { + bytes_to_transfer = len; - while ( len != 0 ) - { - bytes_to_transfer = len; + if (bytes_to_transfer > 4) + bytes_to_transfer = 4; - if ( bytes_to_transfer > 4 ) bytes_to_transfer = 4; - - ChipAddr = fixChipAddr(device, bus, addr); + ChipAddr = fixChipAddr(device, bus, addr); - if ( FlexI2cWrite4(adapter, device, ChipAddr, addr, buf, bytes_to_transfer) == 0 ) return buf - start; + if (FlexI2cWrite4(adapter, device, ChipAddr, addr, buf, bytes_to_transfer) == 0) + return buf - start; - buf = buf + bytes_to_transfer; - addr = addr + bytes_to_transfer; - len = len - bytes_to_transfer; - } + buf = buf + bytes_to_transfer; + addr = addr + bytes_to_transfer; + len = len - bytes_to_transfer; + } - return buf - start; + return buf - start; } -static int master_xfer (struct dvb_i2c_bus * i2c, const struct i2c_msg * msgs, int num) +static int master_xfer(struct dvb_i2c_bus *i2c, const struct i2c_msg *msgs, int num) { - struct adapter * tmp = i2c->data; - int i, ret=0; + struct adapter *tmp = i2c->data; + int i, ret = 0; - if (down_interruptible (&tmp->i2c_sem)) return -ERESTARTSYS; - - if(0) - { - dprintk("%s:\n",__FUNCTION__); + if (down_interruptible(&tmp->i2c_sem)) + return -ERESTARTSYS; - for(i=0; i<num; i++) - { - printk("message %d: flags=%x, addr=0x%04x, buf=%x, len=%d \n", i, msgs[i].flags, msgs[i].addr, (u32)msgs[i].buf, msgs[i].len); + if (0) { + dprintk("%s:\n", __FUNCTION__); + + for (i = 0; i < num; i++) { + printk("message %d: flags=%x, addr=0x%04x, buf=%x, len=%d \n", i, msgs[i].flags, msgs[i].addr, (u32) msgs[i].buf, msgs[i].len); + } } - } + // allow only the vp310 frontend to access the bus + if ((msgs[0].addr != 0x0E) && (msgs[0].addr != 0x61)) { + up(&tmp->i2c_sem); - // allow only the vp310 frontend to access the bus - if ( ( msgs[0].addr != 0x0E) && ( msgs[0].addr != 0x61 ) ) - { - up (&tmp->i2c_sem); + return -EREMOTEIO; + } - return -EREMOTEIO; - } + if ((num == 1) && (msgs[0].buf != NULL)) { + if (msgs[0].flags == I2C_M_RD) { + ret = -EINVAL; - if ( ( num == 1 ) && ( msgs[0].buf != NULL ) ) - { - if ( msgs[0].flags == I2C_M_RD ) - { - ret = -EINVAL; - - } else { + } else { - // single writes do have the reg addr in buf[0] and data in buf[1] to buf[n] - ret = FLEXI2C_write(tmp, 0x10000000, msgs[0].addr, msgs[0].buf[0], &msgs[0].buf[1], msgs[0].len - 1); + // single writes do have the reg addr in buf[0] and data in buf[1] to buf[n] + ret = FLEXI2C_write(tmp, 0x10000000, msgs[0].addr, msgs[0].buf[0], &msgs[0].buf[1], msgs[0].len - 1); - if ( ret != msgs[0].len - 1) - ret = -EREMOTEIO; - else - ret = num; - } + if (ret != msgs[0].len - 1) + ret = -EREMOTEIO; + else + ret = num; + } - } else if ( ( num == 2 ) && ( msgs[1].buf != NULL ) ) { - - // i2c reads consist of a reg addr _write_ followed by a data read, so msg[1].flags has to be examined - if ( msgs[1].flags == I2C_M_RD ) - { - ret = FLEXI2C_read(tmp, 0x10000000, msgs[0].addr, msgs[0].buf[0], msgs[1].buf, msgs[1].len); + } else if ((num == 2) && (msgs[1].buf != NULL)) { - } else { + // i2c reads consist of a reg addr _write_ followed by a data read, so msg[1].flags has to be examined + if (msgs[1].flags == I2C_M_RD) { + ret = FLEXI2C_read(tmp, 0x10000000, msgs[0].addr, msgs[0].buf[0], msgs[1].buf, msgs[1].len); - ret = FLEXI2C_write(tmp, 0x10000000, msgs[0].addr, msgs[0].buf[0], msgs[1].buf, msgs[1].len); - } + } else { - if (ret != msgs[1].len) - ret = -EREMOTEIO; - else - ret = num; - } + ret = FLEXI2C_write(tmp, 0x10000000, msgs[0].addr, msgs[0].buf[0], msgs[1].buf, msgs[1].len); + } - up (&tmp->i2c_sem); + if (ret != msgs[1].len) + ret = -EREMOTEIO; + else + ret = num; + } + + up(&tmp->i2c_sem); - // master xfer functions always return the number of successfully - // transmitted messages, not the number of transmitted bytes. - // return -EREMOTEIO in case of failure. - return ret; + // master xfer functions always return the number of successfully + // transmitted messages, not the number of transmitted bytes. + // return -EREMOTEIO in case of failure. + return ret; } ///////////////////////////////////////////////////////////////////// // SRAM (Skystar2 rev2.3 has one "ISSI IS61LV256" chip on board, // but it seems that FlexCopII can work with more than one chip) ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -u32 SRAMSetNetDest(struct adapter *adapter, u8 dest) + +u32 SRAMSetNetDest(struct adapter * adapter, u8 dest) { - u32 tmp; + u32 tmp; - udelay(1000); + udelay(1000); - tmp = ( ReadRegDW(adapter, 0x714) & 0xFFFFFFFC ) | ( dest & 3 ); + tmp = (ReadRegDW(adapter, 0x714) & 0xFFFFFFFC) | (dest & 3); - udelay(1000); + udelay(1000); - WriteRegDW(adapter, 0x714, tmp); - WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); - udelay(1000); + udelay(1000); - return tmp; + return tmp; } -//------------------------------------------------------------------- -u32 SRAMSetCaiDest(struct adapter *adapter, u8 dest) +u32 SRAMSetCaiDest(struct adapter * adapter, u8 dest) { - u32 tmp; + u32 tmp; - udelay(1000); + udelay(1000); - tmp = ( ReadRegDW(adapter, 0x714) & 0xFFFFFFF3 ) | ( ( dest & 3 ) << 2); + tmp = (ReadRegDW(adapter, 0x714) & 0xFFFFFFF3) | ((dest & 3) << 2); - udelay(1000); - udelay(1000); + udelay(1000); + udelay(1000); - WriteRegDW(adapter, 0x714, tmp); - WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); - udelay(1000); + udelay(1000); - return tmp; + return tmp; } -//------------------------------------------------------------------- -u32 SRAMSetCaoDest(struct adapter *adapter, u8 dest) +u32 SRAMSetCaoDest(struct adapter * adapter, u8 dest) { - u32 tmp; - - udelay(1000); + u32 tmp; + + udelay(1000); - tmp = ( ReadRegDW(adapter, 0x714) & 0xFFFFFFCF ) | ( ( dest & 3 ) << 4 ); + tmp = (ReadRegDW(adapter, 0x714) & 0xFFFFFFCF) | ((dest & 3) << 4); - udelay(1000); - udelay(1000); + udelay(1000); + udelay(1000); - WriteRegDW(adapter, 0x714, tmp); - WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); - udelay(1000); + udelay(1000); - return tmp; + return tmp; } -//------------------------------------------------------------------- -u32 SRAMSetMediaDest(struct adapter *adapter, u8 dest) +u32 SRAMSetMediaDest(struct adapter * adapter, u8 dest) { - u32 tmp; - - udelay(1000); + u32 tmp; - tmp = ( ReadRegDW(adapter, 0x714) & 0xFFFFFF3F ) | ( ( dest & 3 ) << 6 ); + udelay(1000); + + tmp = (ReadRegDW(adapter, 0x714) & 0xFFFFFF3F) | ((dest & 3) << 6); - udelay(1000); - udelay(1000); + udelay(1000); + udelay(1000); - WriteRegDW(adapter, 0x714, tmp); - WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); + WriteRegDW(adapter, 0x714, tmp); - udelay(1000); + udelay(1000); - return tmp; + return tmp; } ///////////////////////////////////////////////////////////////////// @@ -485,250 +466,241 @@ u32 SRAMSetMediaDest(struct adapter *adapter, u8 dest) // bits 28-29 : memory bank selector // bit 31 : busy flag //////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -void FlexSramWrite(struct adapter * adapter, u32 bank, u32 addr, u8 *buf, u32 len) + +void FlexSramWrite(struct adapter *adapter, u32 bank, u32 addr, u8 * buf, u32 len) { - u32 i, command, retries; + u32 i, command, retries; - for ( i = 0; i < len; i++) - { - command = bank | addr | 0x04000000 | ( *buf << 0x10 ); + for (i = 0; i < len; i++) { + command = bank | addr | 0x04000000 | (*buf << 0x10); - retries = 2; + retries = 2; - while ( ( ( ReadRegDW(adapter, 0x700) & 0x80000000 ) != 0 ) && ( retries > 0 ) ) - { - linuxdelayms(1); - retries--; - }; + while (((ReadRegDW(adapter, 0x700) & 0x80000000) != 0) && (retries > 0)) { + linuxdelayms(1); + retries--; + }; - if ( retries == 0 ) printk("%s: SRAM timeout\n", __FUNCTION__); + if (retries == 0) + printk("%s: SRAM timeout\n", __FUNCTION__); - WriteRegDW(adapter, 0x700, command); - - buf++; - addr++; - } + WriteRegDW(adapter, 0x700, command); + + buf++; + addr++; + } } -//------------------------------------------------------------------- -void FlexSramRead(struct adapter * adapter, u32 bank, u32 addr, u8 *buf, u32 len) +void FlexSramRead(struct adapter *adapter, u32 bank, u32 addr, u8 * buf, u32 len) { - u32 i, command, value, retries; + u32 i, command, value, retries; - for ( i = 0; i < len; i++) - { - command = bank | addr | 0x04008000 ; + for (i = 0; i < len; i++) { + command = bank | addr | 0x04008000; - retries = 10000; - - while ( ( ( ReadRegDW(adapter, 0x700) & 0x80000000 ) != 0 ) && ( retries > 0 ) ) - { - linuxdelayms(1); - retries--; - }; - - if ( retries == 0 ) printk("%s: SRAM timeout\n", __FUNCTION__); - - WriteRegDW(adapter, 0x700, command); + retries = 10000; - retries = 10000; + while (((ReadRegDW(adapter, 0x700) & 0x80000000) != 0) && (retries > 0)) { + linuxdelayms(1); + retries--; + }; - while ( ( ( ReadRegDW(adapter, 0x700) & 0x80000000 ) != 0 ) && ( retries > 0 ) ) - { - linuxdelayms(1); - retries--; - }; - - if ( retries == 0 ) printk("%s: SRAM timeout\n", __FUNCTION__); - - value = ReadRegDW(adapter, 0x700) >> 0x10; + if (retries == 0) + printk("%s: SRAM timeout\n", __FUNCTION__); - *buf = ( value & 0xff ); + WriteRegDW(adapter, 0x700, command); - addr++; - buf++; - } -} + retries = 10000; -//------------------------------------------------------------------- -void SRAM_writeChunk(struct adapter * adapter, u32 addr, u8 * buf, u16 len) -{ - u32 bank; - - bank = 0; + while (((ReadRegDW(adapter, 0x700) & 0x80000000) != 0) && (retries > 0)) { + linuxdelayms(1); + retries--; + }; - if ( adapter->dwSramType == 0x20000 ) - { - bank = ( addr & 0x18000 ) << 0x0D; - } + if (retries == 0) + printk("%s: SRAM timeout\n", __FUNCTION__); - if ( adapter->dwSramType == 0x00000 ) - { - if ( (addr >> 0x0F) == 0 ) bank = 0x20000000; else bank = 0x10000000; - } + value = ReadRegDW(adapter, 0x700) >> 0x10; - FlexSramWrite(adapter, bank, addr & 0x7FFF, buf, len); + *buf = (value & 0xff); + + addr++; + buf++; + } } -//------------------------------------------------------------------- -void SRAM_readChunk(struct adapter * adapter, u32 addr, u8 * buf, u16 len) +void SRAM_writeChunk(struct adapter *adapter, u32 addr, u8 * buf, u16 len) { - u32 bank; + u32 bank; - bank = 0; + bank = 0; - if ( adapter->dwSramType == 0x20000 ) - { - bank = ( addr & 0x18000 ) << 0x0D; - } + if (adapter->dwSramType == 0x20000) { + bank = (addr & 0x18000) << 0x0D; + } - if ( adapter->dwSramType == 0x00000 ) - { - if ( ( addr >> 0x0F ) == 0 ) bank = 0x20000000; else bank = 0x10000000; - } + if (adapter->dwSramType == 0x00000) { + if ((addr >> 0x0F) == 0) + bank = 0x20000000; + else + bank = 0x10000000; + } - FlexSramRead(adapter, bank, addr & 0x7FFF, buf, len); + FlexSramWrite(adapter, bank, addr & 0x7FFF, buf, len); } -//------------------------------------------------------------------- -void SRAM_read(struct adapter * adapter, u32 addr, u8 * buf, u32 len) +void SRAM_readChunk(struct adapter *adapter, u32 addr, u8 * buf, u16 len) { - u32 length; + u32 bank; - while ( len != 0 ) - { - length = len; + bank = 0; - // check if the address range belongs to the same - // 32K memory chip. If not, the data is read from - // one chip at a time. - if ( (addr >> 0x0F) != ( (addr+len-1) >> 0x0F ) ) - { - length = ( ( (addr >> 0x0F) + 1 ) << 0x0F ) - addr; + if (adapter->dwSramType == 0x20000) { + bank = (addr & 0x18000) << 0x0D; } - SRAM_readChunk(adapter, addr, buf, length); + if (adapter->dwSramType == 0x00000) { + if ((addr >> 0x0F) == 0) + bank = 0x20000000; + else + bank = 0x10000000; + } - addr = addr + length; - buf = buf + length; - len = len - length; - } + FlexSramRead(adapter, bank, addr & 0x7FFF, buf, len); } -//------------------------------------------------------------------- -void SRAM_write(struct adapter * adapter, u32 addr, u8 * buf, u32 len) +void SRAM_read(struct adapter *adapter, u32 addr, u8 * buf, u32 len) { - u32 length; + u32 length; + + while (len != 0) { + length = len; - while ( len != 0 ) - { - length = len; + // check if the address range belongs to the same + // 32K memory chip. If not, the data is read from + // one chip at a time. + if ((addr >> 0x0F) != ((addr + len - 1) >> 0x0F)) { + length = (((addr >> 0x0F) + 1) << 0x0F) - addr; + } + + SRAM_readChunk(adapter, addr, buf, length); - // check if the address range belongs to the same - // 32K memory chip. If not, the data is written to - // one chip at a time. - if ( ( addr >> 0x0F ) != ( (addr+len-1) >> 0x0F ) ) - { - length = ( ( ( addr >> 0x0F )+1 ) << 0x0F ) - addr; + addr = addr + length; + buf = buf + length; + len = len - length; } +} + +void SRAM_write(struct adapter *adapter, u32 addr, u8 * buf, u32 len) +{ + u32 length; + + while (len != 0) { + length = len; - SRAM_writeChunk(adapter, addr, buf, length); + // check if the address range belongs to the same + // 32K memory chip. If not, the data is written to + // one chip at a time. + if ((addr >> 0x0F) != ((addr + len - 1) >> 0x0F)) { + length = (((addr >> 0x0F) + 1) << 0x0F) - addr; + } + + SRAM_writeChunk(adapter, addr, buf, length); - addr = addr + length; - buf = buf + length; - len = len - length; - } + addr = addr + length; + buf = buf + length; + len = len - length; + } } -//------------------------------------------------------------------- -void SRAM_setSize(struct adapter * adapter, u32 mask) +void SRAM_setSize(struct adapter *adapter, u32 mask) { - WriteRegDW(adapter, 0x71C, ( mask | ( ~0x30000 & ReadRegDW(adapter, 0x71C) ) ) ); + WriteRegDW(adapter, 0x71C, (mask | (~0x30000 & ReadRegDW(adapter, 0x71C)))); } -//------------------------------------------------------------------- -u32 SRAM_init(struct adapter * adapter) +u32 SRAM_init(struct adapter *adapter) { - u32 tmp; + u32 tmp; - tmp = ReadRegDW(adapter, 0x71C); + tmp = ReadRegDW(adapter, 0x71C); - WriteRegDW(adapter, 0x71C, 1); + WriteRegDW(adapter, 0x71C, 1); - if ( ReadRegDW(adapter, 0x71C) != 0) - { - WriteRegDW(adapter, 0x71C, tmp); + if (ReadRegDW(adapter, 0x71C) != 0) { + WriteRegDW(adapter, 0x71C, tmp); - adapter->dwSramType = tmp & 0x30000; + adapter->dwSramType = tmp & 0x30000; - dprintk("%s: dwSramType = %x\n", __FUNCTION__, adapter->dwSramType); + dprintk("%s: dwSramType = %x\n", __FUNCTION__, adapter->dwSramType); - } else { + } else { - adapter->dwSramType = 0x10000; + adapter->dwSramType = 0x10000; - dprintk("%s: dwSramType = %x\n", __FUNCTION__, adapter->dwSramType); - } + dprintk("%s: dwSramType = %x\n", __FUNCTION__, adapter->dwSramType); + } - return adapter->dwSramType; + return adapter->dwSramType; } -//------------------------------------------------------------------- -int SRAM_testLocation(struct adapter * adapter, u32 mask, u32 addr) +int SRAM_testLocation(struct adapter *adapter, u32 mask, u32 addr) { - u8 tmp1, tmp2; + u8 tmp1, tmp2; - dprintk("%s: mask = %x, addr = %x\n", __FUNCTION__, mask, addr); + dprintk("%s: mask = %x, addr = %x\n", __FUNCTION__, mask, addr); - SRAM_setSize(adapter, mask); - SRAM_init(adapter); + SRAM_setSize(adapter, mask); + SRAM_init(adapter); + + tmp2 = 0xA5; + tmp1 = 0x4F; - tmp2 = 0xA5; - tmp1 = 0x4F; + SRAM_write(adapter, addr, &tmp2, 1); + SRAM_write(adapter, addr + 4, &tmp1, 1); - SRAM_write(adapter, addr, &tmp2, 1); - SRAM_write(adapter, addr + 4, &tmp1, 1); + tmp2 = 0; - tmp2 = 0; + linuxdelayms(20); - linuxdelayms(20); + SRAM_read(adapter, addr, &tmp2, 1); + SRAM_read(adapter, addr, &tmp2, 1); - SRAM_read(adapter, addr, &tmp2, 1); - SRAM_read(adapter, addr, &tmp2, 1); - - dprintk("%s: wrote 0xA5, read 0x%2x\n", __FUNCTION__, tmp2); + dprintk("%s: wrote 0xA5, read 0x%2x\n", __FUNCTION__, tmp2); - if ( tmp2 != 0xA5 ) return 0; + if (tmp2 != 0xA5) + return 0; - tmp2 = 0x5A; - tmp1 = 0xF4; + tmp2 = 0x5A; + tmp1 = 0xF4; - SRAM_write(adapter, addr, &tmp2, 1); - SRAM_write(adapter, addr + 4, &tmp1, 1); + SRAM_write(adapter, addr, &tmp2, 1); + SRAM_write(adapter, addr + 4, &tmp1, 1); - tmp2 = 0; + tmp2 = 0; - linuxdelayms(20); + linuxdelayms(20); - SRAM_read(adapter, addr, &tmp2, 1); - SRAM_read(adapter, addr, &tmp2, 1); + SRAM_read(adapter, addr, &tmp2, 1); + SRAM_read(adapter, addr, &tmp2, 1); - dprintk("%s: wrote 0x5A, read 0x%2x\n", __FUNCTION__, tmp2); + dprintk("%s: wrote 0x5A, read 0x%2x\n", __FUNCTION__, tmp2); - if ( tmp2 != 0x5A ) return 0; + if (tmp2 != 0x5A) + return 0; - return 1; + return 1; } -//------------------------------------------------------------------- u32 SRAM_length(struct adapter * adapter) { - if ( adapter->dwSramType == 0x10000 ) return 32768; // 32K - if ( adapter->dwSramType == 0x00000 ) return 65536; // 64K - if ( adapter->dwSramType == 0x20000 ) return 131072; // 128K + if (adapter->dwSramType == 0x10000) + return 32768; // 32K + if (adapter->dwSramType == 0x00000) + return 65536; // 64K + if (adapter->dwSramType == 0x20000) + return 131072; // 128K - return 32768; // 32K + return 32768; // 32K } ////////////////////////////////////////////////////////////////////// @@ -745,920 +717,847 @@ u32 SRAM_length(struct adapter * adapter) // bank 2 covers addresses 0x10000-0x17FFF // bank 3 covers addresses 0x18000-0x1FFFF ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -int SramDetectForFlex2(struct adapter * adapter) + +int SramDetectForFlex2(struct adapter *adapter) { - u32 tmp, tmp2, tmp3; - - dprintk("%s:\n", __FUNCTION__); + u32 tmp, tmp2, tmp3; - tmp = ReadRegDW(adapter, 0x208); - WriteRegDW(adapter, 0x208, 0); + dprintk("%s:\n", __FUNCTION__); - tmp2 = ReadRegDW(adapter, 0x71C); + tmp = ReadRegDW(adapter, 0x208); + WriteRegDW(adapter, 0x208, 0); - dprintk("%s: tmp2 = %x\n", __FUNCTION__, tmp2); + tmp2 = ReadRegDW(adapter, 0x71C); - WriteRegDW(adapter, 0x71C, 1); + dprintk("%s: tmp2 = %x\n", __FUNCTION__, tmp2); - tmp3 = ReadRegDW(adapter, 0x71C); + WriteRegDW(adapter, 0x71C, 1); - dprintk("%s: tmp3 = %x\n", __FUNCTION__, tmp3); + tmp3 = ReadRegDW(adapter, 0x71C); - WriteRegDW(adapter, 0x71C, tmp2); + dprintk("%s: tmp3 = %x\n", __FUNCTION__, tmp3); - // check for internal SRAM ??? - tmp3--; - if ( tmp3 != 0 ) - { - SRAM_setSize(adapter, 0x10000); - SRAM_init(adapter); - WriteRegDW(adapter, 0x208, tmp); + WriteRegDW(adapter, 0x71C, tmp2); - dprintk("%s: sram size = 32K\n", __FUNCTION__); + // check for internal SRAM ??? + tmp3--; + if (tmp3 != 0) { + SRAM_setSize(adapter, 0x10000); + SRAM_init(adapter); + WriteRegDW(adapter, 0x208, tmp); - return 32; - } + dprintk("%s: sram size = 32K\n", __FUNCTION__); - if ( SRAM_testLocation(adapter, 0x20000, 0x18000) != 0 ) - { - SRAM_setSize(adapter, 0x20000); - SRAM_init(adapter); - WriteRegDW(adapter, 0x208, tmp); + return 32; + } - dprintk("%s: sram size = 128K\n", __FUNCTION__); + if (SRAM_testLocation(adapter, 0x20000, 0x18000) != 0) { + SRAM_setSize(adapter, 0x20000); + SRAM_init(adapter); + WriteRegDW(adapter, 0x208, tmp); - return 128; - } + dprintk("%s: sram size = 128K\n", __FUNCTION__); - if ( SRAM_testLocation(adapter, 0x00000, 0x10000) != 0 ) - { - SRAM_setSize(adapter, 0x00000); - SRAM_init(adapter); - WriteRegDW(adapter, 0x208, tmp); + return 128; + } - dprintk("%s: sram size = 64K\n", __FUNCTION__); + if (SRAM_testLocation(adapter, 0x00000, 0x10000) != 0) { + SRAM_setSize(adapter, 0x00000); + SRAM_init(adapter); + WriteRegDW(adapter, 0x208, tmp); - return 64; - } + dprintk("%s: sram size = 64K\n", __FUNCTION__); - if ( SRAM_testLocation(adapter, 0x10000, 0x00000) != 0 ) - { - SRAM_setSize(adapter, 0x10000); - SRAM_init(adapter); - WriteRegDW(adapter, 0x208, tmp); + return 64; + } - dprintk("%s: sram size = 32K\n", __FUNCTION__); + if (SRAM_testLocation(adapter, 0x10000, 0x00000) != 0) { + SRAM_setSize(adapter, 0x10000); + SRAM_init(adapter); + WriteRegDW(adapter, 0x208, tmp); - return 32; - } + dprintk("%s: sram size = 32K\n", __FUNCTION__); - SRAM_setSize(adapter, 0x10000); - SRAM_init(adapter); - WriteRegDW(adapter, 0x208, tmp); + return 32; + } - dprintk("%s: SRAM detection failed. Set to 32K \n", __FUNCTION__); + SRAM_setSize(adapter, 0x10000); + SRAM_init(adapter); + WriteRegDW(adapter, 0x208, tmp); - return 0; + dprintk("%s: SRAM detection failed. Set to 32K \n", __FUNCTION__); + + return 0; } -//------------------------------------------------------------------- -void SLL_detectSramSize(struct adapter * adapter) +void SLL_detectSramSize(struct adapter *adapter) { - SramDetectForFlex2(adapter); + SramDetectForFlex2(adapter); } ///////////////////////////////////////////////////////////////////// -// EEPROM (Skystar2 has one "24LC08B" chip on board) +// EEPROM (Skystar2 has one "24LC08B" chip on board) //////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -int EEPROM_write(struct adapter * adapter, u16 addr, u8 *buf, u16 len) +int EEPROM_write(struct adapter *adapter, u16 addr, u8 * buf, u16 len) { - return FLEXI2C_write(adapter, 0x20000000, 0x50, addr, buf, len); + return FLEXI2C_write(adapter, 0x20000000, 0x50, addr, buf, len); } -//------------------------------------------------------------------- -int EEPROM_read(struct adapter * adapter, u16 addr, u8 *buf, u16 len) +int EEPROM_read(struct adapter *adapter, u16 addr, u8 * buf, u16 len) { - return FLEXI2C_read(adapter, 0x20000000, 0x50, addr, buf, len); + return FLEXI2C_read(adapter, 0x20000000, 0x50, addr, buf, len); } -//------------------------------------------------------------------- u8 calc_LRC(u8 * buf, u32 len) { - u32 i; - u8 sum; - - sum = 0; + u32 i; + u8 sum; + + sum = 0; - for (i = 0; i < len; i++) sum = sum ^ buf[i]; + for (i = 0; i < len; i++) + sum = sum ^ buf[i]; - return sum; + return sum; } -//------------------------------------------------------------------- -int EEPROM_LRC_read(struct adapter * adapter, u32 addr, u32 len, u8 * buf, u32 retries) +int EEPROM_LRC_read(struct adapter *adapter, u32 addr, u32 len, u8 * buf, u32 retries) { - int i; + int i; - for ( i = 0; i < retries; i++) - { - if ( EEPROM_read(adapter, addr, buf, len) == len ) - { - if ( calc_LRC(buf, len-1) == buf[len-1] ) return 1; + for (i = 0; i < retries; i++) { + if (EEPROM_read(adapter, addr, buf, len) == len) { + if (calc_LRC(buf, len - 1) == buf[len - 1]) + return 1; + } } - } - return 0; + return 0; } -//------------------------------------------------------------------- -int EEPROM_LRC_write(struct adapter * adapter, u32 addr, u32 len, u8 * wbuf, u8 * rbuf, u32 retries) +int EEPROM_LRC_write(struct adapter *adapter, u32 addr, u32 len, u8 * wbuf, u8 * rbuf, u32 retries) { - int i; + int i; - for ( i = 0; i < retries; i++) - { - if ( EEPROM_write(adapter, addr, wbuf, len) == len ) - { - if ( EEPROM_LRC_read(adapter, addr, len, rbuf, retries) == 1 ) return 1; + for (i = 0; i < retries; i++) { + if (EEPROM_write(adapter, addr, wbuf, len) == len) { + if (EEPROM_LRC_read(adapter, addr, len, rbuf, retries) == 1) + return 1; + } } - } - - return 0; + + return 0; } ///////////////////////////////////////////////////////////////////// // These functions could be called from the initialization routine // to unlock SkyStar2 cards, locked by "Europe On Line". -// +// // in cards from "Europe On Line" the key is: // -// u8 key[20] = { -// 0xB2, 0x01, 0x00, 0x00, -// 0x00, 0x00, 0x00, 0x00, -// 0x00, 0x00, 0x00, 0x00, -// 0x00, 0x00, 0x00, 0x00, -// }; +// u8 key[20] = { +// 0xB2, 0x01, 0x00, 0x00, +// 0x00, 0x00, 0x00, 0x00, +// 0x00, 0x00, 0x00, 0x00, +// 0x00, 0x00, 0x00, 0x00, +// }; // -// LRC = 0xB3; +// LRC = 0xB3; // // in unlocked cards the key is: // -// u8 key[20] = { -// 0xB2, 0x00, 0x00, 0x00, -// 0x00, 0x00, 0x00, 0x00, -// 0x00, 0x00, 0x00, 0x00, -// 0x00, 0x00, 0x00, 0x00, -// }; +// u8 key[20] = { +// 0xB2, 0x00, 0x00, 0x00, +// 0x00, 0x00, 0x00, 0x00, +// 0x00, 0x00, 0x00, 0x00, +// 0x00, 0x00, 0x00, 0x00, +// }; // // LRC = 0xB2; ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -int EEPROM_writeKey(struct adapter * adapter, u8 * key, u32 len) +int EEPROM_writeKey(struct adapter *adapter, u8 * key, u32 len) { - u8 rbuf[20]; - u8 wbuf[20]; + u8 rbuf[20]; + u8 wbuf[20]; - if ( len != 16 ) return 0; + if (len != 16) + return 0; - memcpy(wbuf, key, len); + memcpy(wbuf, key, len); - wbuf[16] = 0; - wbuf[17] = 0; - wbuf[18] = 0; - wbuf[19] = calc_LRC(wbuf, 19); + wbuf[16] = 0; + wbuf[17] = 0; + wbuf[18] = 0; + wbuf[19] = calc_LRC(wbuf, 19); - return EEPROM_LRC_write(adapter, 0x3E4, 20, wbuf, rbuf, 4); + return EEPROM_LRC_write(adapter, 0x3E4, 20, wbuf, rbuf, 4); } -//------------------------------------------------------------------- -int EEPROM_readKey(struct adapter * adapter, u8 * key, u32 len) +int EEPROM_readKey(struct adapter *adapter, u8 * key, u32 len) { - u8 buf[20]; + u8 buf[20]; - if ( len != 16 ) return 0; + if (len != 16) + return 0; - if ( EEPROM_LRC_read(adapter, 0x3E4, 20, buf, 4) == 0 ) return 0; + if (EEPROM_LRC_read(adapter, 0x3E4, 20, buf, 4) == 0) + return 0; - memcpy(key, buf, len); + memcpy(key, buf, len); - return 1; + return 1; } -//------------------------------------------------------------------- -int EEPROM_getMacAddr(struct adapter * adapter, char type, u8 * mac) +int EEPROM_getMacAddr(struct adapter *adapter, char type, u8 * mac) { - u8 tmp[8]; + u8 tmp[8]; - if ( EEPROM_LRC_read(adapter, 0x3F8, 8, tmp, 4) != 0 ) - { - if ( type != 0 ) - { - mac[0] = tmp[0]; - mac[1] = tmp[1]; - mac[2] = tmp[2]; - mac[3] = 0xFE; - mac[4] = 0xFF; - mac[5] = tmp[3]; - mac[6] = tmp[4]; - mac[7] = tmp[5]; - - } else { - - mac[0] = tmp[0]; - mac[1] = tmp[1]; - mac[2] = tmp[2]; - mac[3] = tmp[3]; - mac[4] = tmp[4]; - mac[5] = tmp[5]; - } + if (EEPROM_LRC_read(adapter, 0x3F8, 8, tmp, 4) != 0) { + if (type != 0) { + mac[0] = tmp[0]; + mac[1] = tmp[1]; + mac[2] = tmp[2]; + mac[3] = 0xFE; + mac[4] = 0xFF; + mac[5] = tmp[3]; + mac[6] = tmp[4]; + mac[7] = tmp[5]; - return 1; + } else { - } else { + mac[0] = tmp[0]; + mac[1] = tmp[1]; + mac[2] = tmp[2]; + mac[3] = tmp[3]; + mac[4] = tmp[4]; + mac[5] = tmp[5]; + } - if ( type == 0 ) - { - memset(mac, 0, 6); + return 1; } else { - memset(mac, 0, 8); + if (type == 0) { + memset(mac, 0, 6); + + } else { + + memset(mac, 0, 8); + } + + return 0; } - - return 0; - } } -//------------------------------------------------------------------- -char EEPROM_setMacAddr(struct adapter * adapter, char type, u8 * mac) +char EEPROM_setMacAddr(struct adapter *adapter, char type, u8 * mac) { - u8 tmp[8]; + u8 tmp[8]; + + if (type != 0) { + tmp[0] = mac[0]; + tmp[1] = mac[1]; + tmp[2] = mac[2]; + tmp[3] = mac[5]; + tmp[4] = mac[6]; + tmp[5] = mac[7]; - if ( type != 0 ) - { - tmp[0] = mac[0]; - tmp[1] = mac[1]; - tmp[2] = mac[2]; - tmp[3] = mac[5]; - tmp[4] = mac[6]; - tmp[5] = mac[7]; + } else { - } else { + tmp[0] = mac[0]; + tmp[1] = mac[1]; + tmp[2] = mac[2]; + tmp[3] = mac[3]; + tmp[4] = mac[4]; + tmp[5] = mac[5]; + } - tmp[0] = mac[0]; - tmp[1] = mac[1]; - tmp[2] = mac[2]; - tmp[3] = mac[3]; - tmp[4] = mac[4]; - tmp[5] = mac[5]; - } + tmp[6] = 0; + tmp[7] = calc_LRC(tmp, 7); - tmp[6] = 0; - tmp[7] = calc_LRC(tmp, 7); - - if ( EEPROM_write(adapter, 0x3F8, tmp, 8) == 8 ) return 1; + if (EEPROM_write(adapter, 0x3F8, tmp, 8) == 8) + return 1; - return 0; + return 0; } ///////////////////////////////////////////////////////////////////// -// PID filter +// PID filter ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -void FilterEnableStream1Filter(struct adapter * adapter, u32 op) +void FilterEnableStream1Filter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000001, 0); - - } else { + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000001, 0); - WriteRegOp(adapter, 0x208, 1, 0, 0x00000001); - } + } else { + + WriteRegOp(adapter, 0x208, 1, 0, 0x00000001); + } } -//------------------------------------------------------------------- -void FilterEnableStream2Filter(struct adapter * adapter, u32 op) +void FilterEnableStream2Filter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000002, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000002, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000002); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000002); + } } -//------------------------------------------------------------------- -void FilterEnablePcrFilter(struct adapter * adapter, u32 op) +void FilterEnablePcrFilter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000004, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000004, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000004); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000004); + } } -//------------------------------------------------------------------- -void FilterEnablePmtFilter(struct adapter * adapter, u32 op) +void FilterEnablePmtFilter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000008, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000008, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000008); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000008); + } } -//------------------------------------------------------------------- -void FilterEnableEmmFilter(struct adapter * adapter, u32 op) +void FilterEnableEmmFilter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000010, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000010, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000010); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000010); + } } -//------------------------------------------------------------------- -void FilterEnableEcmFilter(struct adapter * adapter, u32 op) +void FilterEnableEcmFilter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000020, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000020, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000020); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000020); + } } -//------------------------------------------------------------------- void FilterEnableNullFilter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000040, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000040, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000040); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000040); + } } -//------------------------------------------------------------------- void FilterEnableMaskFilter(struct adapter *adapter, u32 op) { - dprintk("%s: op=%x\n", __FUNCTION__, op); + dprintk("%s: op=%x\n", __FUNCTION__, op); - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000080, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000080, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000080); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000080); + } } -//------------------------------------------------------------------- void CtrlEnableMAC(struct adapter *adapter, u32 op) { - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00004000, 0); - - } else { - - WriteRegOp(adapter, 0x208, 1, 0, 0x00004000); - } + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00004000, 0); + + } else { + + WriteRegOp(adapter, 0x208, 1, 0, 0x00004000); + } } -//------------------------------------------------------------------- -int CASetMacDstAddrFilter(struct adapter *adapter, u8 *mac) +int CASetMacDstAddrFilter(struct adapter *adapter, u8 * mac) { - u32 tmp1, tmp2; + u32 tmp1, tmp2; - tmp1 = ( mac[3] << 0x18 ) | ( mac[2] << 0x10 ) | ( mac[1] << 0x08 ) | mac[0]; - tmp2 = ( mac[5] << 0x08 ) | mac[4]; + tmp1 = (mac[3] << 0x18) | (mac[2] << 0x10) | (mac[1] << 0x08) | mac[0]; + tmp2 = (mac[5] << 0x08) | mac[4]; - WriteRegDW(adapter, 0x418, tmp1); - WriteRegDW(adapter, 0x41C, tmp2); + WriteRegDW(adapter, 0x418, tmp1); + WriteRegDW(adapter, 0x41C, tmp2); - return 0; + return 0; } -//------------------------------------------------------------------- -void SetIgnoreMACFilter(struct adapter * adapter, u8 op) +void SetIgnoreMACFilter(struct adapter *adapter, u8 op) { - if ( op != 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00004000, 0); + if (op != 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00004000, 0); - adapter->mac_filter = 1; + adapter->mac_filter = 1; - } else { + } else { - if ( adapter->mac_filter != 0 ) - { - adapter->mac_filter = 0; + if (adapter->mac_filter != 0) { + adapter->mac_filter = 0; - WriteRegOp(adapter, 0x208, 1, 0, 0x00004000); + WriteRegOp(adapter, 0x208, 1, 0, 0x00004000); + } } - } } -//------------------------------------------------------------------- -void CheckNullFilterEnable(struct adapter * adapter) +void CheckNullFilterEnable(struct adapter *adapter) { - FilterEnableNullFilter(adapter, 1); - FilterEnableMaskFilter(adapter, 1); + FilterEnableNullFilter(adapter, 1); + FilterEnableMaskFilter(adapter, 1); } -//------------------------------------------------------------------- void InitPIDsInfo(struct adapter *adapter) { - int i; + int i; - for ( i = 0; i < 0x27; i++) adapter->pids[i] = 0x1FFF; + for (i = 0; i < 0x27; i++) + adapter->pids[i] = 0x1FFF; } -//------------------------------------------------------------------- -u32 CheckPID(struct adapter * adapter, u16 pid) +u32 CheckPID(struct adapter *adapter, u16 pid) { - u32 i; + u32 i; - if ( pid == 0x1FFF ) return 0; + if (pid == 0x1FFF) + return 0; - for ( i = 0; i < 0x27; i++ ) - { - if ( adapter->pids[i] == pid ) return 1; - } + for (i = 0; i < 0x27; i++) { + if (adapter->pids[i] == pid) + return 1; + } - return 0; + return 0; } -//------------------------------------------------------------------- -u32 PidSetGroupPID(struct adapter *adapter, u32 pid) +u32 PidSetGroupPID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = ( pid & 0x3FFF) | ( ReadRegDW(adapter, 0x30C) & 0xFFFF0000 ); + value = (pid & 0x3FFF) | (ReadRegDW(adapter, 0x30C) & 0xFFFF0000); - WriteRegDW(adapter, 0x30C, value); + WriteRegDW(adapter, 0x30C, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetGroupMASK(struct adapter *adapter, u32 pid) +u32 PidSetGroupMASK(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = ( ( pid & 0x3FFF ) << 0x10 ) | (ReadRegDW(adapter, 0x30C) & 0xFFFF ); + value = ((pid & 0x3FFF) << 0x10) | (ReadRegDW(adapter, 0x30C) & 0xFFFF); - WriteRegDW(adapter, 0x30C, value); + WriteRegDW(adapter, 0x30C, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetStream1PID(struct adapter *adapter, u32 pid) +u32 PidSetStream1PID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = ( pid & 0x3FFF ) | ( ReadRegDW(adapter, 0x300) & 0xFFFFC000 ); + value = (pid & 0x3FFF) | (ReadRegDW(adapter, 0x300) & 0xFFFFC000); - WriteRegDW(adapter, 0x300, value); + WriteRegDW(adapter, 0x300, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetStream2PID(struct adapter *adapter, u32 pid) +u32 PidSetStream2PID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = ( ( pid & 0x3FFF ) << 0x10 ) | ( ReadRegDW(adapter, 0x300) & 0xFFFF ); + value = ((pid & 0x3FFF) << 0x10) | (ReadRegDW(adapter, 0x300) & 0xFFFF); - WriteRegDW(adapter, 0x300, value); + WriteRegDW(adapter, 0x300, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetPcrPID(struct adapter *adapter, u32 pid) +u32 PidSetPcrPID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = (pid & 0x3FFF) | ( ReadRegDW(adapter, 0x304) & 0xFFFFC000 ); + value = (pid & 0x3FFF) | (ReadRegDW(adapter, 0x304) & 0xFFFFC000); - WriteRegDW(adapter, 0x304, value); + WriteRegDW(adapter, 0x304, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetPmtPID(struct adapter *adapter, u32 pid) +u32 PidSetPmtPID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = ( (pid & 0x3FFF) << 0x10) | ( ReadRegDW(adapter, 0x304) & 0x3FFF ); + value = ((pid & 0x3FFF) << 0x10) | (ReadRegDW(adapter, 0x304) & 0x3FFF); - WriteRegDW(adapter, 0x304, value); + WriteRegDW(adapter, 0x304, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetEmmPID(struct adapter *adapter, u32 pid) +u32 PidSetEmmPID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = (pid & 0xFFFF) | ( ReadRegDW(adapter, 0x308) & 0xFFFF0000 ); + value = (pid & 0xFFFF) | (ReadRegDW(adapter, 0x308) & 0xFFFF0000); - WriteRegDW(adapter, 0x308, value); + WriteRegDW(adapter, 0x308, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidSetEcmPID(struct adapter *adapter, u32 pid) +u32 PidSetEcmPID(struct adapter * adapter, u32 pid) { - u32 value; + u32 value; - dprintk("%s: pid=%x\n", __FUNCTION__, pid); + dprintk("%s: pid=%x\n", __FUNCTION__, pid); - value = (pid << 0x10 ) | ( ReadRegDW(adapter, 0x308) & 0xFFFF ); + value = (pid << 0x10) | (ReadRegDW(adapter, 0x308) & 0xFFFF); - WriteRegDW(adapter, 0x308, value); + WriteRegDW(adapter, 0x308, value); - return value; + return value; } -//------------------------------------------------------------------- -u32 PidGetStream1PID(struct adapter *adapter) +u32 PidGetStream1PID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x300) & 0x0000FFFF; + return ReadRegDW(adapter, 0x300) & 0x0000FFFF; } -//------------------------------------------------------------------- -u32 PidGetStream2PID(struct adapter *adapter) +u32 PidGetStream2PID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x300) >> 0x10; + return ReadRegDW(adapter, 0x300) >> 0x10; } -//------------------------------------------------------------------- -u32 PidGetPcrPID(struct adapter *adapter) +u32 PidGetPcrPID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x304) & 0x0000FFFF; + return ReadRegDW(adapter, 0x304) & 0x0000FFFF; } -//------------------------------------------------------------------- -u32 PidGetPmtPID(struct adapter *adapter) +u32 PidGetPmtPID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x304) >> 0x10; + return ReadRegDW(adapter, 0x304) >> 0x10; } -//------------------------------------------------------------------- -u32 PidGetEmmPID(struct adapter *adapter) +u32 PidGetEmmPID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x308) & 0x0000FFFF; + return ReadRegDW(adapter, 0x308) & 0x0000FFFF; } -//------------------------------------------------------------------- -u32 PidGetEcmPID(struct adapter *adapter) +u32 PidGetEcmPID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x308) >> 0x10; + return ReadRegDW(adapter, 0x308) >> 0x10; } -//------------------------------------------------------------------- -u32 PidGetGroupPID(struct adapter *adapter) +u32 PidGetGroupPID(struct adapter * adapter) { - return ReadRegDW(adapter, 0x30C) & 0x0000FFFF; + return ReadRegDW(adapter, 0x30C) & 0x0000FFFF; } -//------------------------------------------------------------------- -u32 PidGetGroupMASK(struct adapter *adapter) +u32 PidGetGroupMASK(struct adapter * adapter) { - return ReadRegDW(adapter, 0x30C) >> 0x10; + return ReadRegDW(adapter, 0x30C) >> 0x10; } -//------------------------------------------------------------------- void ResetHardwarePIDFilter(struct adapter *adapter) { - PidSetStream1PID(adapter, 0x1FFF); + PidSetStream1PID(adapter, 0x1FFF); - PidSetStream2PID(adapter, 0x1FFF); - FilterEnableStream2Filter(adapter, 0); + PidSetStream2PID(adapter, 0x1FFF); + FilterEnableStream2Filter(adapter, 0); - PidSetPcrPID(adapter, 0x1FFF); - FilterEnablePcrFilter(adapter, 0); + PidSetPcrPID(adapter, 0x1FFF); + FilterEnablePcrFilter(adapter, 0); - PidSetPmtPID(adapter, 0x1FFF); - FilterEnablePmtFilter(adapter, 0); + PidSetPmtPID(adapter, 0x1FFF); + FilterEnablePmtFilter(adapter, 0); - PidSetEcmPID(adapter, 0x1FFF); - FilterEnableEcmFilter(adapter, 0); + PidSetEcmPID(adapter, 0x1FFF); + FilterEnableEcmFilter(adapter, 0); - PidSetEmmPID(adapter, 0x1FFF); - FilterEnableEmmFilter(adapter, 0); + PidSetEmmPID(adapter, 0x1FFF); + FilterEnableEmmFilter(adapter, 0); } -//------------------------------------------------------------------- -void OpenWholeBandwidth(struct adapter * adapter) +void OpenWholeBandwidth(struct adapter *adapter) { - PidSetGroupPID(adapter, 0); + PidSetGroupPID(adapter, 0); - PidSetGroupMASK(adapter, 0); + PidSetGroupMASK(adapter, 0); - FilterEnableMaskFilter(adapter, 1); + FilterEnableMaskFilter(adapter, 1); } -//------------------------------------------------------------------- -int AddHwPID(struct adapter * adapter, u32 pid) +int AddHwPID(struct adapter *adapter, u32 pid) { - dprintk("%s: pid=%d\n", __FUNCTION__, pid); + dprintk("%s: pid=%d\n", __FUNCTION__, pid); - if ( pid <= 0x1F ) return 1; + if (pid <= 0x1F) + return 1; - if ( ( PidGetGroupMASK(adapter) == 0 ) && ( PidGetGroupPID(adapter) == 0 ) ) return 0; + if ((PidGetGroupMASK(adapter) == 0) && (PidGetGroupPID(adapter) == 0)) + return 0; + if ((PidGetStream1PID(adapter) & 0x1FFF) == 0x1FFF) { + PidSetStream1PID(adapter, pid & 0xFFFF); - if ( ( PidGetStream1PID(adapter) & 0x1FFF ) == 0x1FFF ) - { - PidSetStream1PID(adapter, pid & 0xFFFF ); + FilterEnableStream1Filter(adapter, 1); - FilterEnableStream1Filter(adapter, 1); + return 1; + } - return 1; - } + if ((PidGetStream2PID(adapter) & 0x1FFF) == 0x1FFF) { + PidSetStream2PID(adapter, (pid & 0xFFFF)); - if ( ( PidGetStream2PID(adapter) & 0x1FFF ) == 0x1FFF ) - { - PidSetStream2PID(adapter, ( pid & 0xFFFF ) ); + FilterEnableStream2Filter(adapter, 1); - FilterEnableStream2Filter(adapter, 1); + return 1; + } - return 1; - } + if ((PidGetPcrPID(adapter) & 0x1FFF) == 0x1FFF) { + PidSetPcrPID(adapter, (pid & 0xFFFF)); - if ( ( PidGetPcrPID(adapter) & 0x1FFF ) == 0x1FFF ) - { - PidSetPcrPID(adapter, ( pid & 0xFFFF ) ); + FilterEnablePcrFilter(adapter, 1); - FilterEnablePcrFilter(adapter, 1); + return 1; + } - return 1; - } + if ((PidGetPmtPID(adapter) & 0x1FFF) == 0x1FFF) { + PidSetPmtPID(adapter, (pid & 0xFFFF)); - if ( ( PidGetPmtPID(adapter) & 0x1FFF ) == 0x1FFF ) - { - PidSetPmtPID(adapter, ( pid & 0xFFFF ) ); + FilterEnablePmtFilter(adapter, 1); - FilterEnablePmtFilter(adapter, 1); + return 1; + } - return 1; - } + if ((PidGetEmmPID(adapter) & 0x1FFF) == 0x1FFF) { + PidSetEmmPID(adapter, (pid & 0xFFFF)); - if ( ( PidGetEmmPID(adapter) & 0x1FFF ) == 0x1FFF ) - { - PidSetEmmPID(adapter, ( pid & 0xFFFF ) ); + FilterEnableEmmFilter(adapter, 1); - FilterEnableEmmFilter(adapter, 1); + return 1; + } - return 1; - } + if ((PidGetEcmPID(adapter) & 0x1FFF) == 0x1FFF) { + PidSetEcmPID(adapter, (pid & 0xFFFF)); - if ( ( PidGetEcmPID(adapter) & 0x1FFF ) == 0x1FFF ) - { - PidSetEcmPID(adapter, ( pid & 0xFFFF ) ); + FilterEnableEcmFilter(adapter, 1); - FilterEnableEcmFilter(adapter, 1); + return 1; + } - return 1; - } - - return -1; + return -1; } -//------------------------------------------------------------------- -int RemoveHwPID(struct adapter * adapter, u32 pid) +int RemoveHwPID(struct adapter *adapter, u32 pid) { - dprintk("%s: pid=%d\n", __FUNCTION__, pid); + dprintk("%s: pid=%d\n", __FUNCTION__, pid); - if ( pid <= 0x1F ) return 1; + if (pid <= 0x1F) + return 1; - if ( ( PidGetStream1PID(adapter) & 0x1FFF ) == pid ) - { - PidSetStream1PID(adapter, 0x1FFF); + if ((PidGetStream1PID(adapter) & 0x1FFF) == pid) { + PidSetStream1PID(adapter, 0x1FFF); - return 1; - } + return 1; + } - if ( ( PidGetStream2PID(adapter) & 0x1FFF ) == pid ) - { - PidSetStream2PID(adapter, 0x1FFF); + if ((PidGetStream2PID(adapter) & 0x1FFF) == pid) { + PidSetStream2PID(adapter, 0x1FFF); - FilterEnableStream2Filter(adapter, 0); + FilterEnableStream2Filter(adapter, 0); - return 1; - } + return 1; + } - if ( ( PidGetPcrPID(adapter) & 0x1FFF ) == pid ) - { - PidSetPcrPID(adapter, 0x1FFF); + if ((PidGetPcrPID(adapter) & 0x1FFF) == pid) { + PidSetPcrPID(adapter, 0x1FFF); - FilterEnablePcrFilter(adapter, 0); + FilterEnablePcrFilter(adapter, 0); - return 1; - } + return 1; + } - if ( ( PidGetPmtPID(adapter) & 0x1FFF ) == pid ) - { - PidSetPmtPID(adapter, 0x1FFF); + if ((PidGetPmtPID(adapter) & 0x1FFF) == pid) { + PidSetPmtPID(adapter, 0x1FFF); - FilterEnablePmtFilter(adapter, 0); + FilterEnablePmtFilter(adapter, 0); - return 1; - } + return 1; + } - if ( ( PidGetEmmPID(adapter) & 0x1FFF ) == pid ) - { - PidSetEmmPID(adapter, 0x1FFF); + if ((PidGetEmmPID(adapter) & 0x1FFF) == pid) { + PidSetEmmPID(adapter, 0x1FFF); - FilterEnableEmmFilter(adapter, 0); + FilterEnableEmmFilter(adapter, 0); - return 1; - } + return 1; + } - if ( ( PidGetEcmPID(adapter) & 0x1FFF ) == pid ) - { - PidSetEcmPID(adapter, 0x1FFF); + if ((PidGetEcmPID(adapter) & 0x1FFF) == pid) { + PidSetEcmPID(adapter, 0x1FFF); - FilterEnableEcmFilter(adapter, 0); + FilterEnableEcmFilter(adapter, 0); - return 1; - } + return 1; + } - return -1; + return -1; } -//------------------------------------------------------------------------------ -int AddPID(struct adapter * adapter, u32 pid) +int AddPID(struct adapter *adapter, u32 pid) { - int i; + int i; + + dprintk("%s: pid=%d\n", __FUNCTION__, pid); - dprintk("%s: pid=%d\n", __FUNCTION__, pid); + if (pid > 0x1FFE) + return -1; - if ( pid > 0x1FFE ) return -1; + if (CheckPID(adapter, pid) == 1) + return 1; - if ( CheckPID(adapter, pid) == 1 ) return 1; + for (i = 0; i < 0x27; i++) { + if (adapter->pids[i] == 0x1FFF) // find free pid filter + { + adapter->pids[i] = pid; - for ( i = 0; i < 0x27; i++) - { - if ( adapter->pids[i] == 0x1FFF ) // find free pid filter - { - adapter->pids[i] = pid; + if (AddHwPID(adapter, pid) < 0) + OpenWholeBandwidth(adapter); - if ( AddHwPID(adapter, pid) < 0 ) OpenWholeBandwidth(adapter); - - return 1; + return 1; + } } - } - return -1; + return -1; } -//------------------------------------------------------------------- -int RemovePID(struct adapter * adapter, u32 pid) +int RemovePID(struct adapter *adapter, u32 pid) { - u32 i; + u32 i; - dprintk("%s: pid=%d\n", __FUNCTION__, pid); + dprintk("%s: pid=%d\n", __FUNCTION__, pid); - if ( pid > 0x1FFE ) return -1; + if (pid > 0x1FFE) + return -1; - for ( i = 0; i < 0x27; i++) - { - if ( adapter->pids[i] == pid ) - { - adapter->pids[i] = 0x1FFF; + for (i = 0; i < 0x27; i++) { + if (adapter->pids[i] == pid) { + adapter->pids[i] = 0x1FFF; - RemoveHwPID(adapter, pid); + RemoveHwPID(adapter, pid); - return 1; + return 1; + } } - } - return -1; + return -1; } ///////////////////////////////////////////////////////////////////// -// DMA & IRQ +// DMA & IRQ ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- void CtrlEnableSmc(struct adapter *adapter, u32 op) { - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00000800, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00000800, 0); - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00000800); - } + WriteRegOp(adapter, 0x208, 1, 0, 0x00000800); + } } -//------------------------------------------------------------------- u32 DmaEnableDisableIrq(struct adapter *adapter, u32 flag1, u32 flag2, u32 flag3) { - adapter->dma_ctrl = adapter->dma_ctrl & 0x000F0000; + adapter->dma_ctrl = adapter->dma_ctrl & 0x000F0000; - if ( flag1 == 0 ) - { - if ( flag2 == 0 ) - adapter->dma_ctrl = adapter->dma_ctrl & ~0x00010000; - else - adapter->dma_ctrl = adapter->dma_ctrl | 0x00010000; - - if ( flag3 == 0 ) - adapter->dma_ctrl = adapter->dma_ctrl & ~0x00020000; - else - adapter->dma_ctrl = adapter->dma_ctrl | 0x00020000; + if (flag1 == 0) { + if (flag2 == 0) + adapter->dma_ctrl = adapter->dma_ctrl & ~0x00010000; + else + adapter->dma_ctrl = adapter->dma_ctrl | 0x00010000; - } else { + if (flag3 == 0) + adapter->dma_ctrl = adapter->dma_ctrl & ~0x00020000; + else + adapter->dma_ctrl = adapter->dma_ctrl | 0x00020000; - if ( flag2 == 0 ) - adapter->dma_ctrl = adapter->dma_ctrl & ~0x00040000; - else - adapter->dma_ctrl = adapter->dma_ctrl | 0x00040000; + } else { - if ( flag3 == 0 ) - adapter->dma_ctrl = adapter->dma_ctrl & ~0x00080000; - else - adapter->dma_ctrl = adapter->dma_ctrl | 0x00080000; - } + if (flag2 == 0) + adapter->dma_ctrl = adapter->dma_ctrl & ~0x00040000; + else + adapter->dma_ctrl = adapter->dma_ctrl | 0x00040000; - return adapter->dma_ctrl; + if (flag3 == 0) + adapter->dma_ctrl = adapter->dma_ctrl & ~0x00080000; + else + adapter->dma_ctrl = adapter->dma_ctrl | 0x00080000; + } + + return adapter->dma_ctrl; } -//------------------------------------------------------------------- -u32 IrqDmaEnableDisableIrq(struct adapter *adapter, u32 op) +u32 IrqDmaEnableDisableIrq(struct adapter * adapter, u32 op) { - u32 value; + u32 value; - value = ReadRegDW(adapter, 0x208) & 0xFFF0FFFF; + value = ReadRegDW(adapter, 0x208) & 0xFFF0FFFF; - if ( op != 0 ) value = value | ( adapter->dma_ctrl & 0x000F0000); + if (op != 0) + value = value | (adapter->dma_ctrl & 0x000F0000); - WriteRegDW(adapter, 0x208, value); + WriteRegDW(adapter, 0x208, value); - return value; + return value; } /////////////////////////////////////////////////////////////////////// @@ -1671,1032 +1570,974 @@ u32 IrqDmaEnableDisableIrq(struct adapter *adapter, u32 op) // when the subbuffer is full and continue fillig the second subbuffer. // // For DMA1: -// subbuffer size in 32-bit words is stored in the first 24 bits of -// register 0x004. The last 8 bits of register 0x004 contain the number -// of subbuffers. -// -// the first 30 bits of register 0x000 contain the address of the first -// subbuffer. The last 2 bits contain 0, when dma1 is disabled and 1, -// when dma1 is enabled. +// subbuffer size in 32-bit words is stored in the first 24 bits of +// register 0x004. The last 8 bits of register 0x004 contain the number +// of subbuffers. +// +// the first 30 bits of register 0x000 contain the address of the first +// subbuffer. The last 2 bits contain 0, when dma1 is disabled and 1, +// when dma1 is enabled. // -// the first 30 bits of register 0x00C contain the address of the second -// subbuffer. the last 2 bits contain 1. +// the first 30 bits of register 0x00C contain the address of the second +// subbuffer. the last 2 bits contain 1. // -// register 0x008 will contain the address of the subbuffer that was filled -// with TS data, when FlexCopII will generate an interrupt. +// register 0x008 will contain the address of the subbuffer that was filled +// with TS data, when FlexCopII will generate an interrupt. // // For DMA2: -// subbuffer size in 32-bit words is stored in the first 24 bits of -// register 0x014. The last 8 bits of register 0x014 contain the number -// of subbuffers. -// -// the first 30 bits of register 0x010 contain the address of the first -// subbuffer. The last 2 bits contain 0, when dma1 is disabled and 1, -// when dma1 is enabled. +// subbuffer size in 32-bit words is stored in the first 24 bits of +// register 0x014. The last 8 bits of register 0x014 contain the number +// of subbuffers. +// +// the first 30 bits of register 0x010 contain the address of the first +// subbuffer. The last 2 bits contain 0, when dma1 is disabled and 1, +// when dma1 is enabled. // -// the first 30 bits of register 0x01C contain the address of the second -// subbuffer. the last 2 bits contain 1. +// the first 30 bits of register 0x01C contain the address of the second +// subbuffer. the last 2 bits contain 1. // -// register 0x018 contains the address of the subbuffer that was filled -// with TS data, when FlexCopII generates an interrupt. +// register 0x018 contains the address of the subbuffer that was filled +// with TS data, when FlexCopII generates an interrupt. // /////////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -int DmaInitDMA(struct adapter * adapter, u32 dma_channel) +int DmaInitDMA(struct adapter *adapter, u32 dma_channel) { - u32 subbuffers, subbufsize, subbuf0, subbuf1; + u32 subbuffers, subbufsize, subbuf0, subbuf1; - if ( dma_channel == 0 ) - { - dprintk("%s: Initializing DMA1 channel\n", __FUNCTION__); - - subbuffers = 2; + if (dma_channel == 0) { + dprintk("%s: Initializing DMA1 channel\n", __FUNCTION__); - subbufsize = ( ( (adapter->DmaQ1.buffer_size / 2) / 4) << 8 ) | subbuffers; - - subbuf0 = adapter->DmaQ1.bus_addr & 0xFFFFFFFC; + subbuffers = 2; - subbuf1 = ( (adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size / 2) & 0xFFFFFFFC ) | 1; + subbufsize = (((adapter->DmaQ1.buffer_size / 2) / 4) << 8) | subbuffers; - dprintk("%s: first subbuffer address = 0x%x\n", __FUNCTION__, subbuf0); - udelay(1000); - WriteRegDW(adapter, 0x000, subbuf0); + subbuf0 = adapter->DmaQ1.bus_addr & 0xFFFFFFFC; - dprintk("%s: subbuffer size = 0x%x\n", __FUNCTION__, (subbufsize >> 8)*4); - udelay(1000); - WriteRegDW(adapter, 0x004, subbufsize); + subbuf1 = ((adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size / 2) & 0xFFFFFFFC) | 1; - dprintk("%s: second subbuffer address = 0x%x\n", __FUNCTION__, subbuf1); - udelay(1000); - WriteRegDW(adapter, 0x00C, subbuf1); + dprintk("%s: first subbuffer address = 0x%x\n", __FUNCTION__, subbuf0); + udelay(1000); + WriteRegDW(adapter, 0x000, subbuf0); - dprintk("%s: counter = 0x%x\n", __FUNCTION__, adapter->DmaQ1.bus_addr & 0xFFFFFFFC ); - WriteRegDW(adapter, 0x008, adapter->DmaQ1.bus_addr & 0xFFFFFFFC); - udelay(1000); + dprintk("%s: subbuffer size = 0x%x\n", __FUNCTION__, (subbufsize >> 8) * 4); + udelay(1000); + WriteRegDW(adapter, 0x004, subbufsize); - if ( subbuffers == 0 ) DmaEnableDisableIrq(adapter, 0, 1, 0); else DmaEnableDisableIrq(adapter, 0, 1, 1); + dprintk("%s: second subbuffer address = 0x%x\n", __FUNCTION__, subbuf1); + udelay(1000); + WriteRegDW(adapter, 0x00C, subbuf1); - IrqDmaEnableDisableIrq(adapter, 1); + dprintk("%s: counter = 0x%x\n", __FUNCTION__, adapter->DmaQ1.bus_addr & 0xFFFFFFFC); + WriteRegDW(adapter, 0x008, adapter->DmaQ1.bus_addr & 0xFFFFFFFC); + udelay(1000); - SRAMSetMediaDest(adapter, 1); - SRAMSetNetDest(adapter, 1); - SRAMSetCaiDest(adapter, 2); - SRAMSetCaoDest(adapter, 2); - } - - if ( dma_channel == 1 ) - { - dprintk("%s: Initializing DMA2 channel\n", __FUNCTION__); + if (subbuffers == 0) + DmaEnableDisableIrq(adapter, 0, 1, 0); + else + DmaEnableDisableIrq(adapter, 0, 1, 1); - subbuffers = 2; + IrqDmaEnableDisableIrq(adapter, 1); - subbufsize = ( (( adapter->DmaQ2.buffer_size / 2 ) / 4 ) << 8 ) | subbuffers; - - subbuf0 = adapter->DmaQ2.bus_addr & 0xFFFFFFFC; - - subbuf1 = ( ( adapter->DmaQ2.bus_addr + adapter->DmaQ2.buffer_size / 2 ) & 0xFFFFFFFC ) | 1; + SRAMSetMediaDest(adapter, 1); + SRAMSetNetDest(adapter, 1); + SRAMSetCaiDest(adapter, 2); + SRAMSetCaoDest(adapter, 2); + } - dprintk("%s: first subbuffer address = 0x%x\n", __FUNCTION__, subbuf0); - udelay(1000); - WriteRegDW(adapter, 0x010, subbuf0); + if (dma_channel == 1) { + dprintk("%s: Initializing DMA2 channel\n", __FUNCTION__); - dprintk("%s: subbuffer size = 0x%x\n", __FUNCTION__, (subbufsize >> 8)*4); - udelay(1000); - WriteRegDW(adapter, 0x014, subbufsize); + subbuffers = 2; - dprintk("%s: second buffer address = 0x%x\n", __FUNCTION__, subbuf1); - udelay(1000); - WriteRegDW(adapter, 0x01C, subbuf1); + subbufsize = (((adapter->DmaQ2.buffer_size / 2) / 4) << 8) | subbuffers; - - SRAMSetCaiDest(adapter, 2); - } + subbuf0 = adapter->DmaQ2.bus_addr & 0xFFFFFFFC; + + subbuf1 = ((adapter->DmaQ2.bus_addr + adapter->DmaQ2.buffer_size / 2) & 0xFFFFFFFC) | 1; - return 0; + dprintk("%s: first subbuffer address = 0x%x\n", __FUNCTION__, subbuf0); + udelay(1000); + WriteRegDW(adapter, 0x010, subbuf0); + + dprintk("%s: subbuffer size = 0x%x\n", __FUNCTION__, (subbufsize >> 8) * 4); + udelay(1000); + WriteRegDW(adapter, 0x014, subbufsize); + + dprintk("%s: second buffer address = 0x%x\n", __FUNCTION__, subbuf1); + udelay(1000); + WriteRegDW(adapter, 0x01C, subbuf1); + + SRAMSetCaiDest(adapter, 2); + } + + return 0; } -//------------------------------------------------------------------- void CtrlEnableReceiveData(struct adapter *adapter, u32 op) { - if ( op == 0 ) - { - WriteRegOp(adapter, 0x208, 2, ~0x00008000, 0); + if (op == 0) { + WriteRegOp(adapter, 0x208, 2, ~0x00008000, 0); - adapter->dma_status = adapter->dma_status & ~0x00000004; + adapter->dma_status = adapter->dma_status & ~0x00000004; - } else { + } else { - WriteRegOp(adapter, 0x208, 1, 0, 0x00008000); + WriteRegOp(adapter, 0x208, 1, 0, 0x00008000); - adapter->dma_status = adapter->dma_status | 0x00000004; - } + adapter->dma_status = adapter->dma_status | 0x00000004; + } } /////////////////////////////////////////////////////////////////////////////// // bit 0 of dma_mask is set to 1 if dma1 channel has to be enabled/disabled // bit 1 of dma_mask is set to 1 if dma2 channel has to be enabled/disabled -//------------------------------------------------------------------- + void DmaStartStop0x2102(struct adapter *adapter, u32 dma_mask, u32 start_stop) { - u32 dma_enable, dma1_enable, dma2_enable; - - dprintk("%s: dma_mask=%x\n", __FUNCTION__, dma_mask); - - if ( start_stop == 1 ) - { - dprintk("%s: starting dma\n", __FUNCTION__); - - dma1_enable = 0; - dma2_enable = 0; - - if ( ( ( dma_mask & 1 ) != 0 ) && ( ( adapter->dma_status & 1 ) == 0 ) && ( adapter->DmaQ1.bus_addr != 0 ) ) - { - adapter->dma_status = adapter->dma_status | 1; - dma1_enable = 1; - } - - if ( ( ( dma_mask & 2 ) != 0 ) && ( ( adapter->dma_status & 2 ) == 0 ) && ( adapter->DmaQ2.bus_addr != 0 ) ) - { - adapter->dma_status = adapter->dma_status | 2; - dma2_enable = 1; - } - - // enable dma1 and dma2 - if ( ( dma1_enable == 1 ) && ( dma2_enable == 1 ) ) - { - WriteRegDW(adapter, 0x000, adapter->DmaQ1.bus_addr | 1 ); - WriteRegDW(adapter, 0x00C, ( adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size/2 ) | 1); - WriteRegDW(adapter, 0x010, adapter->DmaQ2.bus_addr | 1); + u32 dma_enable, dma1_enable, dma2_enable; - CtrlEnableReceiveData(adapter, 1); + dprintk("%s: dma_mask=%x\n", __FUNCTION__, dma_mask); - return; - } + if (start_stop == 1) { + dprintk("%s: starting dma\n", __FUNCTION__); - // enable dma1 - if ( ( dma1_enable == 1 ) && ( dma2_enable == 0 ) ) - { - WriteRegDW(adapter, 0x000, adapter->DmaQ1.bus_addr | 1); - WriteRegDW(adapter, 0x00C, ( adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size/2 ) | 1 ); + dma1_enable = 0; + dma2_enable = 0; - CtrlEnableReceiveData(adapter, 1); + if (((dma_mask & 1) != 0) && ((adapter->dma_status & 1) == 0) && (adapter->DmaQ1.bus_addr != 0)) { + adapter->dma_status = adapter->dma_status | 1; + dma1_enable = 1; + } - return; - } + if (((dma_mask & 2) != 0) && ((adapter->dma_status & 2) == 0) && (adapter->DmaQ2.bus_addr != 0)) { + adapter->dma_status = adapter->dma_status | 2; + dma2_enable = 1; + } + // enable dma1 and dma2 + if ((dma1_enable == 1) && (dma2_enable == 1)) { + WriteRegDW(adapter, 0x000, adapter->DmaQ1.bus_addr | 1); + WriteRegDW(adapter, 0x00C, (adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size / 2) | 1); + WriteRegDW(adapter, 0x010, adapter->DmaQ2.bus_addr | 1); - // enable dma2 - if ( ( dma1_enable == 0 ) && ( dma2_enable == 1 ) ) - { - WriteRegDW(adapter, 0x010, adapter->DmaQ2.bus_addr | 1); + CtrlEnableReceiveData(adapter, 1); - CtrlEnableReceiveData(adapter, 1); + return; + } + // enable dma1 + if ((dma1_enable == 1) && (dma2_enable == 0)) { + WriteRegDW(adapter, 0x000, adapter->DmaQ1.bus_addr | 1); + WriteRegDW(adapter, 0x00C, (adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size / 2) | 1); - return; - } + CtrlEnableReceiveData(adapter, 1); - // start dma - if ( ( dma1_enable == 0 ) && ( dma2_enable == 0 ) ) - { - CtrlEnableReceiveData(adapter, 1); + return; + } + // enable dma2 + if ((dma1_enable == 0) && (dma2_enable == 1)) { + WriteRegDW(adapter, 0x010, adapter->DmaQ2.bus_addr | 1); - return; - } + CtrlEnableReceiveData(adapter, 1); - } else { + return; + } + // start dma + if ((dma1_enable == 0) && (dma2_enable == 0)) { + CtrlEnableReceiveData(adapter, 1); - dprintk("%s: stoping dma\n", __FUNCTION__); - - dma_enable = adapter->dma_status & 0x00000003; + return; + } - if ( ( ( dma_mask & 1 ) != 0 ) && ( ( adapter->dma_status & 1 ) != 0 ) ) - { - dma_enable = dma_enable & 0xFFFFFFFE; - } + } else { - if ( ( ( dma_mask & 2 ) != 0 ) && ( ( adapter->dma_status & 2 ) != 0 ) ) - { - dma_enable = dma_enable & 0xFFFFFFFD; - } + dprintk("%s: stoping dma\n", __FUNCTION__); - //stop dma - if ( ( dma_enable == 0 ) && ( ( adapter->dma_status & 4 ) != 0 ) ) - { - CtrlEnableReceiveData(adapter, 0); + dma_enable = adapter->dma_status & 0x00000003; - udelay(3000); - } + if (((dma_mask & 1) != 0) && ((adapter->dma_status & 1) != 0)) { + dma_enable = dma_enable & 0xFFFFFFFE; + } - //disable dma1 - if ( ( ( dma_mask & 1 ) != 0 ) && ( ( adapter->dma_status & 1 ) != 0 ) && ( adapter->DmaQ1.bus_addr != 0 ) ) - { - WriteRegDW(adapter, 0x000, adapter->DmaQ1.bus_addr); - WriteRegDW(adapter, 0x00C, ( adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size/2 ) | 1 ); + if (((dma_mask & 2) != 0) && ((adapter->dma_status & 2) != 0)) { + dma_enable = dma_enable & 0xFFFFFFFD; + } + //stop dma + if ((dma_enable == 0) && ((adapter->dma_status & 4) != 0)) { + CtrlEnableReceiveData(adapter, 0); - adapter->dma_status = adapter->dma_status & ~0x00000001; - } + udelay(3000); + } + //disable dma1 + if (((dma_mask & 1) != 0) && ((adapter->dma_status & 1) != 0) && (adapter->DmaQ1.bus_addr != 0)) { + WriteRegDW(adapter, 0x000, adapter->DmaQ1.bus_addr); + WriteRegDW(adapter, 0x00C, (adapter->DmaQ1.bus_addr + adapter->DmaQ1.buffer_size / 2) | 1); - //disable dma2 - if ( ( ( dma_mask & 2 ) != 0 ) && ( ( adapter->dma_status & 2 ) != 0 ) && ( adapter->DmaQ2.bus_addr != 0 ) ) - { - WriteRegDW(adapter, 0x010, adapter->DmaQ2.bus_addr); + adapter->dma_status = adapter->dma_status & ~0x00000001; + } + //disable dma2 + if (((dma_mask & 2) != 0) && ((adapter->dma_status & 2) != 0) && (adapter->DmaQ2.bus_addr != 0)) { + WriteRegDW(adapter, 0x010, adapter->DmaQ2.bus_addr); - adapter->dma_status = adapter->dma_status & ~0x00000002; + adapter->dma_status = adapter->dma_status & ~0x00000002; + } } - } } -//------------------------------------------------------------------- -void OpenStream(struct adapter * adapter, u32 pid) +void OpenStream(struct adapter *adapter, u32 pid) { - u32 dma_mask; + u32 dma_mask; + + if (adapter->capturing == 0) + adapter->capturing = 1; - if ( adapter->capturing == 0 ) adapter->capturing = 1; + FilterEnableMaskFilter(adapter, 1); - FilterEnableMaskFilter(adapter, 1); + AddPID(adapter, pid); - AddPID(adapter, pid); + dprintk("%s: adapter->dma_status=%x\n", __FUNCTION__, adapter->dma_status); - dprintk("%s: adapter->dma_status=%x\n", __FUNCTION__, adapter->dma_status); + if ((adapter->dma_status & 7) != 7) { + dma_mask = 0; - if ( ( adapter->dma_status & 7 ) != 7 ) - { - dma_mask = 0; - - if ( ( ( adapter->dma_status & 0x10000000 ) != 0 ) && ( ( adapter->dma_status & 1 ) == 0 ) ) - { - dma_mask = dma_mask | 1; + if (((adapter->dma_status & 0x10000000) != 0) && ((adapter->dma_status & 1) == 0)) { + dma_mask = dma_mask | 1; - adapter->DmaQ1.head = 0; - adapter->DmaQ1.tail = 0; + adapter->DmaQ1.head = 0; + adapter->DmaQ1.tail = 0; - memset(adapter->DmaQ1.buffer, 0, adapter->DmaQ1.buffer_size); - } + memset(adapter->DmaQ1.buffer, 0, adapter->DmaQ1.buffer_size); + } - if ( ( ( adapter->dma_status & 0x20000000 ) != 0 ) && ( ( adapter->dma_status & 2 ) == 0 ) ) - { - dma_mask = dma_mask | 2; + if (((adapter->dma_status & 0x20000000) != 0) && ((adapter->dma_status & 2) == 0)) { + dma_mask = dma_mask | 2; - adapter->DmaQ2.head = 0; - adapter->DmaQ2.tail = 0; - } + adapter->DmaQ2.head = 0; + adapter->DmaQ2.tail = 0; + } - if ( dma_mask != 0 ) - { - IrqDmaEnableDisableIrq(adapter, 1); + if (dma_mask != 0) { + IrqDmaEnableDisableIrq(adapter, 1); - DmaStartStop0x2102(adapter, dma_mask, 1); - } - } + DmaStartStop0x2102(adapter, dma_mask, 1); + } + } } -//------------------------------------------------------------------- -void CloseStream(struct adapter * adapter, u32 pid) +void CloseStream(struct adapter *adapter, u32 pid) { - u32 dma_mask; - - if ( adapter->capturing != 0 ) adapter->capturing = 0; + u32 dma_mask; + + if (adapter->capturing != 0) + adapter->capturing = 0; - dprintk("%s: dma_status=%x\n", __FUNCTION__, adapter->dma_status); + dprintk("%s: dma_status=%x\n", __FUNCTION__, adapter->dma_status); - dma_mask = 0; + dma_mask = 0; - if ( ( adapter->dma_status & 1 ) != 0 ) dma_mask = dma_mask | 0x00000001; - if ( ( adapter->dma_status & 2 ) != 0 ) dma_mask = dma_mask | 0x00000002; + if ((adapter->dma_status & 1) != 0) + dma_mask = dma_mask | 0x00000001; + if ((adapter->dma_status & 2) != 0) + dma_mask = dma_mask | 0x00000002; - if ( dma_mask != 0 ) - { - DmaStartStop0x2102(adapter, dma_mask, 0); - } + if (dma_mask != 0) { + DmaStartStop0x2102(adapter, dma_mask, 0); + } - RemovePID(adapter, pid); + RemovePID(adapter, pid); } -//------------------------------------------------------------------- u32 InterruptServiceDMA1(struct adapter *adapter) { - struct dvb_demux * dvbdmx = &adapter->demux; - struct packet_header_t packet_header; + struct dvb_demux *dvbdmx = &adapter->demux; + struct packet_header_t packet_header; - int nCurDmaCounter; - u32 nNumBytesParsed; - u32 nNumNewBytesTransferred; - u32 dwDefaultPacketSize = 188; - u8 gbTmpBuffer[188]; - u8 *pbDMABufCurPos; + int nCurDmaCounter; + u32 nNumBytesParsed; + u32 nNumNewBytesTransferred; + u32 dwDefaultPacketSize = 188; + u8 gbTmpBuffer[188]; + u8 *pbDMABufCurPos; - nCurDmaCounter = readl(adapter->io_mem + 0x008) - adapter->DmaQ1.bus_addr; - nCurDmaCounter = ( nCurDmaCounter / dwDefaultPacketSize ) * dwDefaultPacketSize; + nCurDmaCounter = readl(adapter->io_mem + 0x008) - adapter->DmaQ1.bus_addr; + nCurDmaCounter = (nCurDmaCounter / dwDefaultPacketSize) * dwDefaultPacketSize; - if ( ( nCurDmaCounter < 0 ) || ( nCurDmaCounter > adapter->DmaQ1.buffer_size) ) - { - dprintk("%s: dma counter outside dma buffer\n", __FUNCTION__); + if ((nCurDmaCounter < 0) || (nCurDmaCounter > adapter->DmaQ1.buffer_size)) { + dprintk("%s: dma counter outside dma buffer\n", __FUNCTION__); - return 1; - } + return 1; + } - adapter->DmaQ1.head = nCurDmaCounter; + adapter->DmaQ1.head = nCurDmaCounter; - if ( adapter->DmaQ1.tail <= nCurDmaCounter ) - { - nNumNewBytesTransferred = nCurDmaCounter - adapter->DmaQ1.tail; - - } else { + if (adapter->DmaQ1.tail <= nCurDmaCounter) { + nNumNewBytesTransferred = nCurDmaCounter - adapter->DmaQ1.tail; - nNumNewBytesTransferred = (adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail) + nCurDmaCounter; - } + } else { + + nNumNewBytesTransferred = (adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail) + nCurDmaCounter; + } // dprintk("%s: nCurDmaCounter = %d\n" , __FUNCTION__, nCurDmaCounter); // dprintk("%s: DmaQ1.tail = %d\n" , __FUNCTION__, adapter->DmaQ1.tail): // dprintk("%s: BytesTransferred = %d\n" , __FUNCTION__, nNumNewBytesTransferred); - if ( nNumNewBytesTransferred < dwDefaultPacketSize ) return 0; + if (nNumNewBytesTransferred < dwDefaultPacketSize) + return 0; - nNumBytesParsed = 0; + nNumBytesParsed = 0; - while ( nNumBytesParsed < nNumNewBytesTransferred ) - { - pbDMABufCurPos = adapter->DmaQ1.buffer + adapter->DmaQ1.tail; + while (nNumBytesParsed < nNumNewBytesTransferred) { + pbDMABufCurPos = adapter->DmaQ1.buffer + adapter->DmaQ1.tail; - if ( adapter->DmaQ1.buffer + adapter->DmaQ1.buffer_size < adapter->DmaQ1.buffer + adapter->DmaQ1.tail + 188) - { - memcpy(gbTmpBuffer, adapter->DmaQ1.buffer + adapter->DmaQ1.tail, adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail); - memcpy(gbTmpBuffer + (adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail), adapter->DmaQ1.buffer, ( 188 - ( adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail ) ) ); + if (adapter->DmaQ1.buffer + adapter->DmaQ1.buffer_size < adapter->DmaQ1.buffer + adapter->DmaQ1.tail + 188) { + memcpy(gbTmpBuffer, adapter->DmaQ1.buffer + adapter->DmaQ1.tail, adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail); + memcpy(gbTmpBuffer + (adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail), adapter->DmaQ1.buffer, (188 - (adapter->DmaQ1.buffer_size - adapter->DmaQ1.tail))); - pbDMABufCurPos = gbTmpBuffer; - } + pbDMABufCurPos = gbTmpBuffer; + } - if ( adapter->capturing != 0 ) - { - u32 * dq = (u32 *)pbDMABufCurPos; + if (adapter->capturing != 0) { + u32 *dq = (u32 *) pbDMABufCurPos; - packet_header.sync_byte = *dq & 0x000000FF; - packet_header.transport_error_indicator = *dq & 0x00008000; - packet_header.payload_unit_start_indicator = *dq & 0x00004000; - packet_header.transport_priority = *dq & 0x00002000; - packet_header.pid = ( ( *dq & 0x00FF0000 ) >> 0x10 ) | ( *dq & 0x00001F00 ); - packet_header.transport_scrambling_control = *dq >> 0x1E; - packet_header.adaptation_field_control = ( *dq & 0x30000000 ) >> 0x1C; - packet_header.continuity_counter = ( *dq & 0x0F000000 ) >> 0x18; - - if ( ( packet_header.sync_byte == 0x47 ) && - ( packet_header.transport_error_indicator == 0 ) && - ( packet_header.pid != 0x1FFF ) ) - { - if ( CheckPID(adapter, packet_header.pid & 0x0000FFFF) != 0 ) - { - dvb_dmx_swfilter_packets(dvbdmx, pbDMABufCurPos, dwDefaultPacketSize/188); + packet_header.sync_byte = *dq & 0x000000FF; + packet_header.transport_error_indicator = *dq & 0x00008000; + packet_header.payload_unit_start_indicator = *dq & 0x00004000; + packet_header.transport_priority = *dq & 0x00002000; + packet_header.pid = ((*dq & 0x00FF0000) >> 0x10) | (*dq & 0x00001F00); + packet_header.transport_scrambling_control = *dq >> 0x1E; + packet_header.adaptation_field_control = (*dq & 0x30000000) >> 0x1C; + packet_header.continuity_counter = (*dq & 0x0F000000) >> 0x18; - } else { + if ((packet_header.sync_byte == 0x47) && (packet_header.transport_error_indicator == 0) && (packet_header.pid != 0x1FFF)) { + if (CheckPID(adapter, packet_header.pid & 0x0000FFFF) != 0) { + dvb_dmx_swfilter_packets(dvbdmx, pbDMABufCurPos, dwDefaultPacketSize / 188); -// dprintk("%s: pid=%x\n", __FUNCTION__, packet_header.pid); + } else { + +// dprintk("%s: pid=%x\n", __FUNCTION__, packet_header.pid); + } + } } - } - } - nNumBytesParsed = nNumBytesParsed + dwDefaultPacketSize; + nNumBytesParsed = nNumBytesParsed + dwDefaultPacketSize; - adapter->DmaQ1.tail = adapter->DmaQ1.tail + dwDefaultPacketSize; + adapter->DmaQ1.tail = adapter->DmaQ1.tail + dwDefaultPacketSize; - if ( adapter->DmaQ1.tail >= adapter->DmaQ1.buffer_size ) adapter->DmaQ1.tail = adapter->DmaQ1.tail - adapter->DmaQ1.buffer_size; - }; + if (adapter->DmaQ1.tail >= adapter->DmaQ1.buffer_size) + adapter->DmaQ1.tail = adapter->DmaQ1.tail - adapter->DmaQ1.buffer_size; + }; - return 1; + return 1; } -//------------------------------------------------------------------- void InterruptServiceDMA2(struct adapter *adapter) { - printk("%s:\n", __FUNCTION__); + printk("%s:\n", __FUNCTION__); } -//------------------------------------------------------------------- void isr(int irq, void *dev_id, struct pt_regs *regs) { - struct adapter *tmp = dev_id; + struct adapter *tmp = dev_id; - u32 value; + u32 value; // dprintk("%s:\n", __FUNCTION__); - spin_lock_irq(&tmp->lock); + spin_lock_irq(&tmp->lock); - while ( ( ( value = ReadRegDW(tmp, 0x20C) ) & 0x0F ) != 0 ) - { - if ( ( value & 0x03 ) != 0 ) InterruptServiceDMA1(tmp); - if ( ( value & 0x0C ) != 0 ) InterruptServiceDMA2(tmp); - } + while (((value = ReadRegDW(tmp, 0x20C)) & 0x0F) != 0) { + if ((value & 0x03) != 0) + InterruptServiceDMA1(tmp); + if ((value & 0x0C) != 0) + InterruptServiceDMA2(tmp); + } - spin_unlock_irq(&tmp->lock); + spin_unlock_irq(&tmp->lock); } -//------------------------------------------------------------------- void InitDmaQueue(struct adapter *adapter) { - dma_addr_t dma_addr; + dma_addr_t dma_addr; + if (adapter->DmaQ1.buffer != 0) + return; - if ( adapter->DmaQ1.buffer != 0 ) return; + adapter->DmaQ1.head = 0; + adapter->DmaQ1.tail = 0; + adapter->DmaQ1.buffer = 0; - adapter->DmaQ1.head = 0; - adapter->DmaQ1.tail = 0; - adapter->DmaQ1.buffer = 0; + adapter->DmaQ1.buffer = pci_alloc_consistent(adapter->pdev, SizeOfBufDMA1 + 0x80, &dma_addr); - adapter->DmaQ1.buffer = pci_alloc_consistent(adapter->pdev, SizeOfBufDMA1 + 0x80, &dma_addr); + if (adapter->DmaQ1.buffer != 0) { + memset(adapter->DmaQ1.buffer, 0, SizeOfBufDMA1); - if ( adapter->DmaQ1.buffer != 0 ) - { - memset(adapter->DmaQ1.buffer, 0, SizeOfBufDMA1); + adapter->DmaQ1.bus_addr = dma_addr; + adapter->DmaQ1.buffer_size = SizeOfBufDMA1; - adapter->DmaQ1.bus_addr = dma_addr; - adapter->DmaQ1.buffer_size = SizeOfBufDMA1; + DmaInitDMA(adapter, 0); - DmaInitDMA(adapter, 0); + adapter->dma_status = adapter->dma_status | 0x10000000; - adapter->dma_status = adapter->dma_status | 0x10000000; - - dprintk("%s: allocated dma buffer at 0x%x, length=%d\n", __FUNCTION__, (int)adapter->DmaQ1.buffer, SizeOfBufDMA1); + dprintk("%s: allocated dma buffer at 0x%x, length=%d\n", __FUNCTION__, (int) adapter->DmaQ1.buffer, SizeOfBufDMA1); - } else { + } else { - adapter->dma_status = adapter->dma_status & ~0x10000000; - } + adapter->dma_status = adapter->dma_status & ~0x10000000; + } + if (adapter->DmaQ2.buffer != 0) + return; - if ( adapter->DmaQ2.buffer != 0 ) return; + adapter->DmaQ2.head = 0; + adapter->DmaQ2.tail = 0; + adapter->DmaQ2.buffer = 0; - adapter->DmaQ2.head = 0; - adapter->DmaQ2.tail = 0; - adapter->DmaQ2.buffer = 0; + adapter->DmaQ2.buffer = pci_alloc_consistent(adapter->pdev, SizeOfBufDMA2 + 0x80, &dma_addr); - adapter->DmaQ2.buffer = pci_alloc_consistent(adapter->pdev, SizeOfBufDMA2 + 0x80, &dma_addr); + if (adapter->DmaQ2.buffer != 0) { + memset(adapter->DmaQ2.buffer, 0, SizeOfBufDMA2); - if ( adapter->DmaQ2.buffer != 0 ) - { - memset(adapter->DmaQ2.buffer, 0, SizeOfBufDMA2); + adapter->DmaQ2.bus_addr = dma_addr; + adapter->DmaQ2.buffer_size = SizeOfBufDMA2; - adapter->DmaQ2.bus_addr = dma_addr; - adapter->DmaQ2.buffer_size = SizeOfBufDMA2; + DmaInitDMA(adapter, 1); - DmaInitDMA(adapter, 1); + adapter->dma_status = adapter->dma_status | 0x20000000; - adapter->dma_status = adapter->dma_status | 0x20000000; + dprintk("%s: allocated dma buffer at 0x%x, length=%d\n", __FUNCTION__, (int) adapter->DmaQ2.buffer, (int) SizeOfBufDMA2); - dprintk("%s: allocated dma buffer at 0x%x, length=%d\n", __FUNCTION__, (int)adapter->DmaQ2.buffer, (int)SizeOfBufDMA2); - - } else { + } else { - adapter->dma_status = adapter->dma_status & ~0x20000000; - } + adapter->dma_status = adapter->dma_status & ~0x20000000; + } } -//------------------------------------------------------------------- void FreeDmaQueue(struct adapter *adapter) { - if ( adapter->DmaQ1.buffer != 0 ) - { - pci_free_consistent(adapter->pdev, SizeOfBufDMA1 + 0x80, adapter->DmaQ1.buffer, adapter->DmaQ1.bus_addr); + if (adapter->DmaQ1.buffer != 0) { + pci_free_consistent(adapter->pdev, SizeOfBufDMA1 + 0x80, adapter->DmaQ1.buffer, adapter->DmaQ1.bus_addr); - adapter->DmaQ1.bus_addr = 0; - adapter->DmaQ1.head = 0; - adapter->DmaQ1.tail = 0; - adapter->DmaQ1.buffer_size = 0; - adapter->DmaQ1.buffer = 0; - } + adapter->DmaQ1.bus_addr = 0; + adapter->DmaQ1.head = 0; + adapter->DmaQ1.tail = 0; + adapter->DmaQ1.buffer_size = 0; + adapter->DmaQ1.buffer = 0; + } - if ( adapter->DmaQ2.buffer != 0 ) - { - pci_free_consistent(adapter->pdev, SizeOfBufDMA2 + 0x80, adapter->DmaQ2.buffer, adapter->DmaQ2.bus_addr); + if (adapter->DmaQ2.buffer != 0) { + pci_free_consistent(adapter->pdev, SizeOfBufDMA2 + 0x80, adapter->DmaQ2.buffer, adapter->DmaQ2.bus_addr); - adapter->DmaQ2.bus_addr = 0; - adapter->DmaQ2.head = 0; - adapter->DmaQ2.tail = 0; - adapter->DmaQ2.buffer_size = 0; - adapter->DmaQ2.buffer = 0; - } + adapter->DmaQ2.bus_addr = 0; + adapter->DmaQ2.head = 0; + adapter->DmaQ2.tail = 0; + adapter->DmaQ2.buffer_size = 0; + adapter->DmaQ2.buffer = 0; + } } -//------------------------------------------------------------------- void FreeAdapterObject(struct adapter *adapter) { - dprintk("%s:\n", __FUNCTION__); + dprintk("%s:\n", __FUNCTION__); - CloseStream(adapter, 0); + CloseStream(adapter, 0); - if ( adapter->irq != 0 ) free_irq(adapter->irq, adapter); + if (adapter->irq != 0) + free_irq(adapter->irq, adapter); - FreeDmaQueue(adapter); + FreeDmaQueue(adapter); - if ( adapter->io_mem != 0 ) iounmap((void *)adapter->io_mem); + if (adapter->io_mem != 0) + iounmap((void *) adapter->io_mem); - if ( adapter != 0 ) kfree(adapter); + if (adapter != 0) + kfree(adapter); } -//------------------------------------------------------------------- int ClaimAdapter(struct adapter *adapter) { - struct pci_dev *pdev = adapter->pdev; + struct pci_dev *pdev = adapter->pdev; + + u16 var; - u16 var; + if (!request_region(pci_resource_start(pdev, 1), pci_resource_len(pdev, 1), pdev->name)) + return -EBUSY; - if ( !request_region(pci_resource_start(pdev,1), pci_resource_len(pdev,1), pdev->name) ) return -EBUSY; + if (!request_mem_region(pci_resource_start(pdev, 0), pci_resource_len(pdev, 0), pdev->name)) + return -EBUSY; - if ( !request_mem_region(pci_resource_start(pdev,0), pci_resource_len(pdev,0), pdev->name) ) return -EBUSY; + pci_read_config_byte(pdev, PCI_CLASS_REVISION, &adapter->card_revision); + dprintk("%s: card revision %x \n", __FUNCTION__, adapter->card_revision); - pci_read_config_byte(pdev, PCI_CLASS_REVISION, &adapter->card_revision); + if (pci_enable_device(pdev)) + return -EIO; - dprintk("%s: card revision %x \n", __FUNCTION__, adapter->card_revision); + pci_read_config_word(pdev, 4, &var); - if ( pci_enable_device(pdev) ) return -EIO; + if ((var & 4) == 0) + pci_set_master(pdev); - pci_read_config_word(pdev, 4, &var); + adapter->io_port = pdev->resource[1].start; - if ( ( var & 4 ) == 0 ) pci_set_master(pdev); + adapter->io_mem = (u32) ioremap(pdev->resource[0].start, 0x800); - adapter->io_port = pdev->resource[1].start; + if (adapter->io_mem == 0) { + dprintk("%s: can not map io memory\n", __FUNCTION__); - adapter->io_mem = (u32)ioremap( pdev->resource[0].start, 0x800); + return 2; + } + + dprintk("%s: io memory maped at %x\n", __FUNCTION__, adapter->io_mem); - if ( adapter->io_mem == 0 ) - { - dprintk("%s: can not map io memory\n", __FUNCTION__); - - return 2; - } - - dprintk("%s: io memory maped at %x\n", __FUNCTION__, adapter->io_mem); - - return 1; + return 1; } -//------------------------------------------------------------------- -int SLL_reset_FlexCOP(struct adapter * adapter) +int SLL_reset_FlexCOP(struct adapter *adapter) { - WriteRegDW(adapter, 0x208, 0); - WriteRegDW(adapter, 0x210, 0xB2FF); + WriteRegDW(adapter, 0x208, 0); + WriteRegDW(adapter, 0x210, 0xB2FF); - return 0; + return 0; } -//------------------------------------------------------------------- u32 DriverInitialize(struct pci_dev * pdev) { - struct adapter * adapter; - u32 tmp; - u8 key[16]; + struct adapter *adapter; + u32 tmp; + u8 key[16]; + + if (!(adapter = kmalloc(sizeof(struct adapter), GFP_KERNEL))) { + dprintk("%s: out of memory!\n", __FUNCTION__); - if ( ! (adapter = kmalloc( sizeof(struct adapter), GFP_KERNEL) ) ) - { - dprintk("%s: out of memory!\n", __FUNCTION__); + return -ENOMEM; + } - return -ENOMEM; - } + memset(adapter, 0, sizeof(struct adapter)); - memset(adapter, 0, sizeof(struct adapter) ); + pdev->driver_data = adapter; - pdev->driver_data = adapter; + adapter->pdev = pdev; + adapter->irq = pdev->irq; - adapter->pdev = pdev; - adapter->irq = pdev->irq; - - if ( ( ClaimAdapter(adapter) ) != 1 ) - { - FreeAdapterObject(adapter); + if ((ClaimAdapter(adapter)) != 1) { + FreeAdapterObject(adapter); - return 2; - } + return 2; + } - IrqDmaEnableDisableIrq(adapter, 0); + IrqDmaEnableDisableIrq(adapter, 0); - if ( request_irq(pdev->irq, isr, 0x4000000, "Skystar2", adapter) != 0 ) - { - dprintk("%s: unable to allocate irq=%d !\n", __FUNCTION__, pdev->irq); + if (request_irq(pdev->irq, isr, 0x4000000, "Skystar2", adapter) != 0) { + dprintk("%s: unable to allocate irq=%d !\n", __FUNCTION__, pdev->irq); - FreeAdapterObject(adapter); - - return 2; - } - - ReadRegDW(adapter, 0x208); - WriteRegDW(adapter, 0x208, 0); - WriteRegDW(adapter, 0x210, 0xB2FF); - WriteRegDW(adapter, 0x208, 0x40); - - InitPIDsInfo(adapter); - - PidSetGroupPID(adapter, 0); - PidSetGroupMASK(adapter, 0x1FE0); - PidSetStream1PID(adapter, 0x1FFF); - PidSetStream2PID(adapter, 0x1FFF); - PidSetPmtPID(adapter, 0x1FFF); - PidSetPcrPID(adapter, 0x1FFF); - PidSetEcmPID(adapter, 0x1FFF); - PidSetEmmPID(adapter, 0x1FFF); - - InitDmaQueue(adapter); - - if ( (adapter->dma_status & 0x30000000) == 0 ) - { - FreeAdapterObject(adapter); + FreeAdapterObject(adapter); + + return 2; + } + + ReadRegDW(adapter, 0x208); + WriteRegDW(adapter, 0x208, 0); + WriteRegDW(adapter, 0x210, 0xB2FF); + WriteRegDW(adapter, 0x208, 0x40); + + InitPIDsInfo(adapter); + + PidSetGroupPID(adapter, 0); + PidSetGroupMASK(adapter, 0x1FE0); + PidSetStream1PID(adapter, 0x1FFF); + PidSetStream2PID(adapter, 0x1FFF); + PidSetPmtPID(adapter, 0x1FFF); + PidSetPcrPID(adapter, 0x1FFF); + PidSetEcmPID(adapter, 0x1FFF); + PidSetEmmPID(adapter, 0x1FFF); + + InitDmaQueue(adapter); - return 2; - } + if ((adapter->dma_status & 0x30000000) == 0) { + FreeAdapterObject(adapter); - adapter->B2C2_revision = ( ReadRegDW(adapter, 0x204) >> 0x18); + return 2; + } + + adapter->B2C2_revision = (ReadRegDW(adapter, 0x204) >> 0x18); + + if ((adapter->B2C2_revision != 0x82) && (adapter->B2C2_revision != 0xC3)) + if (adapter->B2C2_revision != 0x82) { + dprintk("%s: The revision of the FlexCopII chip on your card is - %d\n", __FUNCTION__, adapter->B2C2_revision); + dprintk("%s: This driver works now only with FlexCopII(rev.130) and FlexCopIIB(rev.195).\n", __FUNCTION__); + FreeAdapterObject(adapter); - if( (adapter->B2C2_revision != 0x82) && (adapter->B2C2_revision != 0xC3) ) - if ( adapter->B2C2_revision != 0x82 ) - { - dprintk("%s: The revision of the FlexCopII chip on your card is - %d\n", __FUNCTION__, adapter->B2C2_revision); - dprintk("%s: This driver works now only with FlexCopII(rev.130) and FlexCopIIB(rev.195).\n", __FUNCTION__); + return 2; + } - FreeAdapterObject(adapter); + tmp = ReadRegDW(adapter, 0x204); - return 2; - } + WriteRegDW(adapter, 0x204, 0); + linuxdelayms(20); - tmp = ReadRegDW(adapter, 0x204); + WriteRegDW(adapter, 0x204, tmp); + linuxdelayms(10); - WriteRegDW(adapter, 0x204, 0); - linuxdelayms(20); + tmp = ReadRegDW(adapter, 0x308); + WriteRegDW(adapter, 0x308, 0x4000 | tmp); - WriteRegDW(adapter, 0x204, tmp); - linuxdelayms(10); + adapter->dwSramType = 0x10000; - tmp = ReadRegDW(adapter, 0x308); - WriteRegDW(adapter, 0x308, 0x4000 | tmp ); + SLL_detectSramSize(adapter); + dprintk("%s sram length = %d, sram type= %x\n", __FUNCTION__, SRAM_length(adapter), adapter->dwSramType); - adapter->dwSramType = 0x10000; + SRAMSetMediaDest(adapter, 1); + SRAMSetNetDest(adapter, 1); - SLL_detectSramSize(adapter); - - dprintk("%s sram length = %d, sram type= %x\n", __FUNCTION__, SRAM_length(adapter), adapter->dwSramType); - - SRAMSetMediaDest(adapter, 1); - SRAMSetNetDest(adapter, 1); + CtrlEnableSmc(adapter, 0); - CtrlEnableSmc(adapter, 0); + SRAMSetCaiDest(adapter, 2); + SRAMSetCaoDest(adapter, 2); - SRAMSetCaiDest(adapter, 2); - SRAMSetCaoDest(adapter, 2); + DmaEnableDisableIrq(adapter, 1, 0, 0); + if (EEPROM_getMacAddr(adapter, 0, adapter->mac_addr) != 0) { + printk("%s MAC address = %02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x \n", __FUNCTION__, adapter->mac_addr[0], adapter->mac_addr[1], adapter->mac_addr[2], adapter->mac_addr[3], adapter->mac_addr[4], adapter->mac_addr[5], adapter->mac_addr[6], adapter->mac_addr[7] + ); - DmaEnableDisableIrq(adapter, 1, 0, 0); + CASetMacDstAddrFilter(adapter, adapter->mac_addr); + CtrlEnableMAC(adapter, 1); + } - if ( EEPROM_getMacAddr(adapter, 0, adapter->mac_addr) != 0 ) - { - printk("%s MAC address = %02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x \n", __FUNCTION__, - adapter->mac_addr[0], adapter->mac_addr[1], - adapter->mac_addr[2], adapter->mac_addr[3], - adapter->mac_addr[4], adapter->mac_addr[5], - adapter->mac_addr[6], adapter->mac_addr[7] - ); - - CASetMacDstAddrFilter(adapter, adapter->mac_addr); - CtrlEnableMAC(adapter, 1); - } - - EEPROM_readKey(adapter, key, 16); + EEPROM_readKey(adapter, key, 16); - printk("%s key = \n %02x %02x %02x %02x \n %02x %02x %02x %02x \n %02x %02x %02x %02x \n %02x %02x %02x %02x \n", __FUNCTION__, - key[0], key[1], key[2], key[3], - key[4], key[5], key[6], key[7], - key[8], key[9], key[10], key[11], - key[12], key[13], key[14], key[15] - ); + printk("%s key = \n %02x %02x %02x %02x \n %02x %02x %02x %02x \n %02x %02x %02x %02x \n %02x %02x %02x %02x \n", __FUNCTION__, key[0], key[1], key[2], key[3], key[4], key[5], key[6], key[7], key[8], key[9], key[10], key[11], key[12], key[13], key[14], key[15] + ); - adapter->lock = SPIN_LOCK_UNLOCKED; + adapter->lock = SPIN_LOCK_UNLOCKED; - return 1; + return 1; } -//------------------------------------------------------------------- -void DriverHalt(struct pci_dev * pdev) +void DriverHalt(struct pci_dev *pdev) { - struct adapter * adapter; + struct adapter *adapter; + + adapter = pci_get_drvdata(pdev); - adapter = pci_get_drvdata(pdev); + IrqDmaEnableDisableIrq(adapter, 0); - IrqDmaEnableDisableIrq(adapter, 0); - - CtrlEnableReceiveData(adapter, 0); + CtrlEnableReceiveData(adapter, 0); - FreeAdapterObject(adapter); - - pci_set_drvdata(pdev, NULL); - - release_region(pci_resource_start(pdev,1), pci_resource_len(pdev,1)); - - release_mem_region(pci_resource_start(pdev,0), pci_resource_len(pdev,0)); + FreeAdapterObject(adapter); + + pci_set_drvdata(pdev, NULL); + + release_region(pci_resource_start(pdev, 1), pci_resource_len(pdev, 1)); + + release_mem_region(pci_resource_start(pdev, 0), pci_resource_len(pdev, 0)); } static int dvb_start_feed(struct dvb_demux_feed *dvbdmxfeed) { - struct dvb_demux * dvbdmx = dvbdmxfeed->demux; - struct adapter * adapter = (struct adapter *) dvbdmx->priv; + struct dvb_demux *dvbdmx = dvbdmxfeed->demux; + struct adapter *adapter = (struct adapter *) dvbdmx->priv; - dprintk("%s: PID=%d, type=%d\n", __FUNCTION__, dvbdmxfeed->pid, dvbdmxfeed->type); + dprintk("%s: PID=%d, type=%d\n", __FUNCTION__, dvbdmxfeed->pid, dvbdmxfeed->type); - OpenStream(adapter, dvbdmxfeed->pid); + OpenStream(adapter, dvbdmxfeed->pid); - return 0; + return 0; } static int dvb_stop_feed(struct dvb_demux_feed *dvbdmxfeed) { - struct dvb_demux * dvbdmx = dvbdmxfeed->demux; - struct adapter * adapter = (struct adapter *) dvbdmx->priv; + struct dvb_demux *dvbdmx = dvbdmxfeed->demux; + struct adapter *adapter = (struct adapter *) dvbdmx->priv; - dprintk("%s: PID=%d, type=%d\n", __FUNCTION__, dvbdmxfeed->pid, dvbdmxfeed->type); + dprintk("%s: PID=%d, type=%d\n", __FUNCTION__, dvbdmxfeed->pid, dvbdmxfeed->type); - CloseStream(adapter, dvbdmxfeed->pid); + CloseStream(adapter, dvbdmxfeed->pid); - return 0; + return 0; } ///////////////////////////////////////////////////////////////////// -// LNB control +// LNB control ///////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------- -void set_tuner_tone(struct adapter * adapter, u8 tone) -{ - u16 wzHalfPeriodFor45MHz[] = {0x01FF, 0x0154, 0x00FF, 0x00CC}; - u16 ax; - - dprintk("%s: %u\n", __FUNCTION__, tone); - - switch ( tone ) - { - case 1: ax = wzHalfPeriodFor45MHz[0]; break; - case 2: ax = wzHalfPeriodFor45MHz[1]; break; - case 3: ax = wzHalfPeriodFor45MHz[2]; break; - case 4: ax = wzHalfPeriodFor45MHz[3]; break; - - default: ax = 0; - } +void set_tuner_tone(struct adapter *adapter, u8 tone) +{ + u16 wzHalfPeriodFor45MHz[] = { 0x01FF, 0x0154, 0x00FF, 0x00CC }; + u16 ax; + + dprintk("%s: %u\n", __FUNCTION__, tone); + + switch (tone) { + case 1: + ax = wzHalfPeriodFor45MHz[0]; + break; + case 2: + ax = wzHalfPeriodFor45MHz[1]; + break; + case 3: + ax = wzHalfPeriodFor45MHz[2]; + break; + case 4: + ax = wzHalfPeriodFor45MHz[3]; + break; + + default: + ax = 0; + } - if ( ax != 0 ) - { - WriteRegDW(adapter, 0x200, ( ( ax << 0x0F ) + ( ax & 0x7FFF ) ) | 0x40000000); + if (ax != 0) { + WriteRegDW(adapter, 0x200, ((ax << 0x0F) + (ax & 0x7FFF)) | 0x40000000); - } else { + } else { - WriteRegDW(adapter, 0x200, 0x40FF8000); - } + WriteRegDW(adapter, 0x200, 0x40FF8000); + } } -//------------------------------------------------------------------- -void set_tuner_polarity(struct adapter * adapter, u8 polarity) +void set_tuner_polarity(struct adapter *adapter, u8 polarity) { - u32 var; + u32 var; - dprintk("%s : polarity = %u \n", __FUNCTION__, polarity); + dprintk("%s : polarity = %u \n", __FUNCTION__, polarity); - var = ReadRegDW(adapter, 0x204); + var = ReadRegDW(adapter, 0x204); - if ( polarity == 0 ) - { - dprintk ("%s: LNB power off\n", __FUNCTION__); - var = var | 1; - }; + if (polarity == 0) { + dprintk("%s: LNB power off\n", __FUNCTION__); + var = var | 1; + }; - if ( polarity == 1 ) - { - var = var & ~1; - var = var & ~4; - }; + if (polarity == 1) { + var = var & ~1; + var = var & ~4; + }; - if ( polarity == 2 ) - { - var = var & ~1; - var = var | 4; - } + if (polarity == 2) { + var = var & ~1; + var = var | 4; + } - WriteRegDW(adapter, 0x204, var); + WriteRegDW(adapter, 0x204, var); } -static int flexcop_diseqc_ioctl (struct dvb_frontend *fe, unsigned int cmd, void *arg) +static int flexcop_diseqc_ioctl(struct dvb_frontend *fe, unsigned int cmd, void *arg) { - struct adapter * adapter = fe->before_after_data; + struct adapter *adapter = fe->before_after_data; - switch (cmd) - { + switch (cmd) { case FE_SLEEP: - { - printk ("%s: FE_SLEEP\n", __FUNCTION__); - - set_tuner_polarity(adapter, 0); + { + printk("%s: FE_SLEEP\n", __FUNCTION__); - // return -EOPNOTSUPP, to make DVB core also send "FE_SLEEP" command to frontend. - return -EOPNOTSUPP; - } + set_tuner_polarity(adapter, 0); + + // return -EOPNOTSUPP, to make DVB core also send "FE_SLEEP" command to frontend. + return -EOPNOTSUPP; + } case FE_SET_VOLTAGE: - { - dprintk ("%s: FE_SET_VOLTAGE\n", __FUNCTION__); + { + dprintk("%s: FE_SET_VOLTAGE\n", __FUNCTION__); - switch ((fe_sec_voltage_t) arg) - { - case SEC_VOLTAGE_13: + switch ((fe_sec_voltage_t) arg) { + case SEC_VOLTAGE_13: - printk ("%s: SEC_VOLTAGE_13, %x\n", __FUNCTION__, SEC_VOLTAGE_13); - - set_tuner_polarity(adapter, 1); - - break; + printk("%s: SEC_VOLTAGE_13, %x\n", __FUNCTION__, SEC_VOLTAGE_13); - case SEC_VOLTAGE_18: + set_tuner_polarity(adapter, 1); - printk ("%s: SEC_VOLTAGE_18, %x\n", __FUNCTION__, SEC_VOLTAGE_18); + break; - set_tuner_polarity(adapter, 2); - - break; + case SEC_VOLTAGE_18: - default: - - return -EINVAL; - }; + printk("%s: SEC_VOLTAGE_18, %x\n", __FUNCTION__, SEC_VOLTAGE_18); + + set_tuner_polarity(adapter, 2); + + break; + + default: + + return -EINVAL; + }; + + break; + } - break; - } - case FE_SET_TONE: - { - dprintk ("%s: FE_SET_TONE\n", __FUNCTION__); + { + dprintk("%s: FE_SET_TONE\n", __FUNCTION__); - switch ((fe_sec_tone_mode_t) arg) - { - case SEC_TONE_ON: + switch ((fe_sec_tone_mode_t) arg) { + case SEC_TONE_ON: - printk ("%s: SEC_TONE_ON, %x\n", __FUNCTION__, SEC_TONE_ON); + printk("%s: SEC_TONE_ON, %x\n", __FUNCTION__, SEC_TONE_ON); - set_tuner_tone(adapter, 1); + set_tuner_tone(adapter, 1); - break; - - case SEC_TONE_OFF: - - printk ("%s: SEC_TONE_OFF, %x\n", __FUNCTION__, SEC_TONE_OFF); + break; - set_tuner_tone(adapter, 0); + case SEC_TONE_OFF: - break; - - default: + printk("%s: SEC_TONE_OFF, %x\n", __FUNCTION__, SEC_TONE_OFF); - return -EINVAL; - }; + set_tuner_tone(adapter, 0); - break; - } - - default: + break; + + default: + + return -EINVAL; + }; + + break; + } + + default: - return -EOPNOTSUPP; - }; + return -EOPNOTSUPP; + }; - return 0; + return 0; } -//------------------------------------------------------------------- static int skystar2_probe(struct pci_dev *pdev, const struct pci_device_id *ent) { - struct adapter * adapter; - struct dvb_adapter * dvb_adapter; - struct dvb_demux * dvbdemux; + struct adapter *adapter; + struct dvb_adapter *dvb_adapter; + struct dvb_demux *dvbdemux; + + int ret; + + if (pdev == NULL) + return -ENODEV; + + if (DriverInitialize(pdev) != 1) + return -ENODEV; + + dvb_register_adapter(&dvb_adapter, pdev->name); + + if (dvb_adapter == NULL) { + printk("%s: Error registering DVB adapter\n", __FUNCTION__); + + DriverHalt(pdev); + + return -ENODEV; + } - int ret; + adapter = (struct adapter *) pdev->driver_data; - if ( pdev == NULL ) return -ENODEV; + adapter->dvb_adapter = dvb_adapter; - if ( DriverInitialize(pdev) != 1 ) return -ENODEV; - - dvb_register_adapter(&dvb_adapter, pdev->name); - - if (dvb_adapter == NULL) - { - printk("%s: Error registering DVB adapter\n", __FUNCTION__); - - DriverHalt(pdev); + init_MUTEX(&adapter->i2c_sem); - return -ENODEV; - } - - adapter = (struct adapter *) pdev->driver_data; + adapter->i2c_bus = dvb_register_i2c_bus(master_xfer, adapter, adapter->dvb_adapter, 0); - adapter->dvb_adapter = dvb_adapter; + if (!adapter->i2c_bus) + return -ENOMEM; - init_MUTEX(&adapter->i2c_sem); + dvb_add_frontend_ioctls(adapter->dvb_adapter, flexcop_diseqc_ioctl, NULL, adapter); - adapter->i2c_bus = dvb_register_i2c_bus(master_xfer, adapter, adapter->dvb_adapter, 0); + dvbdemux = &adapter->demux; + + dvbdemux->priv = (void *) adapter; + dvbdemux->filternum = 32; + dvbdemux->feednum = 32; + dvbdemux->start_feed = dvb_start_feed; + dvbdemux->stop_feed = dvb_stop_feed; + dvbdemux->write_to_decoder = 0; + dvbdemux->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING | DMX_MEMORY_BASED_FILTERING); + + dvb_dmx_init(&adapter->demux); - if (!adapter->i2c_bus) return -ENOMEM; + adapter->hw_frontend.source = DMX_FRONTEND_0; - dvb_add_frontend_ioctls(adapter->dvb_adapter, flexcop_diseqc_ioctl, NULL, adapter); + adapter->dmxdev.filternum = 32; + adapter->dmxdev.demux = &dvbdemux->dmx; + adapter->dmxdev.capabilities = 0; - dvbdemux = &adapter->demux; - - dvbdemux->priv = (void *) adapter; - dvbdemux->filternum = 32; - dvbdemux->feednum = 32; - dvbdemux->start_feed = dvb_start_feed; - dvbdemux->stop_feed = dvb_stop_feed; - dvbdemux->write_to_decoder = 0; - dvbdemux->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING | DMX_MEMORY_BASED_FILTERING); + dvb_dmxdev_init(&adapter->dmxdev, adapter->dvb_adapter); - dvb_dmx_init(&adapter->demux); + ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &adapter->hw_frontend); + if (ret < 0) + return ret; - adapter->hw_frontend.source = DMX_FRONTEND_0; + adapter->mem_frontend.source = DMX_MEMORY_FE; - adapter->dmxdev.filternum = 32; - adapter->dmxdev.demux = &dvbdemux->dmx; - adapter->dmxdev.capabilities = 0; - - dvb_dmxdev_init(&adapter->dmxdev, adapter->dvb_adapter); + ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &adapter->mem_frontend); + if (ret < 0) + return ret; - ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &adapter->hw_frontend); - if (ret < 0) return ret; - - adapter->mem_frontend.source = DMX_MEMORY_FE; - - ret=dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &adapter->mem_frontend); - if (ret < 0) return ret; - - ret = dvbdemux->dmx.connect_frontend(&dvbdemux->dmx, &adapter->hw_frontend); - if (ret < 0) return ret; - - dvb_net_init(adapter->dvb_adapter, &adapter->dvbnet, &dvbdemux->dmx); - return 0; + ret = dvbdemux->dmx.connect_frontend(&dvbdemux->dmx, &adapter->hw_frontend); + if (ret < 0) + return ret; + + dvb_net_init(adapter->dvb_adapter, &adapter->dvbnet, &dvbdemux->dmx); + return 0; } -//------------------------------------------------------------------- -static void skystar2_remove(struct pci_dev * pdev) +static void skystar2_remove(struct pci_dev *pdev) { - struct adapter * adapter; - struct dvb_demux * dvbdemux; + struct adapter *adapter; + struct dvb_demux *dvbdemux; - if ( pdev == NULL ) return; + if (pdev == NULL) + return; - adapter = pci_get_drvdata(pdev); + adapter = pci_get_drvdata(pdev); - if ( adapter != NULL ) - { - dvb_net_release(&adapter->dvbnet); - dvbdemux = &adapter->demux; - - dvbdemux->dmx.close(&dvbdemux->dmx); - dvbdemux->dmx.remove_frontend(&dvbdemux->dmx, &adapter->hw_frontend); - dvbdemux->dmx.remove_frontend(&dvbdemux->dmx, &adapter->mem_frontend); - - dvb_dmxdev_release(&adapter->dmxdev); - dvb_dmx_release(&adapter->demux); + if (adapter != NULL) { + dvb_net_release(&adapter->dvbnet); + dvbdemux = &adapter->demux; - if ( adapter->dvb_adapter != NULL ) - { - dvb_remove_frontend_ioctls (adapter->dvb_adapter, flexcop_diseqc_ioctl, NULL); + dvbdemux->dmx.close(&dvbdemux->dmx); + dvbdemux->dmx.remove_frontend(&dvbdemux->dmx, &adapter->hw_frontend); + dvbdemux->dmx.remove_frontend(&dvbdemux->dmx, &adapter->mem_frontend); - if ( adapter->i2c_bus != NULL ) dvb_unregister_i2c_bus(master_xfer, adapter->i2c_bus->adapter, adapter->i2c_bus->id); + dvb_dmxdev_release(&adapter->dmxdev); + dvb_dmx_release(&adapter->demux); - dvb_unregister_adapter (adapter->dvb_adapter); - } + if (adapter->dvb_adapter != NULL) { + dvb_remove_frontend_ioctls(adapter->dvb_adapter, flexcop_diseqc_ioctl, NULL); - DriverHalt(pdev); - } -} + if (adapter->i2c_bus != NULL) + dvb_unregister_i2c_bus(master_xfer, adapter->i2c_bus->adapter, adapter->i2c_bus->id); + + dvb_unregister_adapter(adapter->dvb_adapter); + } + DriverHalt(pdev); + } +} static struct pci_device_id skystar2_pci_tbl[] = { - { 0x000013D0, 0x00002103, 0xFFFFFFFF, 0xFFFFFFFF, 0x00000000, 0x00000000, 0x00000000 }, - { 0, }, + {0x000013D0, 0x00002103, 0xFFFFFFFF, 0xFFFFFFFF, 0x00000000, 0x00000000, 0x00000000}, + {0,}, }; static struct pci_driver skystar2_pci_driver = { - .name = "Technisat SkyStar2 driver", - .id_table = skystar2_pci_tbl, - .probe = skystar2_probe, - .remove = skystar2_remove, + .name = "Technisat SkyStar2 driver", + .id_table = skystar2_pci_tbl, + .probe = skystar2_probe, + .remove = skystar2_remove, }; -//------------------------------------------------------------------- static int skystar2_init(void) { - printk("\nTechnisat SkyStar2 driver loading\n"); + printk("\nTechnisat SkyStar2 driver loading\n"); - return pci_module_init(&skystar2_pci_driver); + return pci_module_init(&skystar2_pci_driver); } -//------------------------------------------------------------------- static void skystar2_cleanup(void) { - printk("\nTechnisat SkyStar2 driver unloading\n"); + printk("\nTechnisat SkyStar2 driver unloading\n"); - pci_unregister_driver(&skystar2_pci_driver); + pci_unregister_driver(&skystar2_pci_driver); } module_init(skystar2_init); |