[Not Applicable]
[Not Applicable]
[Not Applicable]
In a communication system, a data bitstream is transmitted at a particular bit rate. The data bitstream transitions from high to low, or vice versa, responsive to a clock signal at the transmitter.
However, the receiver operates on a receiver clock signal that has a different period, and phase relationship with the transmitter clock signal. Accordingly, sampling the data signal at the rate of the receiver clock signal is not suitable.
Additionally, the ratio of the receiver clock signal to the transmitter clock signal is likely to be a mixed number (number comprising the sum of an integer and a fraction). As a result, sampling the data signal after a fixed number of receiver clock signal edges may also be unsuitable.
Further limitations and disadvantages of conventional and traditional approaches will become apparent to one of skill in the art, through comparison of such systems with embodiments presented in the remainder of the present application with references to the drawings.
Presented herein are systems and methods for clock rate determination.
In one embodiment, there is presented a method for sampling a bitstream. The method comprises sampling a transmitted signal at a rate corresponding to a receiver clock signal, and measuring an average number of consecutive samples that have a same state selected from a first state and a second state.
In another embodiment, there is presented a method of sampling a bistream. The method comprises measuring a ratio between a receiver clock signal and a transmitter clock signal, wherein the ratio comprises a sum of an integer N and a fraction f; sampling the bitstream after N edges of the receiver clock signal; adding the fraction f to an accumulated value; adding the accumulated value to the integer N and the fraction; sampling the data bistream after N edges, if a sum of the fraction and the accumulated value are less than one; and sampling the data bitstream after N+1 edges, if the sum of the fraction and the accumulated value are more than one.
In another embodiment, there is presented a system for sampling a bitstream. The system comprises a first circuit and a second circuit. The first circuit samples a transmitted signal at a rate corresponding to a receiver clock signal. The second circuit measures an average number of consecutive samples that have a same state selected from a first state and a second state.
In another embodiment, there is presented a system for sampling a bitstream. The system comprises a first circuit, a second circuit, an accumulator register, and an adder. The first circuit measures a ratio between a receiver clock signal and a transmitter clock signal, wherein the ratio comprises a sum of an integer N and a fraction f. The second circuit samples the bitstream after N edges of the receiver clock signal. The accumulator register stores an accumulated value. The adder adds the fraction f to the accumulated value and adds the accumulated value to the integer N and the fraction. If a sum of the fraction and the accumulated total are less than one, the second circuit samples the data bitstream after N edges. If the sum of the fraction and the accumulated total are more than one, the second circuit samples the data bitstream after N+1 edges.
Further limitations and disadvantages of conventional and traditional approaches will become apparent to one of skill in the art, through comparison of such systems with embodiments presented in the remainder of the present application with references to the drawings.
Referring now to
The digital data signal can include a serial data bitstream and a transmitted at transmitter clock signal rate. The serial data bitstream comprises data bits that are transmitted at a particular bit rate. The transmitter signal transitions from a high state to a low state, and from the low state to the high state, at the bit rate.
The receiving terminal 110 is driven by a receiver clock signal. The receiver clock signal has a different rate and phase relationship from the transmitter clock signal. Accordingly, the receiving terminal 110 extracts the rate of the transceiver clock signal and samples the data signal at the rate of the transceiver clock signal.
Referring now to
The receiver 205 synchronizes the serial data bitstream with the receiver clock and checks for data transition. The period of synchronized serial data bitstream transition depends on the sample rate (the ration of the decoding frequency and two times the encoding frequency) programmed. Potentially, the data transition period can be more than two receiver clocks. Depending on the sample rate, the jittered accumulator based clock is derived from the serial data bitstream. The serial data bitstream is sampled with the derived clock and in synchronization with the receiver clock. The receiver 205 works at a sampling rate as low as 2. The BMC data along with non-BMC preamble data are decoded from the serial data bitstream, resulting in the decoded BMC data, BMCp_data. The decoded BMC data BMCp_data is a sequence of half cells collected serially. Two half cells constitute one data bit. The receiver 205 also generates a strobe signal BMCp_strobe to indicate the validity of the decoded BMC data BMCp_data.
The decoded BMC data machine 215 seeks a synchronization preamble pattern. Once a synchronization pattern is achieved, the decoded BMC data machine 215 outputs a corresponding code indicating the particular synchronization preamble pattern detected.
The bit extractor data path 220 module puts the status bit from each sub-frame data word into a shift register at every sub-frame data word strobe goes high. If 32 such status bits are collected, then status bits interrupt is generated. The bit extractor data path 220 outputs preamble Pc and Pd data values. Pc, Pd are valid when active high Pre_cd_Int interrupt is generated. If the programmed data type and bit stream number matches with the data type and bit stream number which are parsed from the bit stream data, then the following data pay load is parsed and outputted. From each sub-frame data 16-bits of valid non-PCM encoded or uncompressed PCM are collected. Since the Main FIFO width is 32, to match the width of the Main FIFO, two sets of such 16-bits data's are combined and sent out as a 32-bit output data from the SPDIF module. This 16-bit to 32-bit conversion is done in this module. The 32-bit output data is swizzled before being sent out if the swizzle input signal status is high, or else output data is sent directly.
Bit extractor data path state machine 225 seeks sync word1 Pa (F872h) and the consecutive sync word2 Pb (4E1Fh). If Pa and Pb sync are achieved, then the data burst sync status signal goes high. After the data burst sync status signal goes high, burst info Pc and code length Pd are parsed and valid Pc, Pd values are indicated by the interrupt generated from the bit extractor data path 220. Always valid payload data burst is followed by these four fields (Pa, Pb, Pc & Pd). If the programmed data type and bit stream number matches with the parsed data type and bit stream number from the audio stream, then payload data is parsed. The total number of valid sub-frames in the payload data burst is found from Pd. If stuff zero input signal status is high then at the end of the payload data burst one 32-bit (all zero bits) is outputted from SPDIF module. Since different data type like Dolby AC-3 and MPEG streams have fixed repetition rates, the stuffed zero data will be transmitted at the end of the payload data burst. This stuffed data is parsed and thrown till the next Pa, Pb, Pc and Pd fields are found.
The receiver 205 extracts the rate of the transmitter clock signal by sampling the transmitter signal at the rate of the receiver clock a statistically significant number of times, such as, for example, 512 times. The receiver 205 calculates the average number of receiver clock cycles that the transmitter signal is in the same state, high or low. The average number of receiver clock cycles that the transmitter signal is in the same state is the data rate of the serial data bitstream.
Referring now to
The receiver 205 includes a receiver clock signal Rx CLK that also alternates between a high state and a low state over a period of time, PRx. The receiver clock signal Rx CLK may have a different rate and phase relationship with the transmitter signal Tx.
The receiver 205 extracts the rate of the transmitter clock signal by sampling the transmitter signal at the rate of the receiver clock Rx CLK a statistically significant number of times, such as, for example, 512 times. The receiver clock Rx CLK is usually faster than the transmitter clock Tx CLK, by a factor that is the sum of an integer N, and a fraction f. When sampling at the receiver clock Rx CLK rate, either N−1, N, or N+1 consecutive samples will be at one state, followed by either N−1, N, or N+1 samples at the other state. The factor (N+f) can be approximated by averaging the number of consecutive samples that are at a particular state over a statistically significant time period.
Referring now to
If the sample taken during 410 is the same as a previous sample taken during a previous rising or falling edge of the receiver clock signal Rx CLK, the value n is incremented at 420. After incrementing the value n, 410 is repeated.
If the sample taken during 410 is different from a previous sample taken during a previous rising or falling edge of the receiver clock signal Rx CLK, the value n is added to an accumulator at 425. At 430, the value m is incremented, and 405 is repeated.
The foregoing, 405-430, is repeated for a statistically significant number of samples (determination 435). After the statistically significant number of samples are taken, the accumulated value, Σn is divided by m (440), resulting in an integer N and a fraction f. The quotient during 440 is an approximation of the ratio between the receiver clock signal Rx CLK and the transmitter clock signal Tx CLK.
The serial data bitstream is sampled with the receiver clock signal Rx CLK, every N or N+1 periods PRx. The serial data bitstream can be sampled every N periods PRx, wherein after each sampling, the fractional portion is accumulated. When the accumulation of the fractional portions exceeds one, the serial data bitstream is sampled after N+1 periods, and one is subtracted from the accumulation of the fractional portions.
Referring now to
The adder 505 adds the contents of the accumulator register 510 and N+f. The accumulator register 510 stores the fractional portion of the sum, while the down counter register 515 stores the integer portion of the sum. At each receiver clock signal Rx CLK rising edge, the down counter register 515 decrements. When the down counter 515 decrements, the receiver 205 generates a data strobe signal, Strb_BMCp, to the decoded BMC data path 210. Responsive to the Strb_BMCp signal, the decoded BMC data path 210 samples the serial data bitstream, BMCp_data.
When the receiver 205 generates the data strobe signal, Strb_BMCp, the adder 505 again adds the contents of the accumulator register 510 to N+f. Initially, the accumulator register 510 stores a zero value. However, after the first iteration, the accumulator register 510 stores f. After the second iteration, the adder 505 adds N+f to the contents of the accumulator register 510, f, resulting in N+f+f. The integer portion of N+f+f is either N or N+1, while the fractional portion is either f+f, or f+f−1.
Referring now to
At 625, the receiver 205 waits for an edge of the receiver clock signal Rx CLK. At each edge of the receiver clock signal Rx CLK, the down counter register 515 decrements (630). The foregoing 625-630, is repeated until the down counter is zero at 635. When the down counter register 515 reaches zero, the receiver 205 transmits a strobe signal at 640. The strobe signal causes the decoded BMC data path 210 to sample (645) the serial data bitstream.
The methods and systems described herein may be implemented as a board level product, as a single chip, application specific integrated circuit (ASIC), or within varying levels of the decoder system and/or integrated with other portions of the system as separate components.
The degree of integration of the decoder system will primarily be determined by speed and cost considerations. Because of the sophisticated nature of modern processors, it is possible to utilize a commercially available processor, which may be implemented external to an ASIC implementation.
Alternatively, if the processor is available as an ASIC core or logic block, then a commercially available processor can be implemented as part of an ASIC device wherein certain operations are implemented in firmware.
While the invention has been described with reference to certain embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the invention.
In addition, many modifications may be made to adapt a particular situation or material to the teachings of the invention without departing from its scope. Therefore, it is intended that the invention not be limited to the particular embodiment(s) disclosed, but that the invention will include all embodiments falling within the scope of the appended claims.