CN104360974A - Method and device for automatically adjusting Baud rate of universal asynchronous receiver/transmitter (UART) - Google Patents
Method and device for automatically adjusting Baud rate of universal asynchronous receiver/transmitter (UART) Download PDFInfo
- Publication number
- CN104360974A CN104360974A CN201410593284.XA CN201410593284A CN104360974A CN 104360974 A CN104360974 A CN 104360974A CN 201410593284 A CN201410593284 A CN 201410593284A CN 104360974 A CN104360974 A CN 104360974A
- Authority
- CN
- China
- Prior art keywords
- uart
- data
- baud
- measurement module
- count value
- Prior art date
- Legal status (The legal status 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 status listed.)
- Pending
Links
Classifications
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/382—Information transfer, e.g. on bus using universal interface adapter
- G06F13/385—Information transfer, e.g. on bus using universal interface adapter for adaptation of a particular data processing system to different peripheral devices
 
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Transfer Systems (AREA)
- Communication Control (AREA)
- Synchronisation In Digital Transmission Systems (AREA)
Abstract
The invention discloses a method and a device for automatically adjusting the Baud rate of a universal asynchronous receiver/transmitter (UART). The method comprises the following steps: sending a preset character with a specific frame format to a central processing unit (CPU) by an upper computer; powering on and resetting the CPU, receiving the preset character, and starting a measurement module to count the pulse width of the preset character according to a work clock of the universal asynchronous receiver/transmitter (UART), so that a corresponding serial Baud rate is configured by a configuration module according to a count value to obtain an adjusted Baud rate, and feeding back the upper computer to confirm the character; receiving the confirmed character by the upper computer to confirm that the automatic Baud rate adjustment of the UART is completed after the verification is correct. The purposes that the Baud rate of the UART is automatically adjusted on an original chip, extra chip pins do not need to be added and the spending is saved are achieved.
    Description
Technical field
      The present invention relates to the technical field of baud rate adjustment, particularly relate to a kind of asynchronous serial port UART auto-baud method of adjustment and device.
    Background technology
      UART (Universal Asynchronous Receiver/Transmitter, asynchronous serial port) is commonly used to transmit data, tune-up data, performs and moves program boot.The interface of UART is non-source sync cap, does not have clock signal, and therefore the Transmission bit rate of UART needs communicating pair to arrange unanimously.
      CPU (Central Processing Unit, central processing unit) crystal oscillator frequency initial configuration need boot start process in realize, but because boot is normally solidificated in ROM (Read Only Memory, read-only memory), corresponding ROM is also referred to as boot ROM, therefore, the boot after this solidification is not easy to configure different Configuration of baud rate programs to different frequency device.
      At present, can by arranging specialized chip pin instruction external crystal-controlled oscillation frequency, boot reads the parameter of this specialized chip pin and configures corresponding baud rate accordingly.But this mode needs to increase extra chip pin, increases extra expense.
    Summary of the invention
      The object of this invention is to provide a kind of asynchronous serial port UART auto-baud method of adjustment and device, to realize carrying out the adjustment of UART auto-baud on original chip, do not need to increase extra chip pin, the object of paring down expenses.
      For solving the problems of the technologies described above, the invention provides following technical scheme.
      A kind of asynchronous serial port UART auto-baud method of adjustment, comprising:
      Host computer sends the preset characters with particular frame format to central processor CPU;
      Described CPU electrification reset, receive described preset characters, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate according to count value, baud rate after being adjusted, and to described host computer feedback acknowledgment character;
      Described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct.
      Preferably, described startup measurement module counts according to the pulsewidth of work clock to described preset characters of asynchronous serial port UART, comprising:
      The data that asynchronous clock domain synchronous processing device CDC sync in described measurement module is received in the data bit of described preset characters by the pin RXD of the reception data of described UART synchronously process, wherein, described data are 8 bit binary data or hexadecimal data;
      Counter Counter2 in described measurement module is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtaining count value n;
      Described Counter1 is after reset or resetting, the operating clock signals uart_clk inputted according to described UART, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtains count value cnt and ready signal ready when terminating counting.
      Preferably, described in make configuration module configure corresponding serial port baud rate according to count value, the baud rate after being adjusted, comprising:
      Described configuration module, when described ready signal ready being detected, obtains count value cnt and count value n, according to f
        baud=f
        uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
        baud; Wherein, div=cnt*16/n.
      
      Preferably, the preset characters described in particular frame format comprises 1 start bit, 8 data bit, 1 even parity bit and 1 position of rest.
      Preferably, when the data in the data bit of 8 in described preset characters are 0x55, counter Counter2 in described measurement module is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and counting adds one when the pulsewidth that described RXD receives described data is rising edge, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtain count value n, comprise:
      Carry out resetting or resetting after reception described reset signal reset or reset signal restart;
      When the pulsewidth that described RXD receives described data 0x55 is rising edge, counting adds one, and generates count enable signal en and be sent to counter Counter1 in described measurement module; Wherein, the pulsewidth rising edge of described data 0x55 has 5;
      Receive 5 rising edges of the pulsewidth of described data 0x55 at described RXD after, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and to obtain count value n be 5.
      Preferably, described host computer receives after described acknowledge character determined the adjustment of UART auto-baud after checking is correct, also comprises:
      Described host computer starts to transmit data to described CPU.
      A kind of asynchronous serial port UART auto-baud regulating device, comprising: host computer and central processor CPU;
      Described host computer, for sending the preset characters with particular frame format to described CPU; The acknowledge character receiving described CPU feedback has determined that UART auto-baud adjusts after checking is correct;
      Described CPU, for electrification reset, receive described preset characters, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate according to count value, baud rate after being adjusted, and to described host computer feedback acknowledgment character.
      Preferably, described host computer comprises PC.
      Preferably, described CPU comprises: be provided with asynchronous clock domain synchronous processing device CDC sync, the measurement module of counter Counter1 sum counter Counter2;
      Described CDC sync, the data received in the data bit of described preset characters for the pin RXD of the reception data by described UART synchronously process, and wherein, described data are 8 bit binary data or hexadecimal data;
      Described Counter2, for after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtaining count value n;
      Described Counter1, for after reset or resetting, the operating clock signals uart_clk inputted according to described UART, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtains count value cnt ready signal ready when terminating counting.
      Preferably, described CPU comprises configuration module;
      Described configuration module, for when described described ready signal ready detected, obtain count value cnt and count value n, according to f
        baud=f
        uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
        baud; Wherein, div=cnt*16/n.
      
      A kind of asynchronous serial port UART auto-baud method of adjustment provided by the present invention and device, described CPU electrification reset, receive the preset characters with particular frame format that described host computer sends to described CPU, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate and baud rate after being adjusted according to count value, and described host computer receives the baud rate after described adjustment and to described CPU feedback acknowledgment character, described CPU receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct, thus realize on original chip, carry out the adjustment of UART auto-baud, do not need to increase extra chip pin, the object of paring down expenses.
    Accompanying drawing explanation
      In order to be illustrated more clearly in the embodiment of the present invention or technical scheme of the prior art, be briefly described to the accompanying drawing used required in embodiment or description of the prior art below, apparently, accompanying drawing in the following describes is only embodiments of the invention, for those of ordinary skill in the art, under the prerequisite not paying creative work, other accompanying drawing can also be obtained according to the accompanying drawing provided.
      The process flow diagram of the asynchronous serial port UART auto-baud method of adjustment that Fig. 1 provides for the embodiment of the present invention one;
      The partial process view of the asynchronous serial port UART auto-baud method of adjustment that Fig. 2 provides for the embodiment of the present invention two;
      The oscillogram of the clock signal uart_clk that Fig. 3 provides for the embodiment of the present invention two and data;
      The process flow diagram that the CPU that Fig. 4 provides for the embodiment of the present invention two is concise and to the point;
      The partial process view of the asynchronous serial port UART auto-baud method of adjustment that Fig. 5 provides for the embodiment of the present invention three;
      The structural drawing of CPU in the asynchronous serial port UART auto-baud adjusting gear that Fig. 6 provides for the embodiment of the present invention four.
    Embodiment
      Core of the present invention is to provide a kind of asynchronous serial port UART auto-baud method of adjustment and device, to realize carrying out the adjustment of UART auto-baud on original chip, does not need to increase extra chip pin, the object of paring down expenses.
      The present invention program is understood better in order to make those skilled in the art person, below in conjunction with the accompanying drawing in the embodiment of the present invention, technical scheme in the embodiment of the present invention is clearly and completely described, obviously, described embodiment is only the present invention's part embodiment, instead of whole embodiments.Based on the embodiment in the present invention, those of ordinary skill in the art, not making the every other embodiment obtained under creative work prerequisite, belong to the scope of protection of the invention.
      Embodiment one
      Please refer to Fig. 1, the process flow diagram of the asynchronous serial port UART auto-baud method of adjustment that Fig. 1 provides for the embodiment of the present invention one, the method comprises:
      Step S101: host computer sends the preset characters with particular frame format to central processor CPU;
      Step S102: described CPU electrification reset, receive described preset characters, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, and makes configuration module configure corresponding serial port baud rate according to count value, and to described host computer feedback acknowledgment character;
      Step S103: described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct;
      Based on the asynchronous serial port UART auto-baud method of adjustment that the embodiment of the present invention provides, described CPU electrification reset, receive the preset characters with particular frame format that described host computer sends to described CPU, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate and baud rate after being adjusted according to count value, and to described host computer feedback acknowledgment character, described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct, thus realize on original chip, carry out the adjustment of UART auto-baud, do not need to increase extra chip pin, the object of paring down expenses.
      Embodiment two
      Based on the asynchronous serial port UART auto-baud method of adjustment disclosed in the invention described above embodiment one, the pulsewidth of work clock to described preset characters of the described startup measurement module foundation asynchronous serial port UART that the embodiment of the present invention two essentially discloses in middle step S102 counts, as shown in Figure 2, and composition graphs 5, preferably adopt following steps to realize:
      Step S201: the data that the asynchronous clock domain synchronous processing device CDC sync in described measurement module is received in the data bit of described preset characters by the pin RXD of the reception data of described UART synchronously process;
      In step s 201, described data are 8 bit binary data or hexadecimal data.
      Step S202: the counter Counter2 in described measurement module after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtaining count value n;
      Step S203: described Counter1 after reset or resetting, the operating clock signals uart_clk inputted according to described UART, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtains count value cnt and ready signal ready when terminating counting.
      Wherein, for step S202 and step S203, composition graphs 3, Fig. 3 is the oscillogram of described uart_clk and described data, in figure, start shows that measurement module starts to start, at each rising edge place of described data waveform, described Counter2 counting adds one, and the periodicity of the described Counter1 pair of described uart_clk waveform corresponding to the rising edge of described data waveform counts.
      Based on above-mentioned asynchronous serial port UART auto-baud method of adjustment preferably and disclosed in the embodiment of the present invention one, the configuration module that makes that the embodiment of the present invention three discloses in step S102 configures corresponding serial port baud rate according to count value, baud rate after being adjusted, preferably adopts following steps to realize:
      Step S301: described configuration module, when described ready signal ready being detected, obtains count value cnt and count value n, according to f
        baud=f
        uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
        baud;
      
      In step S301, div=cnt*16/n, when described configuration module detects described ready signal ready for " 1 ", namely detects the ready signal ready that Counter1 sends, obtain the count value cnt in counter Counter2 and count value n, according to div=cnt*16/n and f
        baud=f
        uart_clk/ 16/div obtains the baud rate f after adjustment
        baud, when described configuration module detects described ready signal ready for " 0 ", the ready signal ready namely detected is for time empty, and described CPU restarts measurement module, again performs subsequent step.
      
      Based on above-mentioned asynchronous serial port UART auto-baud method of adjustment preferably and disclosed in the embodiment of the present invention one, preferably, also comprise after step s 103:
      Step S501: described host computer starts to transmit data to described CPU.
      In the process that step S501 performs, need execution to move program boot transceiving data, and jump to master routine performing data transmission.
      Based on above-mentioned preferably all, it should be noted that, perform in step S102 in the process of described host computer feedback acknowledgment character, described upper seat in the plane comprises character " ACK " to the acknowledge character that described CPU feeds back, and this character " ACK " is acknowledge character.
      Comprehensive the above, concise and to the point process is the outline flowchart of described CPU with reference to figure 4, Fig. 4, and process step is as follows:
      S1: electrification reset;
      S2: receive the preset characters that described host computer sends, starts measurement module;
      S3: the pulsewidth of work clock to described preset characters according to asynchronous serial port UART counts, obtains described ready signal ready when terminating counting;
      S4: judge whether described ready is " 1 ", if so, enters S4; If not, enter S2;
      S5: obtain described count value cnt and described count value n, configure the serial port baud rate of described UART, the baud rate f after being adjusted
        baud;
      
      S6: to described host computer feedback acknowledgment character " ACK ";
      S7: described host computer receives after described acknowledge character " ACK " determined after checking is correct, performs and moves program boot transceiving data;
      S8: jump to master routine performing data transmission.
      Based on the asynchronous serial port UART auto-baud method of adjustment that the embodiment of the present invention provides, described CPU electrification reset, receive the preset characters with particular frame format that described host computer sends to described CPU, by described RXD, the data received in the data bit of described preset characters synchronously process described CDC sync, described Counter2 is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to described Counter1, when described RXD receives described data, stop counting and send described count enable signal en to described Counter1, and obtain count value n.
      Further, described Counter1 is after reset or resetting, according to described uart_clk, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtain count value cnt and ready signal ready when terminating counting, described configuration module, when described ready signal ready being detected, obtains count value cnt and count value n, according to f
        baud=f
        uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
        baud, and to described host computer feedback acknowledgment character.
      
      Further, described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct, described host computer starts to transmit data to described CPU afterwards, thus realize on original chip, carry out the adjustment of UART auto-baud, do not need to increase extra chip pin, the object of paring down expenses.
      Embodiment three
      Based on the asynchronous serial port UART auto-baud method of adjustment disclosed in the invention described above embodiment one and the embodiment of the present invention two, preferably, the described preset characters with particular frame format comprises 1 start bit, 8 data bit, 1 even parity bit and 1 position of rest.
      Based on the asynchronous serial port UART auto-baud method of adjustment disclosed in the invention described above embodiment one and the embodiment of the present invention two, when the data in the data bit of 8 in described preset characters are 0x55, the embodiment of the present invention three discloses step S202: the counter Counter2 in described measurement module is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtain count value n, as shown in Figure 5, preferred employing following steps realize:
      Step S401: carry out resetting or resetting after reception described reset signal reset or reset signal restart;
      Step S402: counting adds one when the pulsewidth that described RXD receives described data 0x55 is rising edge, and generate count enable signal en and be sent to counter Counter1 in described measurement module;
      Wherein, the pulsewidth rising edge of described data 0x55 has 5;
      Step S403: receive 5 rising edges of the pulsewidth of described data 0x55 at described RXD after, stops counting and send described count enable signal en to the counter Counter1 in described measurement module, and to obtain count value n is 5.
      Based on the asynchronous serial port UART auto-baud method of adjustment that the embodiment of the present invention provides, described CPU electrification reset, what receive that described host computer sends to described CPU has 1 start bit, 8 data bit, the preset characters of 1 even parity bit and 1 position of rest, by described RXD, the data 0x55 received in the data bit of described preset characters synchronously processes described CDC sync, described Counter2 is after reception reset signal reset or reset signal restart, when the pulsewidth that described RXD receives described data 0x55 is rising edge, counting adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, receive 5 rising edges of the pulsewidth of described data 0x55 at described RXD after, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and to obtain count value n be 5.
      Further, described Counter1 is after reset or resetting, according to described uart_clk, the uart_clk periodicity receiving described data 0x55 when receiving described count enable signal en is counted, and obtain count value cnt and ready signal ready when terminating counting, configuration module is made to configure corresponding serial port baud rate and baud rate after being adjusted according to count value, and to described host computer feedback acknowledgment character, described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct, thus the chip pin that the adjustment of UART auto-baud does not need increase extra is carried out in realization on original chip, the object of paring down expenses.
      Embodiment four
      Asynchronous serial port UART auto-baud method of adjustment disclosed in the invention described above embodiment one to embodiment three, the embodiment of the present invention four also corresponding said method discloses a kind of asynchronous serial port UART auto-baud adjusting gear, comprising:
      Host computer and central processor CPU;
      Described host computer, for sending the preset characters with particular frame format to described CPU; Receive the baud rate after the adjustment that described CPU obtains; Receive described acknowledge character and determined that UART auto-baud adjusts after checking is correct;
      Described CPU, for electrification reset, receive described preset characters, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate according to count value, baud rate after being adjusted, and to described host computer feedback acknowledgment character.
      Preferably, the described host computer in said apparatus comprises PC;
      Preferably, with reference to figure 6, the described CPU in said apparatus comprises: be provided with asynchronous clock domain synchronous processing device CDC syncF100, the measurement module of counter Counter1F200 sum counter Counter2F300;
      Described CDC syncF100, the data received in the data bit of described preset characters for the pin RXD of the reception data by described UART synchronously process, and wherein, described data are 8 bit binary data or hexadecimal data;
      Described Counter2F300, for after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtaining count value n;
      Described Counter1F200, for after reset or resetting, the operating clock signals uart_clk inputted according to described UART, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtains count value cnt and ready signal ready when terminating counting.
      Preferably, the described CPU in said apparatus comprises configuration module;
      Described configuration module, for when described described ready signal ready detected, obtain count value cnt and count value n, according to f
        baud=f
        uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
        baud; Wherein, div=cnt*16/n.
      
      A kind of asynchronous serial port UART auto-baud adjusting gear that the embodiment of the present invention provides, described CPU electrification reset, receive the preset characters with particular frame format that described host computer sends to described CPU, by described RXD, the data received in the data bit of described preset characters synchronously process described CDC sync, described Counter2 is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to described Counter1, when described RXD receives described data, stop counting and send described count enable signal en to described Counter1, and obtain count value n.
      Further, described Counter1 is after reset or resetting, according to described uart_clk, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtain count value cnt and ready signal ready when terminating counting, described configuration module when described described ready signal ready detected, obtain count value cnt and count value n, according to f
        baud=f
        uart_clk/ 16/div configures the serial port baud rate of described UART, and div=cnt*16/n, the baud rate f after being adjusted
        baudand to described host computer feedback acknowledgment character, described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct, described host computer starts to transmit data to described CPU afterwards, thus the chip pin that the adjustment of UART auto-baud does not need increase extra is carried out in realization on original chip, the object of paring down expenses.
      
      Above a kind of asynchronous serial port UART auto-baud method of adjustment provided by the present invention and device are described in detail.Apply specific case herein to set forth principle of the present invention and embodiment, the explanation of above embodiment just understands method of the present invention and core concept thereof for helping.It should be pointed out that for those skilled in the art, under the premise without departing from the principles of the invention, can also carry out some improvement and modification to the present invention, these improve and modify and also fall in the protection domain of the claims in the present invention.
    Claims (10)
1. an asynchronous serial port UART auto-baud method of adjustment, is characterized in that, comprising:
      Host computer sends the preset characters with particular frame format to central processor CPU;
      Described CPU electrification reset, receive described preset characters, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate according to count value, baud rate after being adjusted, and to described host computer feedback acknowledgment character;
      Described host computer receives described acknowledge character and determined that UART auto-baud adjusts after checking is correct.
    2. the method for claim 1, is characterized in that, described startup measurement module counts according to the pulsewidth of work clock to described preset characters of asynchronous serial port UART, comprising:
      The data that asynchronous clock domain synchronous processing device CDC sync in described measurement module is received in the data bit of described preset characters by the pin RXD of the reception data of described UART synchronously process, wherein, described data are 8 bit binary data or hexadecimal data;
      Counter Counter2 in described measurement module is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtaining count value n;
      Described Counter1 is after reset or resetting, the operating clock signals uart_clk inputted according to described UART, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtains count value cnt and ready signal ready when terminating counting.
    3. method as claimed in claim 2, is characterized in that, described in make configuration module configure corresponding serial port baud rate according to count value, the baud rate after being adjusted, comprising:
      Described configuration module, when described ready signal ready being detected, obtains count value cnt and count value n, according to f
          baud=f
          uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
          baud; Wherein, div=cnt*16/n.
        
    4. method as claimed in claim 3, is characterized in that, described in there is particular frame format preset characters comprise 1 start bit, 8 data bit, 1 even parity bit and 1 position of rest.
    5. method as claimed in claim 4, it is characterized in that, when the data in the data bit of 8 in described preset characters are 0x55, counter Counter2 in described measurement module is after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and counting adds one when the pulsewidth that described RXD receives described data is rising edge, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtain count value n, comprise:
      Carry out resetting or resetting after reception described reset signal reset or reset signal restart;
      When the pulsewidth that described RXD receives described data 0x55 is rising edge, counting adds one, and generates count enable signal en and be sent to counter Counter1 in described measurement module; Wherein, the pulsewidth rising edge of described data 0x55 has 5;
      Receive 5 rising edges of the pulsewidth of described data 0x55 at described RXD after, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and to obtain count value n be 5.
    6. as the method in Claims 1 to 5 as described in any one, it is characterized in that, described host computer receives after described acknowledge character determined the adjustment of UART auto-baud after checking is correct, also comprises:
      Described host computer starts to transmit data to described CPU.
    7. an asynchronous serial port UART auto-baud regulating device, is characterized in that, comprising: host computer and central processor CPU;
      Described host computer, for sending the preset characters with particular frame format to described CPU; The acknowledge character receiving described CPU feedback has determined that UART auto-baud adjusts after checking is correct;
      Described CPU, for electrification reset, receive described preset characters, the pulsewidth of work clock to described preset characters starting measurement module foundation asynchronous serial port UART counts, configuration module is made to configure corresponding serial port baud rate according to count value, baud rate after being adjusted, and to described host computer feedback acknowledgment character.
    8. device as claimed in claim 7, it is characterized in that, described host computer comprises PC.
    9. device as claimed in claim 7, it is characterized in that, described CPU comprises: be provided with asynchronous clock domain synchronous processing device CDC sync, the measurement module of counter Counter1 sum counter Counter2;
      Described CDC sync, the data received in the data bit of described preset characters for the pin RXD of the reception data by described UART synchronously process, and wherein, described data are 8 bit binary data or hexadecimal data;
      Described Counter2, for after reception reset signal reset or reset signal restart, counting is started when described RXD receives described data, and described RXD counting when the pulsewidth receiving described data is rising edge adds one, and generate count enable signal en and be sent to counter Counter1 in described measurement module, when described RXD receives described data, stop counting and send described count enable signal en to the counter Counter1 in described measurement module, and obtaining count value n;
      Described Counter1, for after reset or resetting, the operating clock signals uart_clk inputted according to described UART, the uart_clk periodicity receiving described data when receiving described count enable signal en is counted, and obtains count value cnt ready signal ready when terminating counting.
    10. device as claimed in claim 9, it is characterized in that, described CPU comprises configuration module;
      Described configuration module, for when described described ready signal ready detected, obtain count value cnt and count value n, according to f
          baud=f
          uart_clk/ 16/div configures the serial port baud rate of described UART, the baud rate f after being adjusted
          baud; Wherein, div=cnt*16/n.
        
    Priority Applications (1)
| Application Number | Priority Date | Filing Date | Title | 
|---|---|---|---|
| CN201410593284.XA CN104360974A (en) | 2014-10-29 | 2014-10-29 | Method and device for automatically adjusting Baud rate of universal asynchronous receiver/transmitter (UART) | 
Applications Claiming Priority (1)
| Application Number | Priority Date | Filing Date | Title | 
|---|---|---|---|
| CN201410593284.XA CN104360974A (en) | 2014-10-29 | 2014-10-29 | Method and device for automatically adjusting Baud rate of universal asynchronous receiver/transmitter (UART) | 
Publications (1)
| Publication Number | Publication Date | 
|---|---|
| CN104360974A true CN104360974A (en) | 2015-02-18 | 
Family
ID=52528237
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| CN201410593284.XA Pending CN104360974A (en) | 2014-10-29 | 2014-10-29 | Method and device for automatically adjusting Baud rate of universal asynchronous receiver/transmitter (UART) | 
Country Status (1)
| Country | Link | 
|---|---|
| CN (1) | CN104360974A (en) | 
Cited By (9)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| CN106130856A (en) * | 2016-08-17 | 2016-11-16 | 天津市英贝特航天科技有限公司 | A kind of self adaptation baud rate RS485 communications protocol | 
| CN107450935A (en) * | 2016-05-30 | 2017-12-08 | 北京信威通信技术股份有限公司 | A kind of BOOTROM of chip starts collocation method and device | 
| CN109525350A (en) * | 2018-10-12 | 2019-03-26 | 福建星云电子股份有限公司 | Module synchronization control method based on asynchronous serial port synchronisation source | 
| CN109669899A (en) * | 2018-11-23 | 2019-04-23 | 中科曙光信息产业成都有限公司 | The method and serial port device of automatic adjusument serial communication baud rate | 
| CN111211869A (en) * | 2020-01-02 | 2020-05-29 | 深圳震有科技股份有限公司 | Method for automatically adapting baud rate, intelligent terminal and storage medium | 
| CN111274194A (en) * | 2018-12-05 | 2020-06-12 | 锐迪科(重庆)微电子科技有限公司 | Data processing apparatus and control method thereof | 
| CN111400216A (en) * | 2019-01-03 | 2020-07-10 | 珠海格力电器股份有限公司 | UART module, method for adjusting transmission parameters of UART module and system-level chip | 
| CN112202528A (en) * | 2020-08-17 | 2021-01-08 | 北京海泰方圆科技股份有限公司 | Communication baud rate correction method and device, electronic equipment and storage medium | 
| CN113448907A (en) * | 2021-08-31 | 2021-09-28 | 北京智联安科技有限公司 | Low-power-consumption serial asynchronous transceiver, data receiving method and medium | 
Citations (6)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| CN1293852A (en) * | 1998-03-16 | 2001-05-02 | 艾利森公司 | Automatic rate detection for asynchronous serial communication | 
| CN1353828A (en) * | 1999-03-30 | 2002-06-12 | 西门子能量及自动化公司 | Programmable logic controller method, system and apparatus | 
| US20050041594A1 (en) * | 2003-08-06 | 2005-02-24 | Jha Mithilesh Kumar | Automatic baud rate determination | 
| CN102306136A (en) * | 2011-08-03 | 2012-01-04 | 宁波三星电气股份有限公司 | Baud rate self-adaption method based on input capture function of singlechip | 
| CN103036823A (en) * | 2012-12-14 | 2013-04-10 | 中船重工(武汉)凌久电子有限责任公司 | Baud rate fast self-adaptive method based on field programmable gate array (FPGA), processor and receiving end | 
| CN103412615A (en) * | 2013-08-22 | 2013-11-27 | 中国航天科工集团第三研究院第八三五七研究所 | Glitch-free self-adaptive clock switching method for UART (Universal Asynchronous Receiver Transmitter) interface chip | 
- 
        2014
        - 2014-10-29 CN CN201410593284.XA patent/CN104360974A/en active Pending
 
Patent Citations (6)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| CN1293852A (en) * | 1998-03-16 | 2001-05-02 | 艾利森公司 | Automatic rate detection for asynchronous serial communication | 
| CN1353828A (en) * | 1999-03-30 | 2002-06-12 | 西门子能量及自动化公司 | Programmable logic controller method, system and apparatus | 
| US20050041594A1 (en) * | 2003-08-06 | 2005-02-24 | Jha Mithilesh Kumar | Automatic baud rate determination | 
| CN102306136A (en) * | 2011-08-03 | 2012-01-04 | 宁波三星电气股份有限公司 | Baud rate self-adaption method based on input capture function of singlechip | 
| CN103036823A (en) * | 2012-12-14 | 2013-04-10 | 中船重工(武汉)凌久电子有限责任公司 | Baud rate fast self-adaptive method based on field programmable gate array (FPGA), processor and receiving end | 
| CN103412615A (en) * | 2013-08-22 | 2013-11-27 | 中国航天科工集团第三研究院第八三五七研究所 | Glitch-free self-adaptive clock switching method for UART (Universal Asynchronous Receiver Transmitter) interface chip | 
Cited By (11)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| CN107450935A (en) * | 2016-05-30 | 2017-12-08 | 北京信威通信技术股份有限公司 | A kind of BOOTROM of chip starts collocation method and device | 
| CN106130856A (en) * | 2016-08-17 | 2016-11-16 | 天津市英贝特航天科技有限公司 | A kind of self adaptation baud rate RS485 communications protocol | 
| CN109525350A (en) * | 2018-10-12 | 2019-03-26 | 福建星云电子股份有限公司 | Module synchronization control method based on asynchronous serial port synchronisation source | 
| CN109525350B (en) * | 2018-10-12 | 2020-04-10 | 福建星云电子股份有限公司 | Module synchronization control method based on asynchronous serial port synchronization source | 
| CN109669899A (en) * | 2018-11-23 | 2019-04-23 | 中科曙光信息产业成都有限公司 | The method and serial port device of automatic adjusument serial communication baud rate | 
| CN109669899B (en) * | 2018-11-23 | 2020-07-28 | 中科曙光信息产业成都有限公司 | Method for adaptively adjusting serial port communication baud rate and serial port device | 
| CN111274194A (en) * | 2018-12-05 | 2020-06-12 | 锐迪科(重庆)微电子科技有限公司 | Data processing apparatus and control method thereof | 
| CN111400216A (en) * | 2019-01-03 | 2020-07-10 | 珠海格力电器股份有限公司 | UART module, method for adjusting transmission parameters of UART module and system-level chip | 
| CN111211869A (en) * | 2020-01-02 | 2020-05-29 | 深圳震有科技股份有限公司 | Method for automatically adapting baud rate, intelligent terminal and storage medium | 
| CN112202528A (en) * | 2020-08-17 | 2021-01-08 | 北京海泰方圆科技股份有限公司 | Communication baud rate correction method and device, electronic equipment and storage medium | 
| CN113448907A (en) * | 2021-08-31 | 2021-09-28 | 北京智联安科技有限公司 | Low-power-consumption serial asynchronous transceiver, data receiving method and medium | 
Similar Documents
| Publication | Publication Date | Title | 
|---|---|---|
| CN104360974A (en) | Method and device for automatically adjusting Baud rate of universal asynchronous receiver/transmitter (UART) | |
| CN104915237B (en) | Upgrading, upgrade control method and the equipment of bluetooth equipment firmware program | |
| EP3170090B1 (en) | Systems and methods for chip to chip communication | |
| CN104461972B (en) | A kind of method and apparatus of data signal samples | |
| KR20160140847A (en) | Methods to send extra information in-band on inter-integrated circuit (i2c) bus | |
| WO2017039985A1 (en) | Multiphase clock data recovery for a 3-phase interface | |
| CN110687993A (en) | Controlling power delivery by tunneling messages through USB | |
| CN105790756B (en) | A kind of method and device communicating calibration clock using UART | |
| WO2017065923A1 (en) | Methods to avoid i2c void message in i3c | |
| CN107566088A (en) | The method of adjustment and charging adapter of a kind of baud rate | |
| US9608800B2 (en) | Frequency aided clock recovery based on low speed information exchange mechanism | |
| CN107480088A (en) | Universal serial bus device and applied frequency correction method | |
| CN106484155A (en) | Navigation system and its clock calibration method | |
| KR20140049488A (en) | Transmission interface device capable of calibrating transmission frequency automatically and method thereof | |
| CN108027744B (en) | Data transmission method and mobile terminal | |
| US20170185100A1 (en) | Solving unstable universal asynchronous receive transmit (uart) communication between a power manager and a universal serial bus (usb)-bridge device | |
| US20250077460A1 (en) | Pcie clock detection circuit and method thereof | |
| CN101977051B (en) | Frequency correction circuit and method for automatically correcting frequency | |
| CN104348748B (en) | A kind of method and system of limitation network speed | |
| US8953662B1 (en) | Method and apparatus for baud rate tracking | |
| El Kouche et al. | WSN platform Plug-and-Play (PnP) customization | |
| CN106095717A (en) | A kind of dynamic retardation compensation method and device | |
| CN106201956A (en) | Apparatus and method for automatically correcting clock of amorphous oscillator | |
| CN102739270B (en) | Communication device, control signal generation method, shutter glasses, and communication system | |
| US8898354B2 (en) | Methods and devices for synchronizing to a remotely generated time base | 
Legal Events
| Date | Code | Title | Description | 
|---|---|---|---|
| C06 | Publication | ||
| PB01 | Publication | ||
| SE01 | Entry into force of request for substantive examination | ||
| SE01 | Entry into force of request for substantive examination | ||
| TA01 | Transfer of patent application right | ||
| TA01 | Transfer of patent application right | Effective date of registration: 20190710 Address after: 100097 Jinyuan Times Business Center (Block C) 2E, No. 2 Courtyard, Lanindichang East Road, Haidian District, Beijing Applicant after: The perseverance space Big Dipper (Beijing) development in science and technology Co., Ltd Address before: 201203 West Side of Second Floor, 125 Songtao Road, Zhangjiang High-tech Park, Shanghai Applicant before: Shanghai Jialilue Navigation Co., Ltd. | |
| WD01 | Invention patent application deemed withdrawn after publication | ||
| WD01 | Invention patent application deemed withdrawn after publication | Application publication date: 20150218 |