WO2006003417A1 - Baud rate detection - Google Patents
Baud rate detection Download PDFInfo
- 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
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L25/00—Baseband systems
- H04L25/02—Details ; arrangements for supplying electrical power along data transmission lines
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L25/00—Baseband systems
- H04L25/02—Details ; arrangements for supplying electrical power along data transmission lines
- H04L25/0262—Arrangements 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
Description
Claims
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)
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)
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)
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 |
-
2004
- 2004-07-01 GB GBGB0414793.0A patent/GB0414793D0/en not_active Ceased
-
2005
- 2005-06-28 TW TW094121545A patent/TWI292986B/en not_active IP Right Cessation
- 2005-07-01 KR KR1020077001740A patent/KR100976579B1/en active IP Right Grant
- 2005-07-01 WO PCT/GB2005/002596 patent/WO2006003417A1/en active Application Filing
- 2005-07-01 EP EP05756937A patent/EP1771986A1/en not_active Withdrawn
- 2005-07-01 US US11/629,986 patent/US8139696B2/en not_active Expired - Fee Related
- 2005-07-01 CN CNA2005800226524A patent/CN1981497A/en active Pending
Patent Citations (7)
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 |