[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO2006003417A1 - Baud rate detection - Google Patents

Baud rate detection Download PDF

Info

Publication number
WO2006003417A1
WO2006003417A1 PCT/GB2005/002596 GB2005002596W WO2006003417A1 WO 2006003417 A1 WO2006003417 A1 WO 2006003417A1 GB 2005002596 W GB2005002596 W GB 2005002596W WO 2006003417 A1 WO2006003417 A1 WO 2006003417A1
Authority
WO
WIPO (PCT)
Prior art keywords
stream
rate
assigning
run
symbol
Prior art date
Application number
PCT/GB2005/002596
Other languages
French (fr)
Inventor
Richard Neil Hunt
Original Assignee
Ttpcom Limited
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 Ttpcom Limited filed Critical Ttpcom Limited
Priority to US11/629,986 priority Critical patent/US8139696B2/en
Priority to EP05756937A priority patent/EP1771986A1/en
Publication of WO2006003417A1 publication Critical patent/WO2006003417A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L25/00Baseband systems
    • H04L25/02Details ; arrangements for supplying electrical power along data transmission lines
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L25/00Baseband systems
    • H04L25/02Details ; arrangements for supplying electrical power along data transmission lines
    • H04L25/0262Arrangements for detecting the data rate of an incoming signal

Definitions

  • the invention relates to methods of, and apparatus for, characterising a data stream whose properties can vary from time to time.
  • UART universal asynchronous receiver/transmitter
  • An RS232 link interconnects a DTE (data terminal equipment) with a data circuit terminating equipment (DCE).
  • the DTE is the entity that is sending data into the link and the DCE is the entity that is receiving data from the link.
  • the speed and transmission settings at each end of an RS232 communications link between a DTE and a DCE have to be set to the same values and this configuration process can lead to difficulties for a user. This is especially the case where one end of an RS232 link, usually the DCE, is implemented on a simple consumer device, such as a mobile telephone, where the adjustment of the relevant communications settings is often an unfamiliar process requiring the user to access complex menus with the result that the configuration task is often done incorrectly.
  • a DCE Rather than have a user manually configure the communications settings of an RS232 link, it is possible to arrange for a DCE to adapt itself to the communications settings of a DTE with which it is to form an RS232 link. This requires a DCE to analyse the data stream received from a DTE, which stream consists of a sequence of positive and negative voltage pulses that represent binary symbols. The width of these pulses depends upon the transmission speed of the RS232 link and the number and arrangement of the symbols depends on the parity and other settings of the RS232 link. Perhaps one of the simplest ways to discriminate the transmission speed of a data stream from a DTE is for a DCE to use a timer to measure the width of the pulses in the data stream.
  • Such a timer would need a clock having a frequency several times higher than the maximum baud rate expected in the RS232 link. It can be difficult to implement such a clock without using specialised hardware and the use of such hardware is undesirable in the context of devices such as mobile telephones where it is preferred to implement functions in software so that they can be performed by a standard microprocessor chip. Implementing such a clock in software would lead to a significant real-time load on the host processor as the clock would involve a periodic processor interrupt at the clock frequency, where for each interrupt the processor would need to perform several instructions.
  • the invention relates to a method of characterising a data stream of binary symbols, the method comprising sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, identifying the shortest continuous run of samples having the same logic level and assigning a data rate to the stream on the basis that the identified run is one symbol in length.
  • the invention also consists in apparatus for characterising a data stream of binary symbols, the apparatus comprising means for sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, means for identifying the shortest continuous run of samples having the same logic level and means for assigning a data rate to the stream on the basis that the identified run is one symbol in length.
  • the invention provides a method of determining the baud rate of an RS232-format data stream, the method comprising sampling the stream at a predetermined rate, identifying the shortest continuous run of samples having the same logic level and assigning a baud rate to the stream on the basis that the identified run is one baud in length.
  • the invention also relates to apparatus for carrying out such a method.
  • the invention also encompasses a method of characterising an RS232-format data stream comprising a series of characters each packaged in a frame, the method comprising sampling the stream at a predetermined rate, identifying the shortest continuous run of samples having the same logic level, assigning a baud rate to the stream on the basis that the identified run is one baud in length, recovering one or more frames from the stream on the basis of the assigned baud rate and determining the parity of one or more recovered frames in order to estimate whether or not characters are being transmitted with parity bits.
  • the invention also relates to apparatus for carrying out such a method.
  • a set of symbol length ranges are provided, each range having a nominal data rate, and the symbol length given by the identified run is compared with the ranges such that the nominal data rate of the range into which the identified run falls is the data rate that is assigned to the data stream.
  • the data rate that is assigned to the data stream is the reciprocal of the duration of the identified run.
  • the symbols in the data stream may be organised into successive frames, in which case it may be possible to calculate the parity of at least one frame of the stream in order to make a determination about the frame structure.
  • an assessment of frame structure is based on the assessment of the parities of several frames in order to improve the likelihood that the determination that is made about the frame structure is correct.
  • DMA direct memory access
  • the invention uses such i/o hardware to sample the data stream under investigation.
  • the predetermined rate of the sampling operation is at least double the highest expected data rate of the stream.
  • the invention is used to determine the baud rates and, optionally, the parity settings used in data signals sent to mobile telephones through an RS232 link.
  • the invention can also be implemented as a program for causing data processing apparatus to perform the data stream analysis techniques of the invention.
  • Figure 1 is a block diagram illustrating an RS232 link between a PC and a mobile telephone
  • Figure 2 illustrates the wave form of a typical ASCII character received asynchronously over an RS232 to link.
  • a PC 2 is shown connected to a mobile telephone 4 via an RS232 link 10.
  • the structure of the telephone 4 is presented in simplified form in Figure 1, including only those elements that are necessary for describing the operation of the present embodiment of the invention.
  • the RS232 link 10 connects the PC 2 to a UART 20 within the telephone 4.
  • the data line 8 of the RS232 link is shown extending between the PC 2 and the UART 20.
  • Data signals travelling between the PC 2 and the UART 20 10 have the general wave form shown in Figure 2, in which a positive voltage level V, typically between 8 and 14 volts, represents a logical 0 and a nominally equally negative voltage level represents a logical 1.
  • the wave form shown in Figure 2 represents a single ASCII eight bit character being transferred as a group often pulses, where:
  • the first pulse 11 is a start bit, which is a logical 0, signalling the start of the character
  • a parity bit 13 is added to complete the payload section and force the parity of the payload section 12 to even or odd to conform with the parity setting of the transmission; • a stop bit of logical 1 is appended to the payload section 12 to indicate the end of the group of pulses defining the character (the stop bit essentially defines the minimum inter-character gap, although other values of inter-character gap are permissible, such as 1.5 and 2 bauds); and
  • each pulse is of the same duration, indicated 15, this duration being the reciprocal of the baud rate.
  • the PC 2 is configured to send data through the RS232 link 10 at a certain baud rate and with a certain parity setting and the UART 20 must be configured to match these settings if the data sent from the PC is to be received correctly be the telephone 4.
  • the UART 20 is configured and controlled by a general purpose microprocessor 24 in the telephone 4.
  • a memory resource within the telephone includes an auto-detect software module 9 that can be run by the processor 24 to discriminate the baud rate and parity setting that are being used by the PC 2 so that the user of the telephone 4 does not have to make these settings manually.
  • the processor executes the auto-detect component 9 following a reported error in the incoming data stream (e.g.
  • the telephone 4 includes, in addition to the UART 20, a programmable serial input/output circuit 22 and the auto-detect module 9 is arranged to use this circuit to analyse data travelling to the telephone 4 on the data line 8.
  • the auto-detect component 9 configures the i/o circuit 22 to sample the data line 8, as indicated by notional path 3.
  • the baud rate used by the PC 2 is selected from a standard range of rates, which in this example are 4,800, 9,600, 19,200, 57,600, 115,200 and 230,400Hz and the auto-detect component 9 configures the i/o circuit 22 to sample the data line 8 at twice the maximum baud rate that can be used by the PC 2, i.e. at 460,800Hz.
  • the auto-detect component 9 is arranged to cause the i/o circuit 22 to co-ordinate the capture of samples to commence with the start bit on the data line 8 that follows the error that triggered the processor 24 into executing the auto-detect component.
  • the auto-detect component 9 causes the i/o circuit 22 to capture a train of samples that is sufficient to capture an entire character, i.e. ten pulses, at the slowest baud rate that is to be detected. Given that the sampling rate of the i/o circuit 22 is set to 460,800Hz and the slowest baud rate that can be used by the PC 2 is 4,800Hz, the captured train of samples is to be at least 960 samples long. This sampling process occurs in parallel with the normal data communication activities of the UART 20, which continues to interpret the signal arriving at the telephone 4 on the data line 8 at the current baud rate and parity settings until a decision to change either or both of the settings is made by the auto-detect component 9.
  • the auto-detect component 9 configures the i/o circuit 22 to write the captured sample train directly into a memory resource within the telephone, bypassing the processor 24. In this way, the auto-detect component 9 can cause a train of samples to be captured for baud rate and parity analysis without impacting greatly on the processing load of the processor 24. This is advantageous since the processor 24 is likely to be engaged in other processing activities that need to be completed in real-time.
  • the auto-detect component 9 scans the train to determine the shortest run of samples that share the same logical state. The length of the run so identified is then assumed to correspond to the period of a single baud. As all RS232 command queries start with the characters "A" and "T”, this assumption is likely to be valid ("A” is 0010000011 and "T” is 0010101001 - including start and stop bits).
  • the auto-detect component 9 then translates the minimum run length into a baud rate for the data stream arriving at the telephone 4 through the RS232 link by comparing the minimum run length with a look-up table.
  • a look-up table means that the baud rate of the arriving data stream can be determined rapidly without having to perform computations. Also, the use of a look-up table allows significant tolerances between the baud rate of the PC 2 and that of the UART 20 to be accommodated.
  • the minimum run length determined by the auto-detect component 9 from the sample train is compared with the run length ranges listed in the left-hand column of the table.
  • the nominal baud rate in the row of the table that holds the run length range containing the measured minimum run length is then allocated to the data stream arriving on the data line 8 ofthe RS232 1ink lO.
  • an actual baud rate can be deduced by calculation by taking the reciprocal of the period of time covered by the minimum run length scanned in the sample train acquired by the auto-detect component 9.
  • a baud rate could be assigned by processing the minimum run length through a software decision tree.
  • the incoming bits on the data line can, if desired, be reconstructed. For example, if the auto-detect component 9 samples the incoming data stream at a rate of 460,800 Hz, then a received character "T" transmitted at a rate of 460,800 Hz.
  • the auto-detect component 9 will reduce the above signal train to a binary sequence of:
  • this recovered payload section contains only three symbols of logical 1, it has odd parity.
  • the auto-detect component 9 can therefore conclude that this payload section contains either an eight bit character without a parity bit or a seven bit character with a parity bit that has been set to give the payload section odd parity. Therefore, the auto- detect component 9 needs to analyse several successive recovered payload sections in order to make a determination about the parity setting of the incoming data stream with a degree of confidence.
  • the auto-detect component can conclude that the arriving data stream contains seven bit characters with accompanying parity bits that have been set to give their payload sections odd parity; otherwise, the auto-detect component could conclude that the incoming data stream consists of payload sections containing eight bit characters with no accompanying parity bits.
  • the auto-detect component 9 Once the auto-detect component 9 has determined the baud rate and, optionally, the parity setting of the data stream arriving via data line 8, the auto-detect component causes the processor 24 to impose these settings on the UART 20 which henceforth employs them in the interpretation of the incoming data stream. In the event that one or both of the baud rate and the parity setting change again or have been incorrectly estimated by the auto- detect component 9, the auto-detect component is triggered into performing another round of the baud rate and parity setting estimation process.

Landscapes

  • Engineering & Computer Science (AREA)
  • Power Engineering (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Communication Control (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Abstract

A method is provided of characterising a data stream of binary symbols, the method comprising sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, identifying the shortest continuous run of samples having the same logic level and assigning a symbol rate to the stream on the basis that the identified run is one symbol in length.

Description

BAUD RATE DETECTION
The invention relates to methods of, and apparatus for, characterising a data stream whose properties can vary from time to time.
It is common practice to provide a mobile telephone with a UART (universal asynchronous receiver/transmitter) for exchanging data with an external device such as a PC, over an RS232 link. The advantages of including a UART in a mobile telephone are widely understood. For example, a PC can use a mobile telephone as an "external modem" for sending and receiving data over the wireless network to which the telephone belongs by connecting to the telephone by means of an RS232 link.
An RS232 link interconnects a DTE (data terminal equipment) with a data circuit terminating equipment (DCE). The DTE is the entity that is sending data into the link and the DCE is the entity that is receiving data from the link. The speed and transmission settings at each end of an RS232 communications link between a DTE and a DCE have to be set to the same values and this configuration process can lead to difficulties for a user. This is especially the case where one end of an RS232 link, usually the DCE, is implemented on a simple consumer device, such as a mobile telephone, where the adjustment of the relevant communications settings is often an unfamiliar process requiring the user to access complex menus with the result that the configuration task is often done incorrectly.
Rather than have a user manually configure the communications settings of an RS232 link, it is possible to arrange for a DCE to adapt itself to the communications settings of a DTE with which it is to form an RS232 link. This requires a DCE to analyse the data stream received from a DTE, which stream consists of a sequence of positive and negative voltage pulses that represent binary symbols. The width of these pulses depends upon the transmission speed of the RS232 link and the number and arrangement of the symbols depends on the parity and other settings of the RS232 link. Perhaps one of the simplest ways to discriminate the transmission speed of a data stream from a DTE is for a DCE to use a timer to measure the width of the pulses in the data stream. However, such a timer would need a clock having a frequency several times higher than the maximum baud rate expected in the RS232 link. It can be difficult to implement such a clock without using specialised hardware and the use of such hardware is undesirable in the context of devices such as mobile telephones where it is preferred to implement functions in software so that they can be performed by a standard microprocessor chip. Implementing such a clock in software would lead to a significant real-time load on the host processor as the clock would involve a periodic processor interrupt at the clock frequency, where for each interrupt the processor would need to perform several instructions.
According to one aspect, the invention relates to a method of characterising a data stream of binary symbols, the method comprising sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, identifying the shortest continuous run of samples having the same logic level and assigning a data rate to the stream on the basis that the identified run is one symbol in length.
The invention also consists in apparatus for characterising a data stream of binary symbols, the apparatus comprising means for sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, means for identifying the shortest continuous run of samples having the same logic level and means for assigning a data rate to the stream on the basis that the identified run is one symbol in length.
From one particular view point, the invention provides a method of determining the baud rate of an RS232-format data stream, the method comprising sampling the stream at a predetermined rate, identifying the shortest continuous run of samples having the same logic level and assigning a baud rate to the stream on the basis that the identified run is one baud in length. The invention also relates to apparatus for carrying out such a method.
The invention also encompasses a method of characterising an RS232-format data stream comprising a series of characters each packaged in a frame, the method comprising sampling the stream at a predetermined rate, identifying the shortest continuous run of samples having the same logic level, assigning a baud rate to the stream on the basis that the identified run is one baud in length, recovering one or more frames from the stream on the basis of the assigned baud rate and determining the parity of one or more recovered frames in order to estimate whether or not characters are being transmitted with parity bits. The invention also relates to apparatus for carrying out such a method.
In a preferred embodiment, a set of symbol length ranges are provided, each range having a nominal data rate, and the symbol length given by the identified run is compared with the ranges such that the nominal data rate of the range into which the identified run falls is the data rate that is assigned to the data stream. In an alternative embodiment, the data rate that is assigned to the data stream is the reciprocal of the duration of the identified run.
The symbols in the data stream may be organised into successive frames, in which case it may be possible to calculate the parity of at least one frame of the stream in order to make a determination about the frame structure. Preferably, such an assessment of frame structure is based on the assessment of the parities of several frames in order to improve the likelihood that the determination that is made about the frame structure is correct.
It is common for base band processor integrated circuits for mobile phones to incorporate general serial input/output hardware, not adapted specifically for RS232, which allows the clocking of serial data into a shift register at a rate which can be programmed; and the contents of the serial shift register to be loaded into processor memory, often by a direct memory access (DMA) process which does not impose a large software overhead. In certain embodiments, the invention uses such i/o hardware to sample the data stream under investigation.
Preferably, the predetermined rate of the sampling operation is at least double the highest expected data rate of the stream.
Preferably, but not exclusively, the invention is used to determine the baud rates and, optionally, the parity settings used in data signals sent to mobile telephones through an RS232 link.
The invention can also be implemented as a program for causing data processing apparatus to perform the data stream analysis techniques of the invention. By way of example only, certain embodiments of the invention will now be described by reference to the accompanying figures, in which:
Figure 1 is a block diagram illustrating an RS232 link between a PC and a mobile telephone; and
Figure 2 illustrates the wave form of a typical ASCII character received asynchronously over an RS232 to link.
In Figure 1, a PC 2 is shown connected to a mobile telephone 4 via an RS232 link 10. The structure of the telephone 4 is presented in simplified form in Figure 1, including only those elements that are necessary for describing the operation of the present embodiment of the invention.
The RS232 link 10 connects the PC 2 to a UART 20 within the telephone 4. The data line 8 of the RS232 link is shown extending between the PC 2 and the UART 20. Data signals travelling between the PC 2 and the UART 20 10 have the general wave form shown in Figure 2, in which a positive voltage level V, typically between 8 and 14 volts, represents a logical 0 and a nominally equally negative voltage level represents a logical 1. The wave form shown in Figure 2 represents a single ASCII eight bit character being transferred as a group often pulses, where:
• prior to the first pulse 11 , the wave form remains at the negative voltage level;
• the first pulse 11 is a start bit, which is a logical 0, signalling the start of the character;
• a payload section 12 of eight bits for conveying the ASCII character follows the start bit;
• in the event that the character in the payload section 12 is seven bits long, a parity bit 13 is added to complete the payload section and force the parity of the payload section 12 to even or odd to conform with the parity setting of the transmission; • a stop bit of logical 1 is appended to the payload section 12 to indicate the end of the group of pulses defining the character (the stop bit essentially defines the minimum inter-character gap, although other values of inter-character gap are permissible, such as 1.5 and 2 bauds); and
• each pulse is of the same duration, indicated 15, this duration being the reciprocal of the baud rate.
The PC 2 is configured to send data through the RS232 link 10 at a certain baud rate and with a certain parity setting and the UART 20 must be configured to match these settings if the data sent from the PC is to be received correctly be the telephone 4. The UART 20 is configured and controlled by a general purpose microprocessor 24 in the telephone 4. A memory resource within the telephone includes an auto-detect software module 9 that can be run by the processor 24 to discriminate the baud rate and parity setting that are being used by the PC 2 so that the user of the telephone 4 does not have to make these settings manually. The processor executes the auto-detect component 9 following a reported error in the incoming data stream (e.g. start bit not detected, stop bit not detected or incorrect parity) or a change in control line (DTR, CTS) state. The auto-detect component 9 does not, therefore, operate continuously, thereby lessening the processing burden on the processor 24. As is commonly the case, the telephone 4 includes, in addition to the UART 20, a programmable serial input/output circuit 22 and the auto-detect module 9 is arranged to use this circuit to analyse data travelling to the telephone 4 on the data line 8.
The auto-detect component 9 configures the i/o circuit 22 to sample the data line 8, as indicated by notional path 3. The baud rate used by the PC 2 is selected from a standard range of rates, which in this example are 4,800, 9,600, 19,200, 57,600, 115,200 and 230,400Hz and the auto-detect component 9 configures the i/o circuit 22 to sample the data line 8 at twice the maximum baud rate that can be used by the PC 2, i.e. at 460,800Hz. The auto-detect component 9 is arranged to cause the i/o circuit 22 to co-ordinate the capture of samples to commence with the start bit on the data line 8 that follows the error that triggered the processor 24 into executing the auto-detect component. The auto-detect component 9 causes the i/o circuit 22 to capture a train of samples that is sufficient to capture an entire character, i.e. ten pulses, at the slowest baud rate that is to be detected. Given that the sampling rate of the i/o circuit 22 is set to 460,800Hz and the slowest baud rate that can be used by the PC 2 is 4,800Hz, the captured train of samples is to be at least 960 samples long. This sampling process occurs in parallel with the normal data communication activities of the UART 20, which continues to interpret the signal arriving at the telephone 4 on the data line 8 at the current baud rate and parity settings until a decision to change either or both of the settings is made by the auto-detect component 9.
The auto-detect component 9 configures the i/o circuit 22 to write the captured sample train directly into a memory resource within the telephone, bypassing the processor 24. In this way, the auto-detect component 9 can cause a train of samples to be captured for baud rate and parity analysis without impacting greatly on the processing load of the processor 24. This is advantageous since the processor 24 is likely to be engaged in other processing activities that need to be completed in real-time.
Once the auto-detect component 9 has completed the collection of a train of samples, it scans the train to determine the shortest run of samples that share the same logical state. The length of the run so identified is then assumed to correspond to the period of a single baud. As all RS232 command queries start with the characters "A" and "T", this assumption is likely to be valid ("A" is 0010000011 and "T" is 0010101001 - including start and stop bits).
The auto-detect component 9 then translates the minimum run length into a baud rate for the data stream arriving at the telephone 4 through the RS232 link by comparing the minimum run length with a look-up table. The use of a look-up table means that the baud rate of the arriving data stream can be determined rapidly without having to perform computations. Also, the use of a look-up table allows significant tolerances between the baud rate of the PC 2 and that of the UART 20 to be accommodated.
The look-up table used in an embodiment of the invention in which the auto-detect component 9 samples the data stream at 460,800 Hz is given below:
Figure imgf000008_0001
The minimum run length determined by the auto-detect component 9 from the sample train is compared with the run length ranges listed in the left-hand column of the table. The nominal baud rate in the row of the table that holds the run length range containing the measured minimum run length is then allocated to the data stream arriving on the data line 8 ofthe RS232 1ink lO.
In an alternative embodiment, an actual baud rate can be deduced by calculation by taking the reciprocal of the period of time covered by the minimum run length scanned in the sample train acquired by the auto-detect component 9. In a further variant, a baud rate could be assigned by processing the minimum run length through a software decision tree.
Once a baud rate has been allocated to the data stream, the incoming bits on the data line can, if desired, be reconstructed. For example, if the auto-detect component 9 samples the incoming data stream at a rate of 460,800 Hz, then a received character "T" transmitted at
57,600 bps would, if the start and stop bits are neglected, be received as the following train of samples:
0000000011111111000000001111111100000000111111110000000000000000
Assuming that the auto-detect component 9 has correctly determined the number of samples in a single baud, then the auto-detect component 9 will reduce the above signal train to a binary sequence of:
01010100
Since this recovered payload section contains only three symbols of logical 1, it has odd parity. The auto-detect component 9 can therefore conclude that this payload section contains either an eight bit character without a parity bit or a seven bit character with a parity bit that has been set to give the payload section odd parity. Therefore, the auto- detect component 9 needs to analyse several successive recovered payload sections in order to make a determination about the parity setting of the incoming data stream with a degree of confidence. For example, if the next three payload sections from the data stream are also perceived by the auto-detect component 9 to have odd parity, then the auto-detect component can conclude that the arriving data stream contains seven bit characters with accompanying parity bits that have been set to give their payload sections odd parity; otherwise, the auto-detect component could conclude that the incoming data stream consists of payload sections containing eight bit characters with no accompanying parity bits.
Once the auto-detect component 9 has determined the baud rate and, optionally, the parity setting of the data stream arriving via data line 8, the auto-detect component causes the processor 24 to impose these settings on the UART 20 which henceforth employs them in the interpretation of the incoming data stream. In the event that one or both of the baud rate and the parity setting change again or have been incorrectly estimated by the auto- detect component 9, the auto-detect component is triggered into performing another round of the baud rate and parity setting estimation process.

Claims

1. A method of characterising a data stream of binary symbols, the method comprising sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, identifying the shortest continuous run of samples having the same logic level and assigning a symbol rate to the stream on the basis that the identified run is one symbol in length.
2. A method as claimed in claim 1, wherein assigning a symbol rate to the stream comprises comparing the length of the identified run with a set of ranges, each range being associated with a symbol rate, and assigning the symbol rate associated with the range into which the length of the identified run falls.
3. A method as claimed in claim 1, wherein assigning a symbol rate to the stream comprises taking the reciprocal of the duration of the identified run.
4. A method as claimed in claim 1, wherein assigning a symbol rate to the stream comprises processing the identified run through a software decision tree.
5. A method as claimed in any preceding claim, wherein the predetermined rate is at least double the highest expected symbol rate of the stream.
6. A method as claimed in any preceding claim, further comprising recovering one or more frames of symbols from the stream on the basis of the assigned symbol rate and determining the parity of one or more recovered frames in order to estimate whether or not characters are being transmitted with parity bits.
7. An apparatus for characterising a data stream of binary symbols, the apparatus comprising means for sampling the stream at a predetermined rate sufficient to capture at least two samples per binary symbol, means for identifying the shortest continuous run of samples having the same logic level and means for assigning a symbol rate to the stream on the basis that the identified run is one symbol in length.
8. An apparatus as claimed in claim 7, wherein the means for assigning a symbol rate to the stream comprises means for comparing the length of the identified run with a set of ranges, each range being associated with a symbol rate, and means for assigning the symbol rate associated with the range into which the length of the identified run falls.
9. An apparatus as claimed in claim 7, wherein the means for assigning a symbol rate to the stream comprises means for taking the reciprocal of the duration of the identified run.
10. An apparatus as claimed in claim 7, wherein the means for assigning symbol rate to the stream comprises means for processing the identified run through a software decision tree.
11. An apparatus as claimed in any of claims 7 to 10, wherein the predetermined rate is at least double the highest expected symbol rate of the system.
12. An apparatus as claimed in any of claims 7 to 11, further comprising means for recovering one or more frames of symbols from the stream on the basis of the assigned data rate and means for determining the parity of one or more recovered frames in order to estimate whether or not characters are being transmitted with parity bits.
13. A method of determining the baud rate of an RS232-format data stream, the method comprising sampling the stream at a predetermined rate, identifying the shortest continuous run of samples having the same logic level and assigning a baud rate to the stream on the basis that the identified run is one baud in length.
14. A method of characterising an RS232-format data stream comprising a series of characters each packaged in a frame, the method comprising sampling the stream at a predetermined rate, identifying the shortest continuous run of samples having the same logic level, assigning a baud rate to the stream on the basis that the identified run is one baud in length, recovering one or more frames from the stream on the basis of the assigned baud rate and determining the parity of one or more recovered frames in order to estimate whether or not characters are being transmitted with parity bits.
15. An apparatus for determining the baud rate of an RS232-format data stream, the apparatus comprising means for sampling the stream at a predetermined rate, means for identifying the shortest continuous run of samples having the same logic level and means for assigning a baud rate to the stream on the basis that the identified run is one baud in length.
16. An apparatus for characterising an RS232-format data stream comprising a series of characters each packaged in a frame, the apparatus comprising means for sampling the stream at a predetermined rate, means for identifying the shortest continuous run of samples having the same logic level, means for assigning a baud rate to the stream on the basis that the identified run is one baud in length, means for recovering one or more frames from the stream on the basis of the assigned baud rate and means for determining the parity of one or more recovered frames in order to estimate whether or not characters are being transmitted with parity bits.
17. A method of characterising a data stream, the method being substantially as herein described with reference to the accompanying figures.
18. Apparatus for characterising a data stream, the apparatus being substantially as herein described with reference to the accompanying figures.
PCT/GB2005/002596 2004-07-01 2005-07-01 Baud rate detection WO2006003417A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US11/629,986 US8139696B2 (en) 2004-07-01 2005-07-01 Baud rate detection
EP05756937A EP1771986A1 (en) 2004-07-01 2005-07-01 Baud rate detection

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
GBGB0414793.0A GB0414793D0 (en) 2004-07-01 2004-07-01 Determining characteristics of communications signals
GB0414793.0 2004-07-01

Publications (1)

Publication Number Publication Date
WO2006003417A1 true WO2006003417A1 (en) 2006-01-12

Family

ID=32843419

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/GB2005/002596 WO2006003417A1 (en) 2004-07-01 2005-07-01 Baud rate detection

Country Status (7)

Country Link
US (1) US8139696B2 (en)
EP (1) EP1771986A1 (en)
KR (1) KR100976579B1 (en)
CN (1) CN1981497A (en)
GB (1) GB0414793D0 (en)
TW (1) TWI292986B (en)
WO (1) WO2006003417A1 (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7076033B2 (en) * 2003-03-31 2006-07-11 Research In Motion Limited Bit rate matching system and method
CN102315983B (en) * 2010-12-30 2014-05-07 杭州鼎利环保科技有限公司 Circuit and method for automatically detecting Baud rate of multiple paths of serial communication interfaces
CN103618588B (en) * 2013-11-26 2016-10-05 中国科学院嘉兴微电子与系统工程中心 A kind of auto-baud-detect method and detection module

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5222081A (en) * 1991-06-28 1993-06-22 Universal Data Systems, Inc. Method of performing an autobaud function using a state flow machine
EP0669738A2 (en) 1993-12-29 1995-08-30 International Business Machines Corporation System and method for automatically detecting speed, parity, and character length
US5654983A (en) * 1994-06-10 1997-08-05 Hayes Microcomputer Products, Inc. Method and apparatus of operating data communications equipment in command mode and autobauding
EP0918421A1 (en) * 1997-11-13 1999-05-26 Optimay GmbH Baud rate detection in serial data transmission
US5923705A (en) * 1996-07-18 1999-07-13 Qualcomm Incorporated UART based autobauding without data loss
EP1122921A1 (en) * 2000-02-02 2001-08-08 TELEFONAKTIEBOLAGET L M ERICSSON (publ) Circuit and method for providing a digital data signal with pre-distortion
US6285722B1 (en) * 1997-12-05 2001-09-04 Telcordia Technologies, Inc. Method and apparatus for variable bit rate clock recovery

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3747074A (en) 1972-03-17 1973-07-17 Comteu Method of and apparatus for baud rate detection
US4584690A (en) 1984-05-07 1986-04-22 D.A.V.I.D. Systems, Inc. Alternate Mark Invert (AMI) transceiver with switchable detection and digital precompensation
US4761800A (en) * 1987-03-02 1988-08-02 American Telephone And Telegraph Company, At&T Bell Laboratories Method and apparatus for detecting a rate of data transmission
DE4308418A1 (en) 1993-03-17 1994-09-22 Elsa Gmbh Bit rate detection
US5530707A (en) * 1994-03-09 1996-06-25 At&T Corp. Area-efficient decoders for rate-k/n convolutional codes and other high rate trellis codes
GB2324688A (en) 1997-04-25 1998-10-28 Motorola Ltd A modem in which bit rate is determined using the width of a start bit
US6198785B1 (en) * 1997-09-29 2001-03-06 Lucent Technologies Inc. Autobaud rate detection and adjustment
US6097754A (en) * 1998-02-25 2000-08-01 Lucent Technologies, Inc. Method of automatically detecting the baud rate of an input signal and an apparatus using the method
US6157689A (en) 1998-03-16 2000-12-05 Ericsson Inc. Automatic speed detection for asynchronous serial communications
DE19825258B4 (en) 1998-06-05 2005-11-17 Telefonaktiebolaget Lm Ericsson (Publ) Output buffer circuit for transmitting digital signals over a preemphasis transmission line
US6970525B1 (en) * 2000-08-14 2005-11-29 Texas Instruments Incorporated High-speed, high granularity baud clock generation
US20030225492A1 (en) * 2002-05-29 2003-12-04 Cope Gary G. Flight data transmission via satellite link and ground storage of data
US7062003B2 (en) * 2002-09-27 2006-06-13 Texas Instruments Incorporated Self-tuning baud rate generator for UART applications

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5222081A (en) * 1991-06-28 1993-06-22 Universal Data Systems, Inc. Method of performing an autobaud function using a state flow machine
EP0669738A2 (en) 1993-12-29 1995-08-30 International Business Machines Corporation System and method for automatically detecting speed, parity, and character length
US5654983A (en) * 1994-06-10 1997-08-05 Hayes Microcomputer Products, Inc. Method and apparatus of operating data communications equipment in command mode and autobauding
US5923705A (en) * 1996-07-18 1999-07-13 Qualcomm Incorporated UART based autobauding without data loss
EP0918421A1 (en) * 1997-11-13 1999-05-26 Optimay GmbH Baud rate detection in serial data transmission
US6285722B1 (en) * 1997-12-05 2001-09-04 Telcordia Technologies, Inc. Method and apparatus for variable bit rate clock recovery
EP1122921A1 (en) * 2000-02-02 2001-08-08 TELEFONAKTIEBOLAGET L M ERICSSON (publ) Circuit and method for providing a digital data signal with pre-distortion

Also Published As

Publication number Publication date
GB0414793D0 (en) 2004-08-04
US8139696B2 (en) 2012-03-20
TWI292986B (en) 2008-01-21
KR100976579B1 (en) 2010-08-18
EP1771986A1 (en) 2007-04-11
US20070294044A1 (en) 2007-12-20
CN1981497A (en) 2007-06-13
TW200607261A (en) 2006-02-16
KR20070038519A (en) 2007-04-10

Similar Documents

Publication Publication Date Title
JP5767462B2 (en) COMMUNICATION MODE DETECTION METHOD BY RECEIVING DEVICE FOR NEAR RANGE COMMUNICATION
US6072827A (en) Automatic baud rate detection
CN112559412B (en) Serial port baud rate self-adaptive receiving end, realization method and system
US9338035B2 (en) Microcontroller with can bus module and auto speed detect
KR19990087380A (en) Interfacing between processor and communication channel
CN101710857A (en) Serial communication baud rate adaptive method and device thereof
US6581100B1 (en) System and method for communication parameter determination
US8139696B2 (en) Baud rate detection
JP2000209302A (en) At command analyzer
CN105474584B (en) CAN FD frame end detector and detection method, CAN bit stream processor and operating method
US20050036595A1 (en) Bit rate matching system and method
EP1154603A1 (en) Training of equalisers, for use with signals of differing data rates
JP2004056803A (en) Programmable glitch filter for asynchronous data communication interface
US20020184413A1 (en) Circuit arrangement and method for improving data management in a data communications circuit
US7142592B2 (en) Determining speed of a digital signal in a serial transmission line
CN100356359C (en) Connector between processor and user recognition card
US6798869B1 (en) Bit rate matching system and method
JP3857687B2 (en) Device communication speed detection method
US5793803A (en) Underrecovery system and method for block processing modems
CN107810495B (en) UART with wire activity detector
US6724848B1 (en) Sync regeneration in a universal serial bus
CN109977062A (en) A kind of method, apparatus and electronic equipment of software realization Serial data receiving
JPS6245255A (en) Data reception system
US7167111B2 (en) Method of coding and/or decoding binary data for wireless transmission, particularly for radio transmitted data, and equipment for implementing this method
KR100658565B1 (en) System for diagnosing monitoring access station modem and user equipment modem

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KM KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NG NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SM SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): BW GH GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IS IT LT LU LV MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 11629986

Country of ref document: US

WWE Wipo information: entry into national phase

Ref document number: 3843/KOLNP/2006

Country of ref document: IN

NENP Non-entry into the national phase

Ref country code: DE

WWW Wipo information: withdrawn in national office

Ref document number: DE

WWE Wipo information: entry into national phase

Ref document number: 200580022652.4

Country of ref document: CN

REEP Request for entry into the european phase

Ref document number: 2005756937

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 1020077001740

Country of ref document: KR

Ref document number: 2005756937

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 1020077001740

Country of ref document: KR

WWP Wipo information: published in national office

Ref document number: 2005756937

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 11629986

Country of ref document: US