Understanding UART

Поділитися
Вставка
  • Опубліковано 25 чер 2024
  • This video explains the technical overview of the UART (universal asynchronous receiver/transmitter) serial protocol, including a description of the frame structure and the significance of each frame bit.
    More information on Rohde & Schwarz oscilloscopes: www.rohde-schwarz.com/us/prod...
    Need help with Rohde & Schwarz products & services?
    Contact Us: www.rohde-schwarz.com/us/m4c/...
  • Наука та технологія

КОМЕНТАРІ • 110

  • @AJRobinson
    @AJRobinson 2 роки тому +76

    After watching 6 videos, this one was clear, concise, wasn't 13 minutes long, didn't have awful hand-writing, and included everything I needed to know. Thanks!

  • @jigyasupant453
    @jigyasupant453 Рік тому +18

    Highly appreciate the efforts put in to explain everything in a concise manner. Thanks!!

  • @norvalchenu6102
    @norvalchenu6102 3 роки тому +17

    I found this video very useful. Thank you so much!!

  • @chetananam475
    @chetananam475 3 роки тому +3

    Extremely clear cut explanation!

  • @abhimanyu2842
    @abhimanyu2842 3 роки тому +19

    Small Correction S has value hex value as 0x53 and decimal value as 83.

  • @BALO_BERSERK
    @BALO_BERSERK Рік тому +2

    Excellent video. You clarified many doubts and I understood new concepts.

  • @shvideo1
    @shvideo1 3 роки тому +14

    Excellent video so very clearly explained. This is the best I have seen on this topic. Thank you for covering all the bases.

  • @Someone-fu7wz
    @Someone-fu7wz 3 місяці тому +1

    When someone understands a thing he knows how to explain it clearly! Thank you :D

  • @siricortana9550
    @siricortana9550 5 місяців тому +1

    Short and comprehensive -- amazing video!

  • @occamraiser
    @occamraiser 7 місяців тому +1

    Ahh, happy days of measuring one and a half start bits to work out the width of the clock/pulses to manually read the data from a remote UART. Life was such fun writing process control software in the 1980s :)

  • @Ranmitita
    @Ranmitita 3 роки тому +3

    Great video, thanks for this!

  • @selvakumarr6672
    @selvakumarr6672 Рік тому +1

    The parity bit is more clear now. Thanks.

  • @sung-hyunchoi25
    @sung-hyunchoi25 3 роки тому +4

    THANKS FOR GREAT EXPLANATION!

  • @pascalkreis1524
    @pascalkreis1524 2 роки тому +3

    Very well done. Thank you for this great explanation.

  • @dipsylogic1715
    @dipsylogic1715 3 роки тому +3

    Incredible explanation

  • @limenspicewithshaheenkhali5222
    @limenspicewithshaheenkhali5222 3 роки тому +6

    Thnku so much for such an easy explanation

  • @saumittrasarker7138
    @saumittrasarker7138 3 роки тому +3

    Thank you sir for a clear concept video. best wishes for you.

  • @Annie_EE
    @Annie_EE Рік тому +1

    This is a great introduction

  • @MusaYmc
    @MusaYmc Рік тому +2

    Neat and tidy explanation, tnx!

  • @vinoth3895
    @vinoth3895 4 роки тому +6

    Thank you!

  • @SuperGoodka
    @SuperGoodka 3 роки тому +3

    thanks a lot! its very easy to understand

  • @Basavadi_Sharanaru
    @Basavadi_Sharanaru 2 роки тому +1

    admirably explained sir enjoyed the video
    😍

  • @gyricyace9215
    @gyricyace9215 Рік тому +2

    yeah rohde & schwarz rulezzz ;) pretty good explanation, with few precise questions left to be solved by myself, but i will figure that out soon! keep up the good work! thanks a lot

  • @Autotrope
    @Autotrope 3 роки тому +2

    Great explanation

  • @abheetl9743
    @abheetl9743 Рік тому +2

    Excellent. To the point.

  • @SmoothCode
    @SmoothCode 2 роки тому +1

    Teaching like a GOD.

  • @curtpiazza1688
    @curtpiazza1688 5 місяців тому +1

    Clear concise explanation! 😊

  • @milo7605
    @milo7605 Рік тому +1

    very usefull and concise, thank you!!!

  • @DarkNevrozz
    @DarkNevrozz 3 роки тому +1

    Very well explainded thanks !

  • @aumotion
    @aumotion 10 місяців тому +1

    Nowadays UART often reaches 3 Mbps, i have even used 6 Mbps. Serious SOC have many UARTs peripherals. UART is trivial to handle on the software side. UART is ... GREAT.

    • @pauldenisowski
      @pauldenisowski 9 місяців тому

      UART will always have a special place in my heart :)

  • @saumilkapadia88
    @saumilkapadia88 2 роки тому +1

    Very nice !

  • @suryakrishsaiyan
    @suryakrishsaiyan 2 місяці тому +2

    I have a question here: How do you know if it is a stop bit or a sequence of 1's as data. For example, if i need to send 0xffff, when will UART know that the data has ended?

  • @FabioSpelta
    @FabioSpelta 3 роки тому +4

    EPIC explanation thank you!

  • @egorgreb3828
    @egorgreb3828 2 роки тому +1

    Awesome!

  • @isuckatthisgame
    @isuckatthisgame 2 місяці тому +2

    0% bull shit
    0% advertisements
    50% swag
    50% spot on content

    • @pauldenisowski
      @pauldenisowski 2 місяці тому

      Thanks! Really appreciate the feedback!

  • @Thinkeaic
    @Thinkeaic 14 днів тому

    Best video ever

  • @motivationalcomred
    @motivationalcomred Рік тому +2

    uart(universal asynchronous reciever transmitter) - parity(error detection) - asynchronous so both sender and reciever should transmit at same speeD(baud rate) - tx,rx are registers used in transmitting and recieving data

  • @jcbritobr
    @jcbritobr Місяць тому +1

    Nice stuff.

  • @ThanhThanh-zu3gu
    @ThanhThanh-zu3gu 3 роки тому +1

    thank you

  • @Windy254
    @Windy254 3 місяці тому +1

    Thank you.

  • @ronan5228
    @ronan5228 3 місяці тому +1

    Good video, but a minor correction! 0x52 is listed as ASCII "S" but it is actually 0x53, caused me some confusion while watching :)

    • @pauldenisowski
      @pauldenisowski 2 місяці тому +1

      (laughs) I wish I had a dollar for every person who noticed that :) You're absolutely correct - thanks!

  • @getinthespace7715
    @getinthespace7715 Місяць тому +1

    Awesome.

    • @pauldenisowski
      @pauldenisowski Місяць тому

      Appreciate the feedback - thanks for watching!

  • @sriramkrishnamurthy4473
    @sriramkrishnamurthy4473 2 роки тому +2

    i love u bro amaze

  • @JeremyCook
    @JeremyCook 9 місяців тому +2

    As others have said, very good - not too long, but seems to hit the important details well!

  • @spaceman1328
    @spaceman1328 3 роки тому +1

    More thn basic 🙌

  • @VvtheD3M0N
    @VvtheD3M0N 2 роки тому

    so to go from & bit ASCII to LSB, you just have to reverse the order of the bit?

  • @rahmanmd8460
    @rahmanmd8460 2 роки тому +2

    4:15 its ox53

  • @TheMrR9
    @TheMrR9 6 місяців тому +2

    based

  • @danielvelkov116
    @danielvelkov116 3 роки тому +1

    Can it be used for media(sound,image) transfer from (for e.g) a bluetooth module? What is the cost of implementing this interface in comparison with I^2C, CAN or MLBB?

    • @pauldenisowski
      @pauldenisowski 3 роки тому +1

      My understanding is that a UART is included in most Bluetooth chips for the host-controller interface, with USB being another popular choice. Generally speaking, UART is often cheaper and easier to implement than other protocols but has lower data throughput. That said, the suitability and cost of using one protocol vs. another is a function of many things, so I couldn't really comment on that part of the question without knowing a lot more about the application, other components in the system, etc.

  • @tutankamon31
    @tutankamon31 Рік тому +1

    Thanks for great explanation. 0x52 should be 1010010 in binary system.

    • @pauldenisowski
      @pauldenisowski Рік тому

      Lol - I've had about a half dozen people catch that already :) I guess I should be happy that people are watching the video that closely. Thanks!!!

  • @kirlasharat2714
    @kirlasharat2714 8 місяців тому +1

    actually i have one doubt , inside the UART we have transmitter and receiver . will both transmitter and receiver will work at same clock frequency

    • @pauldenisowski
      @pauldenisowski 2 місяці тому

      In order to UART to work, but transmitter and receiver have to be configured to run at the same speed (asynchronous - no shared clock).

  • @erenoz2910
    @erenoz2910 2 роки тому +1

    okay but how is something like "11111111" transmitted? how does the receiver tell the data apart from the stop bit?

    • @igornedashkivskyi1472
      @igornedashkivskyi1472 2 місяці тому

      You are always have "start" bit for this purpose which are "0" (low level one), this is kind of something change or begin at the line.

  • @ozonewagle
    @ozonewagle Місяць тому

    I have some confusions.
    1. The LSB is indicated first in waveform but actually receiver is receiving the MSB first.
    2. What kind of line coding techniques are used; it is told that NRZ-I is used but the waveforms just represent Unipolar NRZ.
    3. How cannot the receiver misinterpret as the end of data if consecutive 1's is present in the data which is similar as stop bits?

    • @pauldenisowski
      @pauldenisowski Місяць тому

      1. The order of the bits (LSB or MSB) has to be agreed upon by the transmitter and receiver (and clearly must match at both ends)
      2. NRZ is the most common type of line coding used
      3. The transmitter and receiver must be configured to use the same baud rate, number of data bits, parity type, etc. From these two pieces of information, it is possible to derive the length of the frame (number of bits) and distinguish between a payload "1" and the stop bit.

  • @maxint2680
    @maxint2680 3 роки тому +3

    The stop bit just looks like a normal "1" bit. How to distinguish a stop bit from a useful "1" bit, or a useful "1" bit from a stop bit? It is not explained in the video - I did not see the use of any prepositioned "length field" or "escape sequence". Can anyone help me with this?

    • @maxint2680
      @maxint2680 3 роки тому +3

      After doing some searching, I believe the frame length is also pre-configured just like the baud rate. (Please let me know if I am wrong)

    • @pauldenisowski
      @pauldenisowski 3 роки тому +7

      @@maxint2680 Yes, that's correct: Normally in serial communications, you have to explicitly specify (i.e. configure) certain parameters, which need to match on both ends of the connection. These are the speed (baud rate - e.g. 9600), the number of data bits (7 or 8, usually), the number of stop bits (almost always 1), and the parity type (none, even, or odd). So if you know these values, you can derive the length of the frame. If you use PuTTY as a terminal program, these values can be found under "Connection -> Serial"

    • @maxint2680
      @maxint2680 3 роки тому +2

      @@pauldenisowski Detailed explanation. Thanks!

  • @battelground1526
    @battelground1526 3 роки тому +2

    i have not understand that parity bit.means if data bits are 4-1s then parity bit sould be low(0).

    • @pauldenisowski
      @pauldenisowski 3 роки тому +1

      Depends on the type of parity - even versus odd. In even parity, the number of ones in the user bits + parity bit must be even, so if you send 1 1 1 1 and are using even parity, the parity bit would be zero. If you were using odd parity, the total number of ones would need to be odd, and 1 1 1 1 would require a one as the parity bit.

  • @Ankit.max.
    @Ankit.max. 11 місяців тому

    we are not mention in code ,that type of method so where we use that type of method

  • @abandxz
    @abandxz 3 роки тому

    I'm facing problems with one of device , where the display required 7-n-1 setting but for the input need 8-n-1

    • @pauldenisowski
      @pauldenisowski 3 роки тому +1

      7N1 means seven bits, no parity bit and one stop bit, whereas 8N1 means eight bits, no parity bit and one stop bit, so these settings are most likely incompatible. If one of the endpoints is a configurable terminal program (like Hyperterm, PuTTY, etc.) you should be able to configure these parameters.

  • @devided4299
    @devided4299 Рік тому +1

    Aren't there supposed to be 8 data bits, for 8 bits equal to 1 bite?

    • @pauldenisowski
      @pauldenisowski Рік тому

      Typically the user data is 8 bits long. That said, UART doesn't specify how long the payload should be. I still remember when 7-bit ASCII was the norm in serial text transmission.

  • @sudhansumtripathy
    @sudhansumtripathy Місяць тому +1

    can we have a FlexRay tutorial for the braking of M Benz

    • @pauldenisowski
      @pauldenisowski Місяць тому +1

      I'm working on some automotive protocol presentations that should be ready later this year :)

  • @watermark9282
    @watermark9282 2 місяці тому

    i have a question imagine a data with all 1's then how does the receiver identify the stop bit

    • @pauldenisowski
      @pauldenisowski Місяць тому

      UART requires that both sides be configurated with the same bit rate and the number of data bits (this is fixed for all UART frames exchanged and cannot be "signaled"). So the receiver will know how long the frame is and thus can identify the stop bit.

  • @rizwanrazvi-tl1qg
    @rizwanrazvi-tl1qg Рік тому

    hi...I want take 8bits data and 2 bits parity in design .Is it possible?

    • @pauldenisowski
      @pauldenisowski Рік тому

      Sorry, not with "standard" UART. Is there a reason why you would want a second parity (well, error-checking) bit?

  • @mythix8070
    @mythix8070 2 роки тому +1

    I'm a bit late but can I have the presentation I need it for school

  • @Toto-cm5ux
    @Toto-cm5ux Рік тому +1

    For people who doesn't understand math, S is 0x53 not 0x52

    • @pauldenisowski
      @pauldenisowski Рік тому +1

      Actually, it's for people who can't type :) The binary is correct :)

  • @sanjaysethi7033
    @sanjaysethi7033 8 місяців тому +1

    There’s a very silly error here:
    ASCII for “S” = 0x53 NOT 0x52!!

    • @pauldenisowski
      @pauldenisowski 4 місяці тому

      Yep, must have fat-fingered that one (binary is correct). Thanks!

  • @feelpainacceptpain
    @feelpainacceptpain Рік тому

    Dbit

  • @JohnJohn-gy2st
    @JohnJohn-gy2st Рік тому +1

    Hello

  • @jacktorrance2336
    @jacktorrance2336 4 місяці тому +1

    0x52 != 1010011

    • @pauldenisowski
      @pauldenisowski 2 місяці тому

      Thanks - you're absolutely right :)

  • @Estuan
    @Estuan 3 роки тому +1

    Pónganle subtitulos al español :c

  • @y_x2
    @y_x2 Місяць тому

    UART need 3 wires not 2!!! UART are rated in bit per second NOT baud rate!!! Two stop bits is never used for at least 60 years...

    • @pauldenisowski
      @pauldenisowski Місяць тому

      Yes, more than one stop bit is extremely rare. But I'm not sure what you mean by UART needing 3 wires - could you clarify? Thanks!

    • @zxchtl
      @zxchtl Місяць тому

      @@pauldenisowskicould be referencing a ground wire