KR20020059777A - Preparation of data for a reed-solomon decoder - Google Patents

Preparation of data for a reed-solomon decoder Download PDF

Info

Publication number
KR20020059777A
KR20020059777A KR1020027006589A KR20027006589A KR20020059777A KR 20020059777 A KR20020059777 A KR 20020059777A KR 1020027006589 A KR1020027006589 A KR 1020027006589A KR 20027006589 A KR20027006589 A KR 20027006589A KR 20020059777 A KR20020059777 A KR 20020059777A
Authority
KR
South Korea
Prior art keywords
data
address
buffer
reed
ecc
Prior art date
Application number
KR1020027006589A
Other languages
Korean (ko)
Other versions
KR100754905B1 (en
Inventor
로터 프레이스만
Original Assignee
데니스 에이치. 얼백
톰슨 라이센싱 소시에떼 아노님
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 데니스 에이치. 얼백, 톰슨 라이센싱 소시에떼 아노님 filed Critical 데니스 에이치. 얼백
Publication of KR20020059777A publication Critical patent/KR20020059777A/en
Application granted granted Critical
Publication of KR100754905B1 publication Critical patent/KR100754905B1/en

Links

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/13Linear codes
    • H03M13/15Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B20/00Signal processing not specific to the method of recording or reproducing; Circuits therefor
    • G11B20/10Digital recording or reproducing
    • G11B20/18Error detection or correction; Testing, e.g. of drop-outs
    • G11B20/1806Pulse code modulation systems for audio signals
    • G11B20/1809Pulse code modulation systems for audio signals by interleaving

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Probability & Statistics with Applications (AREA)
  • Signal Processing (AREA)
  • Algebra (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Pure & Applied Mathematics (AREA)
  • Multimedia (AREA)
  • Error Detection And Correction (AREA)
  • Detection And Correction Of Errors (AREA)
  • Detection And Prevention Of Errors In Transmission (AREA)

Abstract

본 발명은 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법 및 장치에 관한 것으로, 더 상세하게는, 램부재 DVD 리드-솔로몬 디코더 앞의 지능 버퍼(IBUF)를 위한 방법 및 장치에 관한 것이고, 더욱 특별하게는 ECC-블록의 제 1 통과 정정 저장부로서 또한 사용되는 지능 버퍼(IBUF)를 위한 방법 및 장치에 관한 것이다. 그러한 방법에 있어서, 리드-솔로몬 디코더는 완전한 회로의 고성능 및 보다 적은 필수 RAM을 유도하는 지능 버퍼(IBUF)를 통해서 무질서한 ECC 블록을 획득하지 않을 것이다. 지능 버퍼(IBUF)는 리드 솔로몬 디코더의 제 1 통과 정정 저장부로도 또한 사용된다.The present invention relates to a method and apparatus for preparing data for a Reed-Solomon decoder, and more particularly, to a method and apparatus for an intelligent buffer (IBUF) in front of a RAM member DVD Reed-Solomon decoder. In particular it relates to a method and apparatus for an intelligent buffer (IBUF) which is also used as a first pass correction storage of an ECC-block. In such a method, the Reed-Solomon decoder will not obtain a disordered ECC block through an intelligent buffer (IBUF) that leads to a high performance and less required RAM of a complete circuit. The intelligent buffer IBUF is also used as the first pass correction storage of the Reed Solomon decoder.

Description

리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치 및 방법{PREPARATION OF DATA FOR A REED-SOLOMON DECODER}Apparatus and method for preparing data for a Reed-Solomon decoder {PREPARATION OF DATA FOR A REED-SOLOMON DECODER}

종래의 사전-처리용 버퍼와 리드-솔로몬은 훼손된 데이터를 처리하기 위해서 공통의 RAM을 사용한다. 그러한 장치 및 처리는 일예로 재생을 위해서 DVD와 같은 광 정보 매체 상에 저장된 데이터를 정정하는데 사용된다. 훼손된 데이터를 리드-솔로몬 디코더에 인가하는 것과, ECC 블록을 저장하기 위해서 RAM을 사용하는 것과, 데이터 경로의 속도를 감소시키는 수 차례의 결함 부분 판독을 회피하는 것이 바람직하다. DVD는 디지털 다목적 디스크에 대한 약어이고, ECC는 데이터의 완전성을 검사하는 전자적인 방법인 에러 정정 코드에 대한 약어이다.Conventional pre-processing buffers and Reed-Solomon use a common RAM to process corrupted data. Such apparatus and processing are used, for example, to correct data stored on optical information media such as DVDs for playback. It is desirable to apply corrupted data to the Reed-Solomon decoder, to use RAM to store ECC blocks, and to avoid several faulty reads that reduce the speed of the data path. DVD stands for Digital Versatile Disc, and ECC stands for Error Correction Code, an electronic method of checking data integrity.

ECC의 데이터는 데이터 스트림의 일부분(pieces)에 계층적으로 구성된다. 가장 높은 단위는 다수의 섹터로 분할되는 ECC-블록이다. 각각의 섹터는 고정 길이를 갖는 다수의 행으로 구성된다. 스트림의 정정을 가능하게 하기 위해서, 다수의 패리티 바이트(parity bytes)가 각각의 행에 첨부되고, 추가 바이트의 수가 행마다의정정가능한 결함 장애(fault) 수를 결정한다. 이러한 수평적인 정정 기능 외에도, 한 행의 동일 위치에 있는 ECC-블록의 모든 바이트에 대해서 동일한 계산이 수직적으로 수행되고, 그 결과는 ECC-블록의 추가적인 행에 구성된다.The data of the ECC is organized hierarchically into pieces of the data stream. The highest unit is the ECC-block, which is divided into a number of sectors. Each sector consists of a number of rows with a fixed length. In order to enable correction of the stream, a number of parity bytes are appended to each row, and the number of additional bytes determines the number of correctable fault faults per row. In addition to this horizontal correction function, the same calculation is performed vertically for all bytes of the ECC-block at the same position in one row, and the result is organized in additional rows of the ECC-block.

섹터들의 순서를 제어하기 위해서, 첫 번째 바이트는 식별 정보를 포함한다. 버퍼 및 리드-솔로몬 부분 앞의 블록들은 프레임 내의 스트림을 획득하는데, 두 개의 프레임이 한 행을 구성하고, 프레임 순서의 식별이 평가되며, 그 결과가 적절한 동기-신호에 의해서 버퍼에 이용가능하게 된다.In order to control the order of the sectors, the first byte contains identification information. The blocks in front of the buffer and Reed-Solomon part acquire a stream within the frame, where two frames constitute a row, the identification of the frame order is evaluated, and the result is made available to the buffer by the appropriate sync-signal. .

종래의 장치는, 리드-솔로몬 디코더가 훼손된 데이터 바이트의 정정을 수행하는 것을 시작하기 이전에, 식별 제어 결과에 대하여 공통의 RAM에 데이터를 저장한다. 메모리 내의 장애 데이터를 교체하는 것은 불어날 수 있는 처리비용을 요구할 것이고 시스템 성능을 상당히 약화시킬 것이다.Conventional apparatus stores data in a common RAM for identification control results before the Reed-Solomon decoder begins to correct the corrupted data bytes. Replacing faulty data in memory will require significant processing costs and will significantly reduce system performance.

RAM은 랜덤 엑세스 메모리의 약어이다. 그것은, 프로세서가 프로그램을 실행하고 데이터를 유지하기 위해서 사용하는 일시적인 저장 영역이다. 리드 솔로몬은 수신용 비트 스트림에서 비트 에러의 영향을 상쇄시키는데 사용되는 순방향 에러 정정 코드에 대한 기술적인 용어이다. 리드-솔로몬 코드는 특별하면서 광범위하게 구현되는데, 그 이유는 인코더에 의해서 추가되는 가외의 중복 데이터 수가 임의의 레벨의 에러 정정에 대해서 최소한의 개수이므로 어떠한 비트도 허비되지 않는다는 점에서 거의 완벽하기 때문이다.RAM stands for random access memory. It is a temporary storage area that the processor uses to run programs and maintain data. Reed Solomon is a technical term for a forward error correction code used to offset the effects of bit errors in the receive bit stream. Reed-Solomon code is special and widely implemented because it is almost perfect in that no bits are wasted because the number of extra redundant data added by the encoder is minimal for any level of error correction. .

본 발명은 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법 및 장치에 관한 것으로, 더 상세하게는, 보다 적은 RAM을 필요로 하면서도 고성능을 보장하는 리드-솔로몬 디코더 앞의 지능 버퍼에 대한 방법 및 장치에 관한 것이다.The present invention relates to a method and apparatus for preparing data for a Reed-Solomon decoder, and more particularly, to a method and apparatus for an intelligent buffer in front of the Reed-Solomon decoder that requires less RAM and guarantees high performance. It is about.

도 1에서는 일부 구동 회로와 함께, 램부재 DVD 리드-솔로몬 디코더 앞의 지능 버퍼에 대한 블록도.1 is a block diagram of an intelligent buffer in front of a RAM member DVD Reed-Solomon decoder, with some drive circuitry.

도 2는 addr_in>addr_out인 경우의 순방향 점프에 대한 개략도.2 is a schematic diagram of a forward jump when addr_in> addr_out.

도 3은 addr_in<addr_out인 경우의 순방향 점프에 대한 개략도.3 is a schematic diagram of a forward jump when addr_in <addr_out.

도 4는 addr_in>addr_out인 경우의 역방향 점프에 대한 개략도.4 is a schematic diagram of a backward jump when addr_in> addr_out.

도 5는 addr_in<addr_out인 경우의 역방향 점프에 대한 개략도.5 is a schematic diagram of a backward jump when addr_in <addr_out.

도 6은 섹터 ID에서의 점프의 경우에 입력-어드레스 및 출력-어드레스를 나타내는 도면.Fig. 6 shows the input-address and the output-address in case of jump in sector ID.

본 발명의 목적은, 불어날 수 있는 처리비용을 필요로 하면서 시스템의 성능을 상당히 약화시킬 메모리 내의 데이터 교체를 회피함으로써, 보다 적은 RAM을 필요로 하면서도 고성능을 보장하는 리드-솔로몬 디코더를 위한 방법 및 장치를 제공하는데 있다. 독립항에서 언급된 특징은 이러한 문제점을 해결한다. 종속항에서는 바람직한 실시예를 개시한다. 본 발명의 한 양상에 따라, 일예로 DVD 리드-솔로몬 디코더와 같은 리드-솔로몬 디코더 앞의 지능 버퍼를 위한 방법 및 장치가 제공되는데, 상기 지능 버퍼에서는 인입되는 동기-신호에 기초하여 데이터가 분석되고, 그 데이터는 인입하는 ECC-블록이 리드-솔로몬 디코더에 의해서 복구될 수 있는 한, 적절한 버퍼 위치에 버퍼링된다. ECC-블록이 정정될 수 없는 경우에는, 리드-솔로몬 디코더가 제 1 처리 단계를 취소시키기 위해서 리셋 신호를 획득한다. 어드레스 제어 블록 및 버퍼는 상기 지능 버퍼를 형성한다.SUMMARY OF THE INVENTION An object of the present invention is a method and apparatus for a Reed-Solomon decoder that guarantees high performance while requiring less RAM by avoiding data replacement in memory that would significantly reduce the performance of the system while requiring processing costs. To provide. The features mentioned in the independent claim solve this problem. The dependent claims disclose preferred embodiments. According to one aspect of the invention, there is provided a method and apparatus for an intelligent buffer in front of a Reed-Solomon decoder, such as a DVD Reed-Solomon decoder, in which data is analyzed based on incoming sync-signals. The data is buffered at the appropriate buffer location, as long as the incoming ECC-block can be recovered by the Reed-Solomon decoder. If the ECC-block cannot be corrected, the Reed-Solomon decoder obtains a reset signal to cancel the first processing step. An address control block and a buffer form the intelligent buffer.

RAM을 구비하지 않는 리드 솔로몬 디코더의 경우에, 즉 본 발명에 따른 소위 램부재 리드 솔로몬의 경우에, 프런트-엔드 회로는 완전한 인입 ECC-블록을 연속적인 데이터 스트림으로서 리드-솔로몬 디코더에 전송하기에 앞서 저장하기 위한 어떤 방법도 갖지 않는다. 어떠한 조치(precaution)도 없다면, 리드-솔로몬 디코더는 디코더가 정정할 수 없는 무질서한 많은 ECC-블록을 획득할 것이다. 이것은 완전한 회로의 열악한 성능을 유도한다. 본 발명에 따른 리드-솔로몬-디코더 앞의 지능 버퍼는 가능한 한, 데이터의 구조를 본래대로 유지하려 하고 작은 결함을 제거하며, 결함이 훼손된 데이터를 유발할 경우에는, 리드-솔로몬 블록과 마이크로 제어기가 훼손된 데이터에 대해서 통보를 받을 것이다. 사용되는 램부재 리드-솔로몬 블록이 스케일가능한 파라미터를 갖기 때문에, 리드-솔로몬 버퍼 인터페이스가 다른 상황에서도 유효하다. 데이터 및 동기 결핍의 분류는 다른 블록 코드에 대해서도 타당하다. 버퍼는 데이터 저장을 위한 작은 룸(room)이다. 버퍼는 데이터를 서로 교환하는 두 유닛 사이에 위치된다. 버퍼의 기능은, 다른 유닛이 데이터를 수신할 준비가 되지 않은 상황에 있어 한 유닛으로부터 오는 데이터를 일시적으로 저장하기 위한 룸을 제공하는 것이다. 버퍼는 잠시동안 이들 데이터를 보관한 후에, 수신측이 그 데이터들을 수신할 준비가 되자마자 그 데이터들을 전달한다. DVD-플레이어의 경우에, 일예로 획득부로부터 오는 데이터는 PLL의 경미한 결함을 보상하기 위해 리드-솔로몬 정정 블록에 전달될 수 있기 이전에 버퍼링되어야 한다. PLL은 위상 동기 루프의 약어이다. 이런 이유로, 획득부는 인입 HF-신호로부터의 섹터 식별 및 프레임 헤더를 디코딩하고, 그 정보를 데이터와 함께 버퍼부에 전송한다. 그러한 방식에 있어서, 버퍼는 일반적으로 리드 솔로몬 디코더의 앞에 반드시 존재하고, 그것은 본 발명에 따라서 유리하게 사용된다.In the case of a Reed Solomon decoder without RAM, i.e. in the case of a so-called RAM-free Reed Solomon according to the invention, the front-end circuit is adapted to transmit a complete incoming ECC-block as a continuous data stream to the Reed-Solomon decoder. There is no way to save earlier. If no precaution is taken, the Reed-Solomon decoder will acquire many chaotic ECC-blocks that the decoder cannot correct. This leads to poor performance of the complete circuit. The intelligent buffer in front of the Reed-Solomon-decoder according to the present invention attempts to keep the structure of the data intact, eliminates small defects, and if the defects cause corrupted data, the Reed-Solomon block and the microcontroller are corrupted. You will be notified about the data. Since the RAM member Reed-Solomon block used has scalable parameters, the Reed-Solomon buffer interface is effective in other situations. The classification of data and lack of motivation is also valid for other block codes. The buffer is a small room for data storage. The buffer is located between two units that exchange data with each other. The function of the buffer is to provide a room for temporarily storing data from one unit in situations where the other unit is not ready to receive data. The buffer holds these data for a while and then delivers them as soon as the receiver is ready to receive them. In the case of a DVD-player, for example, data coming from the acquirer must be buffered before it can be passed to the Reed-Solomon correction block to compensate for minor defects in the PLL. PLL is an acronym for phase locked loop. For this reason, the acquisition section decodes the sector identification and frame header from the incoming HF-signal and sends the information along with the data to the buffer section. In such a manner, the buffer is generally necessarily present in front of the Reed Solomon decoder, which is advantageously used according to the invention.

버퍼 블록은, 부적절한 프레임 길이가 리드-솔로몬을 손상시키는 것을 방지하기 위해서, 프레임 및 섹터 경계에서 데이터 스트림을 재동기시킬 수 있어야 한다. 정정가능하지 않은 점프의 경우에, 버퍼 블록은 리드-솔로몬 디코더의 현재 제 1 통과 내부/외부 정정을 중단시키고, 그 다음 ECC-블록 경계에서 재동기한다. 리드-솔로몬-버퍼 인터페이스는 물리적인 점프의 경우에 리셋되어야 한다. 향상된 실시예에 있어서, ECC-블록의 행을 처리하는 제 1 단계의 리드 솔로몬 정정을 위해서 지능 버퍼가 사용된다. 허용된 점프 영역에 관한 일부 제약만이 고려되어야 한다. 그러한 방식에 있어서, 유리하게도, 고성능을 가지면서도 보다 적은 RAM-메모리를필요로 하는 램부재 리드-솔로몬 디코더가 수행된다.The buffer block must be able to resynchronize the data stream at the frame and sector boundaries in order to prevent inappropriate frame lengths from damaging Reed-Solomon. In the case of a non-correctable jump, the buffer block stops the current first pass internal / external correction of the Reed-Solomon decoder and then resynchronizes at the ECC-block boundary. The Reed-Solomon-Buffer interface must be reset in case of a physical jump. In an improved embodiment, an intelligent buffer is used for Reed Solomon correction of the first stage of processing rows of ECC-blocks. Only some constraints on allowed jump areas should be considered. In that manner, a RAM-based Reed-Solomon decoder is advantageously performed that has high performance but requires less RAM-memory.

본 발명이 이제 첨부 도면을 참조하여 설명될 것이다.The invention will now be described with reference to the accompanying drawings.

도 1에서, 미도시된 램부재 리드 솔로몬 디코더 앞의 지능 버퍼(IBUF)의 기능을 설명하는데 필요한 다음의 세 부분이 도시되어 있다.In FIG. 1, the following three parts are shown to illustrate the function of the intelligent buffer IBUF in front of the RAM member Reed Solomon decoder, not shown.

- 제 1 부분은 인입 데이터의 클럭(byte_clk), 데이터 라인 상의 데이터(data_in), 및 동기 정보를 제공하는 획득 블록(ACQ)이다.The first part is an acquisition block (ACQ) that provides a clock (byte_clk) of incoming data, data (data_in) on the data line, and synchronization information.

- 제 2 부분은 획득 블록(ACQ)으로부터 제공되는 동기 신호로부터 어드레스 및 제어 신호를 생성하는 어드레스 제어 블록(ADC)으로서, 거기에는 데이터 라인(data_in) 상의 입력 데이터 스트림에 대한 어드레스와, 버퍼(BUF)로부터 리드-솔로몬 디코더로 전송되는 출력 데이터(data_out)를 위한제어-출력-신호(ctrl_out)의 어드레스가 존재한다.The second part is an address control block (ADC) which generates an address and a control signal from the synchronization signal provided from the acquisition block (ACQ), which includes an address for the input data stream on the data line (data_in) and a buffer (BUF). There is an address of a control-output-signal (ctrl_out) for output data (data_out) that is transmitted from Rep.

- 제 3 부분은 출력 데이터(data_out)와 데이터 라인 상의 인입 데이터(data_in)에 대한 독립적인 시간 구조를 처리하기 위해 이중 포트를 갖는 저장 어레이로서 구성된 버퍼(BUF)이다. 그것은 또한, 입력-데이터 스트림 및 출력-데이터 스트림이 적절하게 연결해제되는 경우에, IO-포트로 구성될 수 있다.The third part is a buffer BUF configured as a storage array with dual ports for processing independent time structures for output data (data_out) and incoming data (data_in) on data lines. It can also be configured as an IO-port if the input-data stream and the output-data stream are properly disconnected.

어드레스 제어 블록(ADC)과 버퍼(BUF)는 본 발명에 따른 소위 지능 버퍼(IBUF)를 형성한다. 다른 블록은 출력 데이터(data_out) 스트림을 위해 사용되는 독립 클럭(out_clk)을 생성하기 위한 생성기(clk_gen)를 나타낸다. 이 태스크(task)는 미도시된 리드-솔로몬 디코더의 부분을 나타낸다.The address control block ADC and the buffer BUF form a so-called intelligent buffer IBUF according to the present invention. The other block represents a generator (clk_gen) for generating an independent clock (out_clk) used for the output data (data_out) stream. This task represents part of the Reed-Solomon decoder, not shown.

도 1에 도시된 바와 같이, 생성기(clk_gen)는 독립 클럭(out_clk)을 제공하기 위해서 어드레스 제어 블록(ADC)과 버퍼(BUF)에 연결되고, 상기 독립 클럭(out_clk)은 버퍼(BUF)로부터 미도시된 리드 솔로몬 블록으로 데이터를 판독하는데 또한 사용된다. 인입 데이터(data-in)의 다른 클럭(byte_clk)은 획득-블록(ACQ)으로부터 유도되어 어드레스 제어 블록(ADC)에 인가되고, 아울러 AND-게이트(&)를 통해 버퍼(BUF)에 인가된다. 상기 AND-게이트(&)의 다른 입력단은 버퍼-입력-인에이블-신호(in_en)를 제공하는 어드레스 제어 블록(ADC)의 출력단에 연결되는데, 상기 버퍼-입력-인에이블-신호(in_en)는, 상기 AND-게이트(&)에 의해서 형성되어 버퍼(BUF)의 대응하는 입력단에 인가되는 마스크된 바이트 클럭 신호(byte_clk_msk)에 의해서 상기 AND-게이트(&)를 통해 버퍼(BUF)의 입력단을 인에이블시킨다. 데이터 라인(data_in)은 획득 블록(ACQ)의 대응하는 출력단을버퍼(BUF)의 대응하는 입력단과 연결하여, 데이터가 획득 블록에서 생성되었을 때 상기 데이터를 버퍼(BUF)에 입력시키기 위해 제공한다. 획득 블록(ACQ)과 어드레스 제어 블록(ADC)은 또한, 프레임 시작 신호(nxfr), 획득 블록(ACQ)에 의해 디코딩되어진 프레임 어드레스 신호(fr_addr), 획득 블록(ACQ)에 의해서 또한 디코딩되어진 섹터 식별자(SID), 그 다음 섹터 시작 신호(nxt_SID), 전달된 섹터 식별자(SID)가 획득 블록(ACQ)에 의해서 정확하게 디코딩되었다는 것을 알려주는 유효 섹터 식별자 신호(SID_valid), 및 심각한 광학상의 문제가 발생한 경우에 내부 마이크로 제어기에 의해서 요청되는 비동기적인 동작 중단을 위한 중단 플래그(stop_flag)가 존재할 때, 어드레스 제어블록(ADC)을 위한 수 개의 신호를 제공하기 위해서 서로 연결된다. 어드레스 제어 블록(ADC)은 버퍼(BUF)와 연결되어, 데이터 라인을 통해 인입 데이터(data_in)의 3 비트 신호인 ECC-시작, 섹터-시작 및 프레임-시작을 포함하는 제어-입력-신호(ctrl_in), 입력 데이터를 위한 버퍼 입력 어드레스 신호(addr_in), 출력 데이터(data_out)를 위한 버퍼 출력 어드레스 신호(addr_out), 및 버퍼(BUF)로부터 미도시된 리드 솔로몬 디코더로 데이터(data_out)를 판독하기 위한 출력 동작 인에이블 신호(out_en)를 버퍼(BUF)에 제공한다. 어드레스 제어 블록(ADC)은 부적법한 점프의 경우에 리드 솔로몬 디코더를 중지시키거나 리셋시키는 신호(RST_RS)를 또한 제공한다. 버퍼(BUF)는 리드 솔로몬 디코더에 제공되는 출력 데이터(data_out)의 3 비트 신호인 ECC-시작, 섹터-시작, 및 프레임-시작을 포함하는 제어-출력-신호(ctrl_out)를 제공한다.As shown in FIG. 1, the generator clk_gen is connected to an address control block ADC and a buffer BUF to provide an independent clock out_clk, and the independent clock out_clk is unloaded from the buffer BUF. It is also used to read data into the Reed Solomon block shown. Another clock byte_clk of incoming data (data-in) is derived from the acquisition-block (ACQ) and applied to the address control block (ADC), and also to the buffer (BUF) through the AND-gate (&). The other input of the AND-gate (&) is connected to the output of an address control block ADC which provides a buffer-input-enable signal in_en, which is the buffer-input-enable signal in_en. The input terminal of the buffer BUF is input through the AND-gate (&) by a masked byte clock signal byte_clk_msk, which is formed by the AND-gate (&) and applied to a corresponding input terminal of the buffer BUF. Enable it. The data line data_in connects the corresponding output terminal of the acquisition block ACQ with the corresponding input terminal of the buffer BUF to provide the data to the buffer BUF when the data is generated in the acquisition block. The acquisition block ACQ and the address control block ADC are also the frame start signal nxfr, the frame address signal fr_addr decoded by the acquisition block ACQ, and the sector identifier also decoded by the acquisition block ACQ. (SID), next sector start signal (nxt_SID), valid sector identifier signal (SID_valid) indicating that the transmitted sector identifier (SID) has been correctly decoded by the acquisition block (ACQ), and in case of serious optical problems When there is a stop flag (stop_flag) for asynchronous stop of operation requested by the internal micro-controller, it is connected to each other to provide several signals for the address control block (ADC). The address control block ADC is connected to the buffer BUF, and a control-input signal ctrl_in including ECC-start, sector-start and frame-start, which are three-bit signals of the incoming data data_in through the data line. ), A buffer input address signal addr_in for input data, a buffer output address signal addr_out for output data data_out, and a read data data_out from the buffer BUF to a Reed Solomon decoder (not shown). The output operation enable signal out_en is provided to the buffer BUF. The address control block ADC also provides a signal RST_RS to stop or reset the Reed Solomon decoder in case of an illegal jump. The buffer BUF provides a control-output-signal ctrl_out including ECC-start, sector-start, and frame-start, which are three-bit signals of the output data data_out provided to the Reed Solomon decoder.

도 1에 도시된 바와 같은 획득 블록(ACQ)은 동기를 위한 데이터 및 수 개의제어 신호를 추출해야 하는, 채널 IC로 지칭되는 채널 회로의 획득부를 나타낸다.Acquisition block (ACQ) as shown in Fig. 1 represents an acquisition portion of a channel circuit called a channel IC, in which data for synchronization and several control signals must be extracted.

일예로 미도시된 DVD 기기의 광학 부분으로부터 오는 비트 스트림으로부터, 이 블록은 데이터(data_in), 바이트 클럭(byte_clk), 프레임 어드레스(fr_addr), 및 섹터 식별자(SID)에 의해 식별되는 섹터 번호를 디코딩한다. 프레임 번호가 무질서한 경우에는, 장애를 나타내는 시퀀스가 획득 부분의 현재 버전에서와 같이 대체된다. 섹터 식별자(SID)의 한정된 디코딩은 프레임 어드레스 디코딩과는 상관없이 1-펄스와 동일한 유효 섹터 식별자 신호(SID_valid)에 의해 분류된다. 이 정보는, 비록 순서가 손상되었다 할 지라도, 프레임 어드레스를 0으로 재동기시키는데 사용된다.As an example, from a bit stream coming from the optical part of a DVD device, not shown, this block decodes the sector number identified by data (data_in), byte clock (byte_clk), frame address (fr_addr), and sector identifier (SID). do. If the frame number is disordered, the sequence representing the fault is replaced as in the current version of the acquisition part. The limited decoding of the sector identifier SID is classified by the valid sector identifier signal SID_valid equal to 1-pulse, regardless of the frame address decoding. This information is used to resynchronize the frame address to zero, even if the order is corrupted.

도 1에 도시된 바와 같은 어드레스 제어 블록(ADC)은 주요한 작업을 수행해야 한다. 버퍼(BUF)를 위한 어드레스를 생성하기 위해서 다음과 같은 세 단계가 사용된다:The address control block (ADC) as shown in FIG. 1 must perform major tasks. Three steps are used to generate the address for the buffer BUF:

제 1 단계 : 예상 프레임 어드레스(fr_addr) 및 섹터 식별자(SID)를 생성하는 단계. 획득 블록(ACQ)으로부터의 동기 신호에 이어서, 예상 프레임 어드레스(fr_addr) 및 섹터 식별자(SID)를 위한 카운터가 어드레스 제어 블록(ADC)에 설정되고, 결함이 발생한 경우에 현재의 입력에 상관없이 증가된다. 점프 트랙을 따라가기 위해서, 내부의 예상 ECC-카운터가 또한 사용되는데, 그것은 이상적인 경우에는 인입 데이터의 ECC 블록을 따라야 한다. 이러한 내부 카운터는, 섹터 번호가 0을 넘었을 때, 증가되거나 감소된다. 만약 획득 블록(ACQ)이 완전하지 않은 프레임 어드레스(fr_addr)와 한정된 섹터 식별자(SID)만을 제공하고 어떠한 ECC 번호도 제공하지 않는다면, 예상 어드레스에서의 가장 유력한 변화가 점프가 발생할 때 가정된다. 만약 완전한 섹터 식별자(SID)가 사용된다면, 최상위 비트가 ECC-카운터를 또한 동기시킬 수 있다.First step: generating an expected frame address fr_addr and a sector identifier SID. Following the synchronization signal from the acquisition block ACQ, a counter for the expected frame address fr_addr and the sector identifier SID is set in the address control block ADC and incremented regardless of the current input in case of a fault. do. To follow the jump track, an internal expected ECC-counter is also used, which ideally should follow the ECC block of incoming data. This internal counter is incremented or decremented when the sector number exceeds zero. If the acquisition block ACQ provides only incomplete frame address fr_addr and a limited sector identifier SID and no ECC number, the most likely change in the expected address is assumed when a jump occurs. If a complete sector identifier (SID) is used, the most significant bit may also synchronize the ECC-counter.

점프를 처리하는데 방법에 있어 규칙은 다음과 같다:The rules for how to handle jumps are:

프레임 또는 섹터의 파괴가 있는 경우에는, 현재 위치로부터 프레임/섹터-길이의 절반 보다 더 긴 거리로 점프하지 않는다.If there is a destruction of a frame or sector, it does not jump more than half the frame / sector-length from its current position.

다음의 경우는 n이 적절하게 선택된 정수인 경우에 표준 길이에 대한 현재 길이의 비율을 평가하기 위해서 가능하다:The following cases are possible to evaluate the ratio of the current length to the standard length when n is a properly chosen integer:

A. 0) 프레임 길이가 적합함, 즉 길이/표준길이=1A. 0) The frame length is suitable, ie length / standard length = 1

1) 프레임 길이가 너무 길고, n < 길이/표준길이 ≤ n+1/21) The frame length is too long, n <length / standard length ≤ n + 1/2

2) 프레임 길이가 너무 길고, n+1/2 < 길이/표준길이 ≤n+12) The frame length is too long, n + 1/2 <length / standard length ≤ n + 1

3) 프레임 길이가 너무 짧고, 0 < 길이/표준길이 ≤1/23) Frame length is too short, 0 <length / standard length ≤ 1/2

4) 프레임 길이가 너무 짧고, 1/2 < 길이/표준길이 < 14) Frame length is too short, 1/2 <length / standard length <1

B. 0) 프레임 어드레스가 적합함B. 0) Frame address is appropriate

1) 프레임 어드레스가 부적합함1) The frame address is invalid

C. 0) 섹터 식별자(SID)가 적합함C. 0) Sector identifier (SID) is appropriate

1) 현재의 ECC-블록에서, 섹터 식별자(SID)가 너무 작음1) In the current ECC-block, the sector identifier (SID) is too small

2) 그 다음 ECC-블록에서, 섹터 식별자(SID)가 너무 작음2) In the next ECC-block, the sector identifier (SID) is too small

3) 현재의 ECC-블록에서, 섹터 식별자(SID)가 너무 큼3) In the current ECC-block, the sector identifier (SID) is too large

4) 이전의 ECC-블록에서, 섹터 식별자(SID)가 너무 큼4) In the previous ECC-block, the sector identifier (SID) is too large

D. 0) 섹터가 적합함D. 0) Sectors are good

1) 섹터가 너무 짧음1) Sector too short

2) 섹터가 너무 김.2) The sector is too long.

만약 획득 블록(ACQ)이 제시간에 프레임 어드레스(fr_addr)를 찾을 수 없다면, 상기 획득 블록(ACQ)은 1을 삽입한다. 만약 그 다음의 유효 프레임 어드레스가 제 1 절반 프레임 길이 동안에 발견되지 않는다면, 어떠한 프레임 어드레스 표시자도 전송되지 않는다. 이것은, 1/2의 공칭 길이와 관련하여 A에서 상이한 경우가 이루어진 이유이다. 이러한 조합들 중 일부는, 조합의 수가 작은 비트를 감소시키도록 하기 위해서 발생하지 않을 수 있다.If the acquisition block ACQ cannot find the frame address fr_addr in time, the acquisition block ACQ inserts one. If the next valid frame address is not found during the first half frame length, no frame address indicator is sent. This is the reason why different cases have been made in A with respect to a nominal length of 1/2. Some of these combinations may not occur in order to reduce the number of bits with a small number of combinations.

제 2 단계 : 버퍼(BUF)에 데이터를 기록하기 위해 버퍼-입력-어드레스 신호(addr_in)를 생성.Step 2: Generate a buffer-input-address signal addr_in to write data to the buffer BUF.

제 1 단계의 ECC-블록, 섹터 식별자(SID), 및 프레임 어드레스(fr_addr)에 대한 예상 어드레스에 기초하여, 입력 어드레스를 위한 원형 카운터는 버퍼 크기의 범위 상에서 증가된다. 점프의 경우에는, 상이한 방법이, 아래에서 상세하게 설명되어질 바와 같이, 점프 방향, 점프의 크기, 및 출력 스트림의 현재 어드레스에 따라 수행되어야 한다.Based on the expected address for the first stage ECC-block, sector identifier (SID), and frame address fr_addr, the circular counter for the input address is incremented over a range of buffer sizes. In the case of a jump, different methods must be performed according to the jump direction, the size of the jump, and the current address of the output stream, as will be described in detail below.

상기 처리는 점프를 수행할 수 있어야 하거나, 어드레스가 도달될 때까지 입력을 중단시킬 수 있어야 하거나, 새로운 ECC-블록이 시작할 때까지 총체적인 처리를 재동기시킬 수 있어야 한다.The process must be able to perform a jump, be able to interrupt the input until an address is reached, or be able to resynchronize the overall process until a new ECC-block starts.

제 3 단계 : 버퍼(BUF)로부터 미도시된 리드-솔로몬 디코더로 출력데이터(data_out)를 판독하기 위한 출력 어드레스를 생성.Step 3: Generating an output address for reading the output data data_out from the buffer BUF to the Reed-Solomon decoder, not shown.

적합한 어드레싱을 보장하기 위해서, 독립적인 출력 클럭(out_clk)이 입력 클럭(byte_clk) 보다 더 빠르다는 것이 가정된다. 데이터 라인(data_in)으로부터의 입력 신호와 출력 데이터(data_out)는 인에이블-신호에 의해서 제어되는 대응하는 스트림을 형성하고, 출력 어드레스(addr_out)는 일정 거리를 두면서 입력 어드레스(addr_in)를 따를 것이다. 실시예에서는, 버퍼 크기의 절반인 거리가 사용되고 있다.To ensure proper addressing, it is assumed that the independent output clock out_clk is faster than the input clock byte_clk. The input signal from the data line data_in and the output data data_out form a corresponding stream controlled by the enable-signal, and the output address addr_out will follow the input address addr_in at a distance. In an embodiment, a distance that is half the buffer size is used.

처음의 재기동화 경우에 있어서, 버퍼 출력 어드레스 신호(addr_out)에 대응하는 출력 어드레스가 0으로 설정되고, 이 경우에는, 입력 어드레스(addr_in)와 출력 어드레스(addr_out) 사이의 거리가 디폴트 거리보다 작을 때, 출력 어드레스(addr_out) 처리는 그 디폴트 거리에 도달할 때까지 기다린다. 만약, 점프로 인해서, 입력 어드레스(addr_in)가 출력 어드레스에 대한 거리를 계속해서 증가시킨다면, 디폴트 거리에 또 다시 도달할 때까지 addr_out이 최대의 출력 클럭(out_clk) 속도로 생성된다.In the first restart case, when the output address corresponding to the buffer output address signal addr_out is set to 0, in this case, when the distance between the input address addr_in and the output address addr_out is smaller than the default distance. The output address addr_out process waits until its default distance is reached. If, due to the jump, the input address addr_in continues to increase the distance to the output address, addr_out is generated at the maximum output clock out_clk speed until the default distance is again reached.

점프를 적절하게 처리하기 위해서, 이러한 처리는 최대 속도로의 어드레스 생성을 수행하고 아래에서 설명될 바와 같이 0으로 재동기하기 위해서 즉시 또는 정해진 어드레스에서 동작을 중단시킬 수 있어야 한다.In order to properly handle the jump, this process must be able to interrupt the operation either immediately or at a given address to perform address generation at full speed and resynchronize to zero as described below.

도 1에 도시된 바와 같은 버퍼(BUF)는 비동기적으로 기록 및 판독될 수 있기 위해서 이중 포트를 구비하는 규정된 크기의 RAM이거나, 대안적으로는 입력-요청과 출력-요청이 동시에 일어나는 것을 방지하는 제어 논리부 및 하나의 IO-포트로 구성되고, 이것은 두 개의 클럭{클럭(byte_clk) 및 클럭(out_clk)}이 서로에 대해서 완벽하게 독립적이기 때문에 필요하다. 입력과 출력 둘 모두는 더 용이하게 클럭 처리를 수행하기 위해서 디스에이블될 수 있다. 동기-데이터가 획득 블록(ACQ)에서 획득되어 어드레스 제어 블록(ADC)으로 전달될 때, 상기 동기 데이터는 리드 솔로몬 블록과 그 다음에 오는 RAM 어드레스 생성기 블록으로 전달되어야 하고, 따라서, 상기 동기 데이터는 또한 저장되어야 하고 출력 데이터(data_out)와 동기적으로 전송되어야 한다.The buffer BUF as shown in FIG. 1 is a defined size RAM with dual ports in order to be able to be written and read asynchronously, or alternatively prevents input- and output-requests from occurring simultaneously. It consists of a control logic and one IO-port, which is necessary because the two clocks (clock_clk) and clock (out_clk) are completely independent of each other. Both inputs and outputs can be disabled to make clocking easier. When sync-data is acquired in an acquiring block (ACQ) and passed to the address control block (ADC), the sync data must be transferred to the Reed Solomon block followed by the RAM address generator block, so that the sync data is It must also be stored and transmitted synchronously with the output data (data_out).

생성기(clk_gen)는 출력 데이터(data_out)를 위한 독립 클럭(out_clk)의 생성기이고, 상기 출력 데이터(data_out)는 인입 데이터, 즉 클럭(byte_clk)의 최대 주파수 보다 더 높은 주파수를 가져야 한다. 독립 클럭(out_clk)의 생성은 적절한 인자에 의한 구현에 있어 사용되는 시스템 클럭을 분할함으로써 이루어질 수 있다.The generator clk_gen is a generator of the independent clock out_clk for the output data data_out, and the output data data_out should have a frequency higher than the maximum frequency of the incoming data, that is, the clock byte_clk. The generation of the independent clock out_clk can be achieved by dividing the system clock used in the implementation by appropriate factors.

점프 처리:Jump processing:

위에서 기재된 어드레스 점프는 데이터 섹션 경계에 대해서 카테고리로 분류되었다. 버퍼 어드레싱에 가장 양호한 전략을 찾기 위해서, 위에서와는 다른 분류가 사용되어야 하는데, 그 이유는 점프가The address jumps described above were categorized into data section boundaries. In order to find the best strategy for buffer addressing, a different classification than above should be used, because

·현재의 입력 및 출력 버퍼 어드레스의 관련성,The relevance of the current input and output buffer addresses,

·점프가 버퍼 데이터의 완전성(integrity)을 손상시켰다는 것을 의미하는 점프 오프셋,A jump offset, meaning that the jump has compromised the integrity of the buffer data,

·현재의 ECC-블록이 여하튼 정정될 수 있는지에 대한 요청에 따라 리드-솔로몬 디코더에 잠시동안 전송된 데이터의 양,The amount of data transmitted for a while to the Reed-Solomon decoder in response to a request of whether the current ECC-block can be corrected anyway,

·그 다음의 동기화가 얼마가 빨리 발생하는가How soon the next synchronization occurs

에 대한 관점 하에서 고려되어야 하기 때문이다.This is because it must be considered from the viewpoint of.

순방향 점프(FWDJ)는 도 2 및 도 3에 따라 처리되고, 역방향 점프(BKWJ)는 도 4 및 도 5에 따라 처리된다.Forward jump FWDJ is processed according to FIGS. 2 and 3, and reverse jump BKWJ is processed according to FIGS. 4 and 5.

이들 도면은 ECC-경계에 대한 마커(ECC0, ECC1, ECC2)를 갖는 데이터 축(1)과, 영역(5)에 표기된 시작 및 종료 어드레스를 가지면서 상기 데이터 축(1)과 평행한 버퍼 축(2)을 나타낸다. 화살표는 출력(6) 하에서의 버퍼 범위와 버퍼 부분을 나타내는데, 상기 버퍼 부분은 입력(7)을 위해서 비어 있다. 또한, 점프가 요청(9)되기 이전의 입력 어드레스에 대한 스냅숏(snapshot)과, 입력 어드레스(8)에 대해 공칭 거리에 위치한 출력 어드레스가 표시되어 있다.These figures show a data axis 1 with markers ECC0, ECC1, ECC2 for ECC-boundary, and a buffer axis parallel to the data axis 1 with a start and end address indicated in area 5. 2) is shown. Arrows indicate the buffer range and buffer portion under output 6, which is empty for input 7. Also shown are a snapshot of the input address before the jump is requested 9 and an output address located at a nominal distance to the input address 8.

도 2 및 도 3은, 버퍼-입력-어드레스(addr_in)가 도 2에 도시된 바와 같이 버퍼-출력-어드레스(addr_out) 보다 더 높은 상황 하에서와, 버퍼-입력-어드레스(addr_in)가 도 3에 도시된 바와 같이 버퍼-출력-어드레스(addr_out) 보다 더 낮은 상황 하에서 요청된 순방향 점프(FWDJ)에 대한 상황을 도시하고 있다. 요청된 제 1 점프(3)는 임의의 영역을 목표로 할 것이고, 이는 제 1 점프 보다 더 긴 제 2 점프(4)와는 대조적으로 저장된 데이터의 상술된 완전성을 손상시키지 않을 것이다. 그러므로, 후자의 경우는 수행되지 않을 것이지만, 출력은 그 다음의 요청된 어드레스가 금지된 범위(6)의 밖에 있을 때까지 가속되어야 하거나, 완전한 ECC-블록이 드롭(drop)되어야 한다. 상기 결정은 ECC-블록을 완성하는데 있어서의 진행과정 및 점프 거리에 의존한다.2 and 3 show that under a situation where the buffer-input-addr_in is higher than the buffer-output-addr_out as shown in FIG. 2, the buffer-input-addr_in is in FIG. As shown, the situation for the requested forward jump FWDJ is lower than the buffer-output-address addr_out. The requested first jump 3 will be aimed at any area, which will not compromise the above described integrity of the stored data as opposed to the second jump 4 which is longer than the first jump. Therefore, the latter case will not be performed, but the output must be accelerated until the next requested address is outside the forbidden range 6, or the complete ECC-block must be dropped. The decision depends on the progress and jump distance in completing the ECC-block.

도 4 및 도 5는, 버퍼-입력-어드레스(addr_in)가 도 4에 도시된 바와 같이 버퍼-출력-어드레스(addr_out) 보다 더 높은 상황 하에서와, 버퍼-입력-어드레스(addr_in)가 도 5에 도시된 바와 같이 버퍼-출력-어드레스(addr_out) 보다 더 낮은 상황 하에서의 역방향 점프(BKWJ) 요청에 대한 구성을 도시하고 있다. 더 짧은 제 1 점프(3)는 허용된 범위를 향하고 입력을 지속시킬 수 있지만, 입력-어드레스와 출력-어드레스 사이의 거리가 공칭적인 거리가 될 때까지는 출력을 중단하여야 한다. 더 긴 제 2 점프(4)의 경우에, 버퍼-입력-어드레스 신호(addr_in)의 요청된 그 다음 입력 어드레스는 버퍼(BUF)로부터 아직 전송되지 않는 영역을 향하고, 만약에 마지막 데이터가 훼손되었다면, 출력은 중단되고 출력 데이터의 영역은 겹침기록된다. 다른 전략은 어드레스 신호(addr_in)에 있는 버퍼의 입력-어드레스가 허용된 영역을 향할 때까지 버퍼(BUF)의 입력 및 출력을 중단시키는 것이다. 두 전략 모두에 있어서, 어쩌면 훼손된 데이터(10)는 이미 전송된다.4 and 5 show that under the situation where the buffer-input-addr_addr is higher than the buffer-output-addr_out as shown in FIG. 4, the buffer-input-addr_addr_in is in FIG. As shown, the configuration for a reverse jump (BKWJ) request under a situation lower than the buffer-output-address (addr_out) is shown. The shorter first jump 3 can continue the input towards the permitted range, but must stop the output until the distance between the input-address and the output-address is nominal. In the case of the longer second jump 4, the next requested input address of the buffer-input-address signal addr_in is directed towards the area not yet transmitted from the buffer BUF, if the last data has been corrupted, The output is stopped and the area of the output data is overwritten. Another strategy is to stop the input and output of the buffer BUF until the input-address of the buffer in the address signal addr_in is directed to the allowed area. In both strategies, possibly corrupted data 10 is already transmitted.

도 6은 입력에 있어서 몇 번의 점프에 대한 실시예의 작용과 출력 어드레스의 작용을 도시하고 있다. 도 6은 대부분의 점프가 평활해진다는 것을 증명한다.6 illustrates the operation of the embodiment and the output address for several jumps in input. 6 demonstrates that most jumps are smoothed.

도 6은 시간 축(t)에 대한 버퍼(BUF)의 어드레스 범위(AR)를 나타낸다. 어드레스 신호(addr_in)에 있는 버퍼의 입력 어드레스는 분명하게 평활해지는 JMP와 같은 점프에도 불구하고 일정 거리를 두고 따라오는 버퍼 출력 어드레스 신호(addr_out)의 출력 어드레스를 야기한다.6 shows the address range AR of the buffer BUF on the time axis t. The input address of the buffer in the address signal addr_in causes the output address of the buffer output address signal addr_out to follow at a certain distance despite a jump such as JMP that is clearly smoothed.

물리적인 점프의 경우에는, 현재 판독되는 섹터의 어떠한 사용도 이루어지지않을 것이다. 이 경우에, 중단 플래그(stop_flag)가 도 1에 도시된 바와 같이 활성된다. 이것은, 현재 판독되는 섹터가 완료되었는지 또는 그렇지 않은지 여부에 상관없다. 어드레스-처리는 그러한 경우에는 완벽하게 재시작될 것이고, 신호(RST_RS)가 리드 솔로몬 동작을 리셋시키기 위해 생성된다.In the case of a physical jump, no use of the sector currently read will be made. In this case, the stop flag stop_flag is activated as shown in FIG. This does not matter whether the sector currently being read is complete or not. The address-process will be completely restarted in that case, and the signal RST_RS is generated to reset the Reed Solomon operation.

제 2의 미도시된 실시예에서는, 버퍼(BUF)가 리드 솔로몬 디코더의 제 1 단계를 위한 정정 버퍼로서 동시에 사용된다. 앞서 설명된 실시예와의 유일한 차이점은, 제 1 실시예에서의 버퍼-출력-어드레스 신호(addr_out)의 단일 출력 어드레스가In the second, not shown embodiment, the buffer BUF is used simultaneously as a correction buffer for the first stage of the Reed Solomon decoder. The only difference from the above-described embodiment is that a single output address of the buffer-output-address signal addr_out in the first embodiment is

·버퍼(BUF)에 저장된 데이터를 사용하여 리드-솔로몬 디코더의 제 1 단계 내부 정정을 계산 및 수행하고,Calculate and perform a first stage internal correction of the Reed-Solomon decoder using the data stored in the buffer (BUF),

·제 1 외부 정정의 신드롬을 계산하며,Calculate the syndrome of the first external correction,

·내부 모드에서 정정된 데이터를 출력하는데 있어Outputting corrected data in internal mode

전용적으로 사용되는 세 개의 어드레스로 분할된다는 것을 고려하여야 하기 때문에, 점프에 대해 더욱 제한된 범위가 존재한다는 점이다.There is a more limited range for jumps, as it must be considered that it is divided into three addresses that are dedicated.

내부 및 외부 정정이란 용어는 리드 솔로몬 디코더 내에서의 알려진 정정 모드에 관련된다.The terms internal and external corrections relate to known correction modes within the Reed Solomon decoder.

그러므로, 버퍼-출력- 어드레스 신호(addr_out)의 출력 어드레스에 대해 앞서 실시예에서 이루어진 결정은 이제 이러한 어드레스에 대한 최대의 제한 상에서 이루어져야 한다. 구현은 리드 솔로몬 디코더의 요구에 따라 더욱 제한적인 시간 구조를 필요로 한다.Therefore, the decision made in the previous embodiment regarding the output address of the buffer-output-address signal addr_out must now be made on the maximum limit for this address. The implementation requires a more restrictive time structure as required by the Reed Solomon decoder.

그러한 방법에 있어서, 리드-솔로몬 디코더는 보다 적은 필수 RAM과 완전한 회로의 고성능을 유도하는 지능 버퍼(IBUF)를 통해 무질서한 ECC 블록을 획득하지 않은 것이다. 본 실시예에 따른 지능 버퍼(IBUF)는 리드 솔로몬 디코더의 제 1 통과 정정 저장부로서 또한 사용된다. 본 명세서에서 설명된 방법 및 장치는 단순히 예시적인 것으로서 제공되고, 당업자는 본 발명의 범위 내에서 본 발명의 다른 실시예를 구현할 수 있다. 본 발명에 따른 지능 버퍼(IBUF)는 여러 종류의 에러 정정 시스템에 수월하게 사용될 수 있다는 점에 있어서 특히 유리하다.In such a method, the Reed-Solomon decoder has not acquired a disordered ECC block through an intelligent buffer (IBUF) that leads to less essential RAM and complete circuit high performance. The intelligent buffer IBUF according to this embodiment is also used as the first pass correction storage of the Reed Solomon decoder. The methods and apparatus described herein are provided merely as illustrative, and one skilled in the art can implement other embodiments of the present invention within the scope of the present invention. The intelligent buffer (IBUF) according to the present invention is particularly advantageous in that it can be easily used in various types of error correction systems.

상술된 바와 같이, 본 발명은 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치 및 방법, 즉, 보다 적은 RAM을 필요로 하면서 높은 성능을 보장하는 리드-솔로몬 디코더 앞의 지능 버퍼에 대한 방법 및 장치에 이용가능하다.As described above, the present invention provides an apparatus and method for preparing data for a Reed-Solomon decoder, i.e., a method and apparatus for an intelligent buffer in front of a Reed-Solomon decoder that requires less RAM and ensures high performance. Available to

Claims (23)

리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치로서,An apparatus for preparing data for a Reed-Solomon decoder, 상기 리드-솔로몬 디코더 앞의 지능 버퍼(IBUF : intelligent buffer)를 포함하고, 상기 지능 버퍼(IBUF)에서는,An intelligent buffer (IBUF) in front of the Reed-Solomon decoder, wherein in the intelligent buffer (IBUF), 수신된 데이터가 인입하는 동기-신호에 기초하여 분석되고, 그 데이터는, 인입 ECC-블록(ECC)이 상기 리드-솔로몬 디코더에 의해서 복구될 수 있는 한 적절한 어드레스에서 버퍼(BUF)에 버퍼링되고,The received data is analyzed based on the incoming sync-signal, which data is buffered in a buffer BUF at an appropriate address as long as the incoming ECC-block (ECC) can be recovered by the Reed-Solomon decoder, ECC-블록(ECC)이 정정될 수 없는 경우에는, 상기 ECC-블록(ECC)을 처리하는 제 1 단계를 취소시키기 위해서 리셋 신호(RST_RS)를 제공하는,If the ECC-block (ECC) cannot be corrected, providing a reset signal (RST_RS) to cancel the first step of processing the ECC-block (ECC), 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.Apparatus for preparing data for the Reed-Solomon decoder. 제 1항에 있어서, 상기 버퍼(BUF)는, 데이터 라인(data_in)을 통해 획득 블록(ACQ)에 연결될 뿐만 아니라, ECC 블록 길이(lgth)를 갖는 완전성에 관한 섹터 식별자(SID)와 프레임 어드레스 신호(fr_addr)를 평가하기 위해서 어드레스 제어 블록(ADC)에 연결되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.2. The frame address signal of claim 1, wherein the buffer BUF is connected to an acquisition block ACQ through a data line data_in, as well as a sector identifier SID and a frame address signal for integrity having an ECC block length lgth. an apparatus for preparing data for a Reed-Solomon decoder, connected to an address control block (ADC) to evaluate (fr_addr). 제 1항에 있어서, 상기 지능 버퍼(IBUF)는 상기 버퍼(BUF)에 공급되는 데이터 라인(data_in) 상의 인입 데이터의 최대 주파수 보다 더 높은 주파수를 갖는 독립 클럭(out_clk)에 의해서 제어되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.The read-out circuit of claim 1, wherein the intelligent buffer IBUF is controlled by an independent clock out_clk having a frequency higher than a maximum frequency of incoming data on a data line data_in supplied to the buffer BUF. Device for preparing data for Solomon decoder. 제 1항에 있어서, 상기 지능 버퍼(IBUF)는 DVD-플레이어의 리드 솔로몬 디코더의 앞에서 일반적으로 사용되는 저장 매체인, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.2. The apparatus of claim 1, wherein the intelligent buffer (IBUF) is a storage medium generally used in front of a Reed Solomon decoder of a DVD-player. 제 1항에 있어서, 상기 지능 버퍼(IBUF)는 상기 리드-솔로몬 디코더의 현재 제 1 통과 내부/외부 정정을 중단시킬 수 있고, 그 다음 ECC 블록 경계(ECC1)에서 재동기하는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.2. The Reed-Solomon decoder of claim 1, wherein the intelligent buffer IBUF can stop the current first pass internal / external correction of the Reed-Solomon decoder and then resynchronize at the ECC block boundary ECC1. Device for preparing data for the. 제 1항에 있어서, 상기 지능 버퍼(IBUF)는 ECC-블록의 행을 처리하는 제 1 단계의 리드 솔로몬 정정을 위해 사용되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.2. The apparatus of claim 1, wherein the intelligent buffer (IBUF) is used for Reed Solomon correction of the first step of processing a row of ECC-blocks. 제 1항에 있어서, 상기 버퍼(BUF)는 비동기적으로 기록 및 판독될 수 있기 위해서 출력 데이터(data_out)와 데이터 라인 상의 인입 데이터(data_in)를 위한 독립적인 시간 구조를 처리하도록 이중 포트를 구비하는 저장 어레이로서 구성되거나, 대안적으로는 입력 요청과 출력 요청이 동시에 일어나는 것을 방지하는 제어 논리부와 하나의 IO-포트로 구성되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.10. The apparatus of claim 1, wherein the buffer BUF has dual ports to process independent time structures for output data data_out and incoming data data_in on data lines so that they can be written and read asynchronously. An apparatus for preparing data for a Reed-Solomon decoder, which is configured as a storage array or, alternatively, consists of one IO-port and a control logic to prevent input and output requests from occurring simultaneously. 제 2항에 있어서, 인입 데이터(data_in)의 클럭(byte_clk)은, 상기 획득-블록(ACQ)으로부터 유도되어 어드레스 제어 블록(ADC)에 인가되고, AND-게이트([']&['])를 통해, 상기 어드레스 제어 블록(ADC)에 의해서 제공되는 버퍼-입력-인에이블-신호(in_en)에 의해서 상기 버퍼(BUF)에 또한 공급되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.The clock byte_clk of the incoming data data_in is derived from the acquisition-block ACQ and applied to the address control block ADC, and the AND-gate (['] & [']). And is also supplied to the buffer (BUF) by a buffer-input-enable signal (in_en) provided by the address control block (ADC). 제 2항에 있어서, 예상 프레임 어드레스(fr_addr) 및 섹터 식별자(SID)를 위한 카운터가 상기 획득 블록(ACQ)으로부터의 동기 신호를 따르고, 결함이 있는 경우에는 현재 입력에 상관없이 증가되거나 감소되어지는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 장치.3. A counter according to claim 2, wherein the counters for the expected frame address fr_addr and the sector identifier SID follow the synchronization signal from the acquisition block ACQ and are incremented or decremented regardless of the current input in case of a fault. , Apparatus for preparing data for the Reed-Solomon decoder. 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법으로서,A method for preparing data for a Reed-Solomon decoder, 인입 동기 신호에 기초하여 데이터를 분석하는 단계와,Analyzing the data based on the incoming sync signal; 상기 리드-솔로몬 디코더가 인입 ECC-블록(ECC)을 복구할 수 있는 한, 어드레스 제어 블록(ADC)에 의해 제공되는 데이터를 버퍼(BUF)의 적절한 어드레스에 버퍼링하는 단계와,Buffering the data provided by the address control block (ADC) to an appropriate address in the buffer BUF as long as the Reed-Solomon decoder can recover the incoming ECC-block (ECC), 상기 ECC-블록(ECC)이 정정될 수 없는 경우에, 상기 ECC-블록(ECC)을 처리하는 제 1 처리 단계를 취소하기 위해서 리셋 신호(RST_RS)를 제공하는 단계를In case the ECC-block (ECC) cannot be corrected, providing a reset signal RST_RS to cancel the first processing step of processing the ECC-block (ECC). 포함하는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.And a method for preparing data for a Reed-Solomon decoder. 제 10항에 있어서, 상기 데이터 분석 단계는, 단지 불완전한 프레임 어드레스(fr_addr) 및 한정된 섹터 식별자(SID)가 검출되고 어떠한 ECC-블록 번호도 검출되지 않을 때 예상 어드레스에서의 점프나 가장 가능한 변화가 가정되는 획득 블록(ACQ)에 의해 디코딩되는 프레임 어드레스(fr_addr), 섹터 식별자(SID) 및 ECC-블록 번호를 포함하는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.The data analysis step of claim 10, wherein the data analysis step assumes a jump or the most likely change in the expected address when only an incomplete frame address (fr_addr) and a limited sector identifier (SID) are detected and no ECC-block number is detected. And a frame address (fr_addr), a sector identifier (SID) and an ECC-block number to be decoded by an acquisition block (ACQ). 제 11항에 있어서, 만약 완전한 섹터 식별자(SID)가 이용가능하다면, 섹터 식별자(SID)의 최상위 비트가 상기 어드레스 제어 블록(ADC) 내의 내부 카운터를 동기시키기 위해서 사용되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.12. The method according to claim 11, wherein if the complete sector identifier (SID) is available, the most significant bit of the sector identifier (SID) is used to synchronize an internal counter in the address control block (ADC). How to prepare your data. 제 10항에 있어서, 프레임 또는 섹터가 손상되는 경우에 있어서 연속적인 데이터의 점프는, 만약 거리가 미리 결정된 거리 보다 더 길지 않은 경우에, ECC-블록(ECC)의 완전성에 영향을 주지 않는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.11. The read of claim 10, wherein the jumping of continuous data in the event that the frame or sector is damaged does not affect the integrity of the ECC-block (ECC) if the distance is not longer than the predetermined distance. -Method for preparing data for the Solomon decoder. 제 13항에 있어서, 상기 거리는 자유 버퍼 길이의 절반 보다 더 길지 않은, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.15. The method of claim 13, wherein the distance is no longer than half the free buffer length. 제 13항에 있어서, 만약 그 다음 유효 프레임 어드레스가 제 1 절반 프레임 길이 동안에 발견된다면, 어떠한 프레임 어드레스 표시자도 제공되지 않는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.15. The method of claim 13, wherein if no next valid frame address is found during the first half frame length, no frame address indicator is provided. 제 13항에 있어서, 어드레스 제어 블록(ADC) 내의 입력 어드레스를 위한 원형 카운터는 ECC-블록(ECC), 섹터 식별자(SID) 및 프레임 어드레스(fr_addr)에 대한 예상 어드레스에 기초하여 버퍼(BUF)의 버퍼 크기 범위 상에서 증가/감소되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.The buffer counter of claim 13, wherein the circular counter for the input address in the address control block ADC is based on the expected address for the ECC-block ECC, the sector identifier SID, and the frame address fr_addr. A method for preparing data for a Reed-Solomon decoder, which is increased / decreased over a buffer size range. 제 13항에 있어서, 처음의 재동기화 경우에 있어서, 버퍼 출력 어드레스 신호(addr_out)에 대응하는 출력 어드레스는 제로로 설정되고, 이 경우에, 입력 어드레스(addr_in)와 출력 어드레스(addr_out) 사이의 거리가 디폴트 거리 보다 더 작을 때는, 상기 디폴트 거리에 이를 때까지 출력 어드레스(addr_out) 처리가 대기하고, 입력 어드레스(addr_in)의 점프로 인해서 거리가 증가한다면, 상기 디폴트 거리에 또 다시 이를 때까지 출력 어드레스(addr_out)가 최대 출력 클럭(out_clk) 속도로 생성되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.14. The output address corresponding to the buffer output address signal addr_out is set to zero in the first resynchronization case, and in this case, the distance between the input address addr_in and the output address addr_out. Is smaller than the default distance, the output address addr_out processing waits until the default distance is reached, and if the distance increases due to the jump of the input address addr_in, the output address until the default distance is reached again. A method for preparing data for a Reed-Solomon decoder, wherein (addr_out) is generated at the maximum output clock (out_clk) rate. 제 13항에 있어서, 순방향 점프(FWDJ)의 경우에, 만약 점프(3)가 길이(lgth)를 갖는 버퍼의 비블록된 영역을 목표로 한다면, 새로운 저장은 이미 저장된 데이터의 완전성을 손상시키지 않고, 만약, 그와 대조적으로, 길이(lgth)를 갖는 버퍼의 블록된 저장 영역에서의 점프(4)가 요청된다면, 상기 점프는 수행되지 않을 것이지만, 그 다음에 요청되는 입력 어드레스가 금지된 범위(6) 밖에 있을 때까지 가속되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.14. The storage of claim 13, wherein in the case of forward jump FWDJ, if jump 3 targets an unblocked area of the buffer having a length, new storage does not impair the integrity of the already stored data. If, in contrast, a jump 4 in a blocked storage area of a buffer having a length is requested, the jump will not be performed, but then the requested input address is in a prohibited range ( 6) A method for preparing data for a Reed-Solomon decoder, which is accelerated until it is outside. 제 13항에 있어서, 역방향 점프(BKWJ)의 경우에, 만약 점프(3)가 길이(lgth)를 갖는 버퍼의 비블록된 영역을 목표로 한다면, 새로운 저장은 저장된 데이터의 완전성을 손상시키지 않을 것이고, 입력은 계속될 수 있지만 입력-어드레스와 출력-어드레스 사이의 거리가 공칭 거리가 될 때까지 출력을 중단시켜야 하고, 만약, 그와 대조적으로, 길이(lgth)를 갖는 버퍼의 블록된 저장 영역에서의 점프(4)가 요청된다면, 버퍼-입력-어드레스 신호(addr_in)의 입력 어드레스는 갱신되지만, 상기 버퍼-입력-어드레스 신호(addr_in)가 허용된 버퍼 영역을 향할 때까지 데이터는 저장되지 않는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.14. The storage of claim 13, in the case of a reverse jump BKWJ, if the jump 3 targets an unblocked area of the buffer having a length, the new store will not compromise the integrity of the stored data. The input can continue, but the output must be stopped until the distance between the input-address and the output-address is nominal and, in contrast, in the blocked storage area of the buffer with length If a jump 4 of is requested, the input address of the buffer-input-address signal addr_in is updated, but no data is stored until the buffer-input-address signal addr_in is directed to the allowed buffer region. Method for preparing data for a Reed-Solomon decoder. 제 10항에 있어서, 플레이어의 픽업이 물리적인 점프를 하는 경우에는, 현재 판독되는 섹터의 사용은 이루어지지 않고, 현재 판독되는 섹터가 완료되었는지 여부에 상관없이 중단 플래그(stop_flag)가 활성되고, 어드레스-처리는 완벽하게 재시작되며, 상기 리드 솔로몬 동작을 리셋시키기 위해서 신호(RST_RS)가 생성되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.The stop flag stop_flag is activated regardless of whether or not the currently read sector is completed. The process is completely restarted and a signal (RST_RS) is generated to reset the Reed Solomon operation. 제 10항에 있어서, 예상 프레임 어드레스(fr_addr)와 섹터 식별자(SID)를 생성하는 단계와, ECC-블록(ECC), 섹터 식별자(SID) 및 프레임 어드레스(fr_addr)에 대한 상기 예상 어드레스에 기초하여 버퍼(BUF)에 데이터를 기록하기 위해 버퍼 입력 어드레스 신호(addr_in)를 생성하는 단계와, 상기 버퍼(BUF)로부터 상기 리드-솔로몬 디코더로 출력 데이터(data_out)를 판독하기 위해 상기 출력 어드레스를 생성하는 단계를 포함하는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.11. The method of claim 10, further comprising: generating an expected frame address fr_addr and a sector identifier SID, and based on the expected address for an ECC-block ECC, sector identifier SID, and frame address fr_addr. Generating a buffer input address signal addr_in to write data to a buffer BUF; and generating the output address to read output data data_out from the buffer BUF to the Reed-Solomon decoder. And preparing data for the Reed-Solomon decoder. 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법으로서,A method for preparing data for a Reed-Solomon decoder, 인입 ECC-블록(ECC)이 상기 리드 솔로몬 디코더에 의해서 복구될 수 있는 한, 버퍼(BUF) 내의 적절한 어드레스에 인입 데이터를 버퍼링하는 단계를 포함하는, 리드-솔로몬 디코더를 위한 데이터를 준비하기 위한 방법.Buffering incoming data at the appropriate address in the buffer BUF as long as an incoming ECC-block (ECC) can be recovered by the Reed Solomon decoder. . 제 22항에 있어서, 상기 버퍼(BUF)의 버퍼 출력 어드레스 신호(addr_out)의 단일 출력 어드레스는,The method of claim 22, wherein the single output address of the buffer output address signal addr_out of the buffer BUF is 상기 버퍼(BUF)에 저장된 데이터를 사용하여 리드-솔로몬 디코더의 제 1 단계 내부 정정을 계산 및 수행하고,Calculate and perform a first stage internal correction of the Reed-Solomon decoder using the data stored in the buffer BUF, 제 1 외부 정정의 신드롬(syndrome)을 계산하며,Calculate a syndrome of the first external correction, 상기 내부 정정 모드에서 정정된 데이터를 출력하는데 있어 전용적으로 사용되는 세 개의 어드레스로 확장되는, 리드-솔로몬 디코더를 위한 데이터를 준비하기위한 방법.A method for preparing data for a Reed-Solomon decoder, extended to three addresses dedicated for outputting corrected data in the internal correction mode.
KR1020027006589A 1999-12-15 2000-12-12 Preparation of data for a reed-solomon decoder KR100754905B1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP99125014 1999-12-15
EP99125014.3 1999-12-15

Publications (2)

Publication Number Publication Date
KR20020059777A true KR20020059777A (en) 2002-07-13
KR100754905B1 KR100754905B1 (en) 2007-09-04

Family

ID=8239619

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020027006589A KR100754905B1 (en) 1999-12-15 2000-12-12 Preparation of data for a reed-solomon decoder

Country Status (8)

Country Link
EP (1) EP1256175A1 (en)
JP (1) JP2003517238A (en)
KR (1) KR100754905B1 (en)
CN (1) CN1233097C (en)
AU (1) AU778986B2 (en)
MX (1) MXPA02005110A (en)
PL (1) PL355602A1 (en)
WO (1) WO2001045271A1 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100920736B1 (en) * 2002-10-08 2009-10-07 삼성전자주식회사 Single carrier transmission system capable of reducing signal distortion and a method therefore
CN101873143B (en) * 2010-06-01 2013-03-27 福建新大陆电脑股份有限公司 Syndrome computing circuit in RS (Reed-Solomon) error correcting code decoder and computing method thereof

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5610983A (en) * 1994-09-30 1997-03-11 Thomson Consumer Electronics, Inc. Apparatus for detecting a synchronization component in a satellite transmission system receiver
US5627935A (en) * 1994-11-11 1997-05-06 Samsung Electronics Co., Ltd. Error-correction-code coding & decoding procedures for the recording & reproduction of digital video data
KR0166268B1 (en) * 1995-11-30 1999-03-20 배순훈 Device for generating block synchronizing signal for reed-solomon decoder

Also Published As

Publication number Publication date
AU778986B2 (en) 2004-12-23
KR100754905B1 (en) 2007-09-04
EP1256175A1 (en) 2002-11-13
JP2003517238A (en) 2003-05-20
AU2364801A (en) 2001-06-25
CN1409896A (en) 2003-04-09
WO2001045271A1 (en) 2001-06-21
CN1233097C (en) 2005-12-21
PL355602A1 (en) 2004-05-04
MXPA02005110A (en) 2003-01-28

Similar Documents

Publication Publication Date Title
KR100430657B1 (en) Signal processor for correcting and detecting errors
US5247523A (en) Code error correction apparatus
US6092231A (en) Circuit and method for rapid checking of error correction codes using cyclic redundancy check
US7549104B2 (en) Digital signal processing method and apparatus performing variable number of error correction repetitions
US8214719B1 (en) Long latency protocol for hard disk controller interface
US5604646A (en) Data error correcting method and signal processing unit for disk accessing apparatus
KR20020029925A (en) Methods and apparatus for correcting soft errors in digital data
JPS631626B2 (en)
US7047476B2 (en) Code error corrector
US6061824A (en) Pipelined error correction for minimizing disk re-reading in hard drives
KR100754905B1 (en) Preparation of data for a reed-solomon decoder
US7085990B2 (en) Preparation of data for a Reed-Solomon decoder
KR100494252B1 (en) Information reproduction apparatus
JP3570324B2 (en) Storage device, storage system using the same, and error occurrence notification method used for the same
EP1090462B1 (en) Circuit and method for rapid checking of error correction codes using cyclic redundancy check
US6690630B1 (en) Compact disc decoder and method for correcting address errors in header data based on an input error flag
US6321351B1 (en) Method and apparatus for detecting errors in DVD data
US6775721B1 (en) Method and system for handling a data stream from optical media utilizing automatic link sector detection
US20060218468A1 (en) Memory initialization device, memory initialization method, and error correction device
US6587973B1 (en) Method and apparatus for implementing fault tolerant logic in a storage system
JP3649766B2 (en) How to receive teletext data items
JPH04310135A (en) Pointer control logic device and method of pointer control
JP2001006298A (en) Digital signal processing circuit and disk reproducing device
JP2805780B2 (en) Magnetic disk drive
US6693867B1 (en) Method and system for window realignment using pipeline and sync correction to correct data frame boundaries

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
LAPS Lapse due to unpaid annual fee