DVD data descrambler for host interface and MPEG interface5917914Abstract A descrambler for a Digital Versatile Disk (DVD) is provided within a DVD controller to allow for real-time descrambling of DVD data from the DVD buffer. The built-in descrambler also allows the controller to interface with a Host Adapter (e.g., ATAPI Host) or MPEG II decoder. The descrambling circuit reads four bits of an identifier portion of each sector. These four bits are used to access a look up table LUT in the descrambler for retrieving a 15 bit seed. The fifteen bit seed is used to generate a descrambling patter, which, when XORed with scrambled data, will descramble data on a byte-by-byte basis. The descrambling pattern is generated on a flash basis, by performing eight shift operations and XOR operations simultaneously, allowing for descrambling one byte per clock cycle. In the preferred embodiment, the flash descrambler may use a programmed register transfer logic (RTL) to generate sixteen bits of descrambling pattern at a time, to allow for descrambling on a word-by-word basis at the rate of one word per clock cycle. Claims What is claimed is: Description FIELD OF THE INVENTION
______________________________________
Segment Bytes Description
______________________________________
ID 4 Identification
IED 2 ID error detection
(detection & correction for ID)
CPR-MAI 6 Copyright Management Information
DATA 2048 Data
EDC 4 Error Detection Code (for DATA)
______________________________________
As illustrated in FIG. 4, each sector may be divided into 12 rows of 172 bytes each, the total of which is 2064 bytes of information, of which 2048 are data. As in prior art CD-ROMs and other rotating media, the concept of a data sector remains in DVD technology. When making a new DVD disk, the ID (e.g., logical sector address) may be first determined, and then error detection/correction IED is calculated. Such error detection and correction techniques are well known in the art (e.g., hamming codes, and the like) and are not necessary for a complete understanding of the present invention. After the IED, six bytes are reserved for proprietary copyright information in the CPR-MAI field. Actual data may then be stored after the CPR-MAI field. From the 2048 bytes of data, a four byte Error Detection Code EDC may be calculated using checksum, cyclic redundancy check (CRC) or the like. Error detection code EDC may represent an error detection code for data within the sector illustrated in FIG. 4. For purposes of illustration, Error Correction Codes (ECC) is not illustrated in FIG. 4. Once an individual sector has been formatted, as illustrated in FIG. 4, the DATA portion may then be scrambled. At this point, actual data may not have been written to a DVD, but merely formatted and stored in preparation for writing (or manufacturing) a DVD. The non-DATA portions of the sector illustrated in FIG. 4 are not scrambled, only the DATA portion. FIG. 2 is a simplified schematic representation of a DATA scrambler. Data is scrambled on a byte-by-byte basis. Each byte from the 2048 bytes in the sector of FIG. 4 is individually scrambled and then returned to its original location. Actual scrambling comprises taking an individual byte of data and XORing the data with a predetermined pattern byte. To descramble the data, one need only XOR the scrambled data with the correct pattern to retrieve the unscrambled data. As illustrated in FIG. 2, the data scrambler works as follows. A starting "seed" of fifteen bits is stored in a shift register 290. Other numbers of bits may be used, but for DVD data, fifteen bits has been chosen. The eight least significant bits (LSB), or bits r0 through r7 of the contents of shift register 290 may be used to XOR with a particular data byte. The first data byte may be XORed with the eight LSB of S.sub.-- REG.sub.-- HOLD.sub.-- HALF. After that, the scrambler of FIG. 2 generates a new pattern from the contents of shift register 290 as follows. The contents of shift register contain fifteen bits, r.sub.0 through r.sub.14. After a byte is scrambled, a new pattern is generated by shifting the contents of shift register 290 and XORing bit r.sub.14 with bit r.sub.10 in XOR gate 280 and placing the contents in bit r.sub.0 of shift register 290 as illustrated in FIG. 2. This shift and XOR operation may be performed eight times to generate a new scrambling pattern from the previous contents of shift register 290. Once each byte is scrambled, it is returned to its correct corresponding location in the sector of FIG. 4. Information indicating which of a number seed values is to be used may be dependent on the identification section ID. Thus, the seed value may change from sector to sector. In the above description, error correction codes have not been discussed for the sake of clarity and simplicity. However, in actual practice, once all sectors, or a number of sectors, have been formatted, and prior to byte scrambling, other types of error correction codes may be applied as illustrated in FIG. 3. FIG. 3 is a diagram illustrating the data storage format for data in the buffer memory with parity information. Data from a number of sectors (e.g., 16) is taken together to generate an error correction code comprising outer and inner parity values (PO and PI). Outer and inner parity values PO and PI may then be interleaved with DATA (D1, D2, D3) within each sector. The use of interleaved error correction codes is illustrated only for the sake of completeness, and forms no part of the present invention. Outer and inner parity values PO and PI, however, are not scrambled or treated as regular data. Thus, once DATA has been assigned to individual sectors and scrambled, interleaved outer and inner parity values are calculated and assigned to each sector. DATA (but not outer and inner parity values PO and PI) are scrambled as discussed above. Before DATA is descrambled, parity values PO and PI are used to detect and correct errors in scrambled DATA. The descrambling device of the present invention will divert PI and PO data from the descrambler and store such data directly in the buffer if the host demands such data. As the descrambling circuit has been preprogrammed with the standard DVD format, it may distinguish between scrambled DATA and PI and PO information. The technique illustrated in FIG. 2 may be reproduced anywhere, so long as a user has the correct seed and combinational logic. Thus, a simple descrambler may be built from FIG. 2 as well. However, such a descrambler may require up to eight clock cycles between descrambling each byte in order to generate a new descrambling pattern value using the shift and XOR operation outlined above. Such a technique may be undesirable when descrambling data in real-time. FIG. 1 is a block diagram illustrating a DVD descrambler which may descramble DVD data on a byte-by-byte basis. Data from a DVD may be initially stored in raw form in a DRAM buffer (not shown). Data from the DRAM buffer may be fed over Buffer Data Input bus (BDI) which may comprise a 16 bit wide bus. Latch 100 may receive buffer data and latch 16 bits at the start of each sector in response to signal load.sub.-- ID0. Signal load.sub.-- ID0 may be generated from the start of a sector or the end of a previous sector. Bits 4 through 7 of the ID field are used to select one of sixteen seed values from look-up table (LUT) 110. Predetermined seed values are stored in LUT 110 according to the DVD specification. The output of LUT 110 is the 15 bit SEED, which passes to MUX 120. At the start of each sector, signal LOAD SEED switches MUX 120 to load the 15 bit SEED value to S-REG 130. Thereafter, the value loaded into S-REG 130 is fed back as will be discussed in more detail below. The fifteen bits of the SEED are loaded as bits r0 through r.sub.14. As noted above, one difference between DVD applications and CD applications is that in CD-ROM and CD audio, most things are happening in a serial fashion. For example, in the CD-ROM area, there is also a similar scrambler, but that is doing a serial bit shifting, every clock, because data coming from the so-called DSP (Digital Signal Processor) chip is sent in a serial format to the controller. But now, by integrating the DSP and the controller together, it may be necessary to make everything byte- or word-oriented for better performance. What used to take eight clocks now takes only one or two clocks. Because of that concern, a bit-by-bit shift may not be possible. Thus, S-REG 130, XOR gate 140 and S-REG-HOLD-HALF register 150 together performs a "flash" pattern generation using a shift and XOR operation to generate a descrambling pattern in one cycle. S-REG 130 operates on a half-clock cycle basis. Within one clock cycle, S-REG 130, S-REG-HOLD-HALF register 150, and XOR gate 140 perform the equivalent of eight place shifts and eight simultaneous XOR operations. As there are 15 bits in the pattern value, it is possible to obtain the next subsequent pattern without waiting for individual shift operations to be completed. As illustrated in FIG. 1, the seven LSB of S-REG 130 are shifted into the seven Most Significant Bits (MSBs) of S-REG-HOLD-HALF register 150. The eight MSB of S-REG 130 are XORed together as follows and stored in the eight LSB of S-REG-HOLD-HALF register 150 according to the following equations: s.sub.1 ›7!=r.sub.14 .sym.r.sub.10 (1) s.sub.1 ›6!=r.sub.13 .sym.r.sub.9 (2) s.sub.1 ›5!=r.sub.12 .sym.r.sub.8 (3) s.sub.1 ›4!=r.sub.11 .sym.r.sub.7 (4) s.sub.1 ›3!=r.sub.10 .sym.r.sub.6 (5) s.sub.1 ›2!=r.sub.9 .sym.r.sub.5 (6) s.sub.1 ›1!=r.sub.8 .sym.r.sub.4 (7) s.sub.1 ›0!=r.sub.7 .sym.r.sub.3 (8) In one embodiment of the present invention, a two clock cycle buffer may be used. Every two clock cycles, the buffer is accessed once to retrieve 16 bits. However, the apparatus of FIG. 1 produces one byte of pattern at a time. One byte of pattern is needed to generate one descrambled byte in one clock cycle so that a second clock cycle may generate a second byte, to form a word. As illustrated in FIG. 1, the present invention uses a half-clock to temporarily store that pattern information in S-REG-HOLD-HALF register 150. Thus, when shifting the contents of S-REG 130, data is not destroyed and the shifted pattern may be retained to generate the next byte of pattern data. S-REG-HOLD-HALF register 150 holds the new pattern and then sends it back to MUX 120. One input of MUX 120 is taking the new shifted pattern, while the other leg of MUX 120 is taking the SEED. For the first byte of each sector, the SEED is loaded into S-REG 130. For every subsequent byte of DATA in a sector, S-REG 130 is updated with new pattern data. The output of S-REG-HOLD-HALF register 150 is fed to latches 160 and 170. Latch 160 will latch the eight LSB of the contents of S-REG-HOLD-HALF for a lower byte of buffer data BDI›7:0!. Latch 170 will latch the eight LSB of the contents of S-REG-HOLD-HALF for an upper byte of buffer data BDI›15:8!. XOR gate 180 will XOR eight bits of pattern data from latch 160 with a lower byte of buffer data BDI›7:0!. XOR gate 190 will XOR eight bits of pattern data from latch 170 with an upper byte of buffer data BDI›15:8!. The resulting descrambled data will be selectively stored in Host FIFO 220 in corresponding low and high bytes. MUXES 200 and 210 are provided to allow data from buffer data interface bus BDI to bypass the descrambling process. As noted above, inner and outer parity information PI and PO are interleaved with DATA in each sector. Signal DVD-data indicates that data from buffer data interface bus BDI is in fact DATA and not parity information PI or PO, and switches XORed data into Host FIFO 220. If signal DVD-data indicates that data from buffer data interface BDI is PI or PO data, that data is switched directly to Host FIFO 220 without being XORed. The apparatus of FIG. 1 may use two clock cycles to process one 16-bit word of data, providing adequate breathing room to process one byte in one clock cycle. A second clock cycle is used to process the high byte. Although the apparatus of FIG. 1 may be adequate for processing DVD data, in the preferred embodiment, it may be desirable to change to a different buffer access scheme, in which everything happens in one clock cycle. Using such an address scheme, there may be problems with the architecture of FIG. 1, as there are not two clock cycles available to do an 8-bit shift. Thus, in the preferred embodiment, a 16-bit shift may be required within one clock cycle. One huge operation can shift the scrambler 16 times but still generate the correct pattern for the shifter. Such a system will allow increased performance in the buffer. To implement such a design, the apparatus of FIG. 1 may be modified by replacing S-REG 130, XOR gate 140 and S-REG-HOLD-HALF register with an RTL (Register Transfer Logic) table and make the data paths wider as well. FIG. 5 is a block diagram illustrating a DVD descrambler of the preferred embodiment which may descramble DVD data on a word-by-word basis. The apparatus of FIG. 5 is similar to that in FIG. 1, except that the data path for the pattern has been expanded to sixteen bits, and sixteen bits of DATA from buffer data interface bus BDI are XORed in XOR gate 500 to descramble DATA. XOR gate 140 has been replaced by Register Transfer Logic (RTL) 540 which operates according to equations 9-39 below. RTL 540 receives all fifteen bytes of pattern data from S-REG 130 and outputs two bytes of pattern data SP›15:0! to S-REG-HOLD-HALF register 150 which has been expanded to sixteen bits accordingly. Pattern data SP›15:0! represents two sequential bytes of pattern data for descrambling two successive bytes of DATA. RTL 540 also outputs 15 bits of revised pattern data representing a revised 15 bit pattern corresponding to the high byte of a word. This 15 bit pattern is then fed back through S-REG 130 to generate the next two bytes of pattern data according to equations 9-39. First Shift Equations: s.sub.1 ›14!=r.sub.6 (9) s.sub.1 ›13!=r.sub.5 (10) s.sub.1 ›12!=r.sub.4 (11) s.sub.1 ›11!=r.sub.3 (12) s.sub.1 ›10!=r.sub.2 (13) s.sub.1 ›9!=r.sub.1 (14) s.sub.1 ›8!=r.sub.0 (15) s.sub.1 ›7!=r.sub.14 .sym.r.sub.10 (16) s.sub.1 ›6!=r.sub.13 .sym.r.sub.9 (17) s.sub.1 ›5!=r.sub.12 .sym.r.sub.8 (18) s.sub.1 ›4!=r.sub.11 .sym.r.sub.7 (19) s.sub.1 ›3!=r.sub.10 .sym.r.sub.6 (20) s.sub.1 ›2!=r.sub.9 .sym.r.sub.5 (21) s.sub.1 ›1!=r.sub.8 .sym.r.sub.4 (22) s.sub.1 ›0!=r.sub.7 .sym.r.sub.3 (23) Second Shift Equations: s.sub.2 ›14!=s.sub.1 ›6!=r.sub.13 .sym.r.sub.9 (24) s.sub.2 ›13!=s.sub.1 ›5!=r.sub.12 .sym.r.sub.8 (25) s.sub.2 ›12!=s.sub.1 ›4!=r.sub.11 .sym.r.sub.7 (26) s.sub.2 ›11!=s.sub.1 ›3!=r.sub.10 .sym.r.sub.6 (27) s.sub.2 ›10!=s.sub.1 ›2!=r.sub.9 .sym.r.sub.5 (28) s.sub.2 ›9!=s.sub.1 ›1!=r.sub.8 .sym.r.sub.4 (29) s.sub.2 ›8!=s.sub.1 ›0!=r.sub.14 .sym.r.sub.10 (30) s.sub.2 ›7!=s.sub.1 ›14!.sym.s.sub.1 ›10!=r.sub.6 .sym.r.sub.2(31) s.sub.2 ›6!=s.sub.1 ›13!.sym.s.sub.1 ›9!=r.sub.5 .sym.r.sub.1(32) s.sub.2 ›5!=s.sub.1 ›12!.sym.s.sub.1 ›8!=r.sub.4 .sym.r.sub.0(33) s.sub.2 ›4!=s.sub.1 ›11!.sym.s.sub.1 ›7!=r.sub.3 .sym.r.sub.14 .sym.r.sub.10(34) s.sub.2 ›3!=s.sub.1 ›10!.sym.s.sub.1 ›6!=r.sub.2 .sym.r.sub.13 .sym.r.sub.9(35) s.sub.2 ›2!=s.sub.1 ›9!.sym.s.sub.1 ›5!=r.sub.1 .sym.r.sub.12 .sym.r.sub.8( 36) s.sub.2 ›1!=s.sub.1 ›8!.sym.s.sub.1 ›4!=r.sub.0 .sym.r.sub.11 .sym.r.sub.7( 37) s.sub.2 ›0!=s.sub.1 ›7!.sym.s.sub.1 ›3!=r.sub.14 .sym.r.sub.10 .sym.r.sub.10 .sym.r.sub.6 (38) Scramble Pattern: SD›15:0!=s.sub.2 ›7:0!&s1›7:0! (39) In equations 9-39, In this table, S.sub.1 and S.sub.2 represent the equivalent of a first and second shift (e.g., low byte and high byte), respectively, in a byte-by-byte descrambling system such as that illustrated in FIG. 1. As can be noted from equations 9-39, it is not necessary to perform the first shift in order to calculate values for the second shift. Thus, a combination logic circuit or the like may be readily constructed to generate the values of equations 9-39 in one clock cycle. In the preferred embodiment, a register transfer logic may be employed to implement equations 9-39. Scrambler Pattern SD›15:0! equals the shift patterns S1›7:0! and S2›7:0! concatenated into one word. Scrambler pattern SD›15:0! may then be used to XOR with one word of DATA to descramble DATA on a word-by-word basis. In both FIGS. 1 and 5, once data is descrambled, data may be output to the host buffer and also to data sector EDC 230. Data sector EDC 230 may perform a checksum, CRC or the like, to determine whether any errors have been introduced into sector data. If an error occurs, the sector may be re-read, processing may be halted, or other appropriate action taken. One advantage of the present invention is that data is left untouched in the DRAM buffer, except when error correction occurs. Even when error correction occurs, only corrupted data is corrected, and the order of data is not altered. Raw (scrambled) data thus sits in the DRAM buffer waiting to be grabbed, to run through the circuit of FIGS. 1 or 5. Although the present invention has been illustrated and described in detail, it is clearly understood that the same is by way of illustration and example only and is not to be taken by way of limitation, the scope and spirit of the present invention being limited only the terms of the appended claims.
|
Same subclass Same class Consider this |
||||||||||
