Неизвестный UART: микросхемы

531451d01e39c0fc0d49400c153277d5.png

  1. Неизвестный UART: теория

  2. Неизвестный UART: микросхемы

Как было сказано в предыдущей статье, UART не является формализованным стандартом и, следовательно, при его использовании имеет смысл опираться на практику реализаций данного протокола в различных микросхемах.
В данной статье будут рассмотрены микросхемы мостов USB‑UART различных производителей, как с точки зрения особенностей поддержки протокола, так и с точки зрения временных/электрических характеристик, а также иных, в том числе не‑электронных соображений.

Производители USB-UART

Есть ряд компаний, для которых мосты USB‑UART являются одним из основных/важных направлений деятельности. Это такие компании, как FTDI, Silicon Labs, Prolific, Cypress (которую недавно купил Infineon), Nanjing Qinheng Microelectronics (владелец бренда WinChipHead), MaxLinear, Microchip. Также существует пара крупных производителей микросхем (Texas Instruments и Maxim Integrated; последнюю недавно купила компания Analog Devices), у которых номинально имеются свои мосты USB‑UART, однако этот вид микросхем не является для них приоритетным.

Линейки мостов USB‑UART первой группы производителей характеризуются

  • широким набором корпусов

  • наличием как медленных и бюджетных (3 Мбит/с и менее), так и быстрых (12 Мбит/с) мостов

  • тактированием как от внутренних генераторов частоты, так и внешних резонаторов

  • наличием встроенных регуляторов напряжения (LDO) для понижения 5‑вольтового питания USB до 3,3 В или ниже (обычно документация прямо сообщает, что мощности встроенного LDO хватит только на сам мост)

Мосты второй группы производителей являются, скорее, уникальными изделиями. Так, MAX3349E от Analog Devices является гибридом двух микросхем в одном корпусе: микросхемы физического уровня USB и, собственно, моста USB‑UART. А микросхема TUSB3410VF от Texas Instruments является, по сути, микроконтроллером с модулем USB, а в мост USB‑UART его превращает специальная прошивка от производителя. Её стоимость сопоставима со стоимостью полноценного микроконтроллера, а также требует внешнего тактирования и внешнего питания 3,3 В. Также к данной группе можно условно отнести и различные микроконтроллеры (вроде STM32F070) общего назначения с модулями USB, которые можно программно превратить в мост USB‑UART.

Цена

Сравнение микросхем по цене является не вполне однозначным действием. Так, если использовать в качестве эталона цен только цены дистрибьютора Mouser Electronics, то микросхемы компаний Prolific и Nanjing Qinheng не попадут в таблицу, ввиду того, что они не продаются у данного дистрибьютора. А цена на стоковых площадках вроде ChipMall сильно зависит от количества микросхем в распродаваемой партии и наличия альтернативных предложений.

Другим источником ценовых аномалий являются микросхемы, снимаемые с производства. Так, не рекомендованный для новых разработок мост FT232RL стоит дороже, чем меньший по размерам и в разы более быстрый мост XR21V1410IL16F.

Поэтому таблица сравнения будет следующая:

Сравнение стоимости различных мостов USB-UART

Сравнение стоимости различных мостов USB-UART

Корпус

Сравнение микросхем по габаритам корпуса также неоднозначно. При габаритах посадочного места разъёма USB‑B («квадрат») 12×16 мм не так уж и важно, имеет ли микросхема корпус SSOP-20 (7×7 мм) или же QFN-16 (4×4 мм).

Кроме того, микросхема с меньшим корпусом может занять бо́льшую площадь на плате за счёт необходимости установки внешнего регулятора напряжения 5,0 В в 3,3 В, а также кварцевого резонатора. А может и не занять. Так, при использовании микросхемы на плате с ПЛИС, скорее всего, там уже будут шины питания с необходимыми напряжениями, и встроенный регулятор напряжения окажется избыточным. К тому же, ПЛИС сама может оказаться подходящим источником тактовых сигналов для моста.

Сравнение габаритов корпусов различных мостов USB-UART

Сравнение габаритов корпусов различных мостов USB-UART

Более детальный взгляд

В данном обзоре не будут подробно рассматриваться по‑своему интересные мосты, и вот почему:

  • TUSB3410VF и MAX3349E. При весьма скромных характеристиках скорости, и выбивающегося из общей массы мостов дополнительного функционала, первый мост является рекордсменом по цене, а второй отсутствует в продаже.

  • FT230XQ и FT2232H.
    Мост FT2232H — это очень распространённый и универсальный мост. Помимо UART, данная микросхема поддерживает ещё 7 различных протоколов. И так как среди них есть протокол JTAG, то FT2232H стала ядром для множества программаторов/отладчиков и поддерживается по умолчанию целым рядом популярных программных продуктов, работающих с JTAG.
    А FT230XQ примечателен тем, что это самый маленький мост USB‑UART от компании FTDI (QFN‑16, 4×4 мм).
    Однако, если рассматривать все мосты компании FTDI, не хватит ни объёма статьи, ни объёма всего цикла. У них слишком широкая номенклатура микросхем. И тем не менее, далее будут рассмотрены два чипа от FTDI.

  • MCP2200‑I/SO и MCP2221A‑I/ML. Мосты компании Microchip — одни из самых медленных из производящихся в настоящее время. Однако определённого внимания заслуживает мост MCP2221A‑I/P. Он самый большой по размерам корпуса (DIP‑14, 19×8 мм).

Для двенадцати различных мостов, включая мост на основе микроконтроллера STM32F070F6P6, будет проведено более детальное сравнение:

Список демоплат с мостами USB-UART, рассматриваемых в статье

Список демоплат с мостами USB-UART, рассматриваемых в статье

ea56c17bbf066b6489de8abb8a06d369.pngb42ce213b1264c1a8e55ac54f269a920.png4161c2a88d578b9b95667cec4ca7cb4b.png

Драйверы: CDC и VCP

Рассмотрим ряд моментов, касающихся программной части мостов USB‑UART, а именно драйверов и протокола USB.

Согласно стандарту USB, любое устройство должно быть сделано так, чтобы к моменту подключения линия D+ была подтянута резистором 1,5 кОм к напряжению +3,3 В (несущественное замечание: для режима LowSpeed подтягиваться должна линия D−). Компьютер, обнаружив при подключении устройства, что линия D+ подтянулась, запрашивает у устройства так называемый дескриптор — описание устройства, выполненное в некоторой стандартизованной для всех устройств USB форме. Этот дескриптор, в частности, содержит коды класса и подкласса устройства.

Список классов и подклассов устройств USB является частью стандарта. Он, однако, представляет из себя не столько стройную, последовательную и логичную классификацию, сколько набор исторических шрамов, полученных стандартом в ходе своего развития.
Примеры:

  • Несмотря на наличие классов «Audio» (код класса 01h) и «Video» (код класса 0Eh) существует класс «Audio/Video Devices» (код класса 10h)

  • Рекламные щиты вынесены в отдельный класс «Billboard Device Class» (код класса 11h), а, к примеру, ИК‑устройства являются подклассом «IrDA Bridge device», спрятанным внутрь класса «Application Specific» (код класса FEh)

  • Классы «Miscellaneous» (код класса EFh) и «Application Specific» (код класса FEh), по сути, оба являются разделом «Прочее». Тем не менее оба присутствуют в списке классов вместе со своими подклассами

  • Имеется отдельный класс «Printer» (код класса 07h), а отдельных классов для клавиатуры и мыши нет. Они вместе со многими другими устройствами помещены в класс «Human Interface Device» (код класса 03h)

  • Сам класс «Human Interface Device» наделён настолько обширным функционалом, что в него умещаются даже те устройства, которые в принципе с человеком никак не взаимодействуют. Причём производители помещают эти устройства в класс «Human Interface Device», несмотря на наличие такого класса, как «Vendor Specific» (код класса FFh)

Есть расхожее утверждение, что мосты USB‑UART относятся к классу устройств «Communication Device Class» (CDC). Отчасти это так. Правда, с достаточно большим «но!». Если мы взглянем на список подклассов класса CDC…

Список подклассов устройств класса CDC

Список подклассов устройств класса CDC

…то увидим, что здесь нет ничего, напоминающего UART. Если же мы ознакомимся с документом USBPSTN1.2 из колонки «Reference», то заметим две важные вещи:

  • Данный документ описывает телефонные модемы (PSTN — «Public Switched Telephone Network»)

  • В самом его конце, в маленьком примечании говорится:

A USB modem may provide means to accommodate common functions performed on a 16550 UART. For more information, see Section 3.2.2.1, «Abstract Control Model Serial Emulation.»

В предыдущей статье цикла была упомянута микросхема PC16550D, крайне популярная в конце 80‑х и реализующая функционал UART‑а. В цитате речь именно о ней.

То есть UART, выросший из телефонных модемов 60‑х годов, к концу 90‑х (когда формировался стандарт USB) не успел от них уйти далеко. И в рамках стандарта стал неким дополнительным функционалом при телефонных модемах. Спустя всего 8–10 лет основной функционал многих подклассов CDC окончательно стал сугубо историческим, но UART‑у уже не отделаться от своего телефонно‑модемного прошлого :)

В частности, это выражается в любопытных артефактах старины

В файле usbd_cdc_if.c из стандартной библиотеки для современных микроконтроллеров STM32, можно встретить упоминание (бездумно скопированное из документа USBPSTN1.2) не только 5…8‑битных, но и… 16‑битных символов:

static int8_t CDC_Control_FS(uint8_t cmd, uint8_t* pbuf, uint16_t length)
{
  UART_HandleTypeDef uart_handler;
  switch(cmd)
  {
    case CDC_SEND_ENCAPSULATED_COMMAND:
	//
    break;
<...>  /*******************************************************************************/
  /* Line Coding Structure                                                       */
  /*-----------------------------------------------------------------------------*/
  /* Offset | Field       | Size | Value  | Description                          */
  /* 0      | dwDTERate   |   4  | Number |Data terminal rate, in bits per second*/
  /* 4      | bCharFormat |   1  | Number | Stop bits                            */
  /*                                        0 - 1 Stop bit                       */
  /*                                        1 - 1.5 Stop bits                    */
  /*                                        2 - 2 Stop bits                      */
  /* 5      | bParityType |  1   | Number | Parity                               */
  /*                                        0 - None                             */
  /*                                        1 - Odd                              */
  /*                                        2 - Even                             */
  /*                                        3 - Mark                             */
  /*                                        4 - Space                            */
  /* 6      | bDataBits  |   1   | Number Data bits (5, 6, 7, 8 or 16).          */
  /*******************************************************************************/
    case CDC_SET_LINE_CODING:
	//
    break;
<...>
  default:
    break;
  }
  return (USBD_OK);
}

Cтандартный драйвер usbser.sys, управляющий мостамиUSB‑UART, не загружался автоматически при подключении нового устройства вплоть до Windows 8.1 включительно. В настоящий же момент для автоматической загрузки данного драйвера устройство USB должно сообщить в дескрипторе, что оно относится к классу CDC (код класса 02h) и подклассу Abstract Control Model (код подкласса 02h).

Однако, существует проблема. Производители мостов USB‑UART стремятся наделить их дополнительным функционалом. К примеру, 8‑битным портом GPIO, дополнительными интерфейсами SPI/I2C/JTAG, возможностью сохранить определённые настройки внутри самой микросхемы моста (запрограммировав при этом её через USB) и так далее. Разумеется, весь этот функционал не поддерживается стандартным драйвером usbser.sys. Поэтому производители задают своим мостам класс устройства Vendor Specific (либо Miscellaneous) и выпускают собственные драйверы. Эти драйверы реализуют дополнительный функционал, а также способны создать в операционной системе виртуальный COM-порт (Virtual COM Port — VCP), который с точки зрения приложений работает точно так же, как и COM-порт, созданный драйвером usbser.sys.

Сравнение типов драйвера исследуемых мостов

Сравнение типов драйвера исследуемых мостов

В данной таблице есть три строчки, представляющие особый интерес:

  • STM32F070F6P6. Так как данный микроконтроллер превращается в мост USB‑UART за счёт прошивки, скомпилированной из программного кода, то можно настроить его так, чтобы операционная система предоставляла ему именно стандартный драйвер usbser.sys.

  • CY7C65213‑28PVXI. Производитель данного моста предусмотрел возможность использования как стандартного драйвера, так и драйвера производителя. Для внесения определённых изменений в реестр и дальнейшего использования usbser.sys производитель предоставляет специальный установочный файл CyWinCDC.inf и инструкцию. Однако производитель предупреждает, что драйвер от Microsoft не позволит развить максимально возможную для данного моста скорость передачи данных и использовать его дополнительные функции.

  • FT260Q. Данный мост определяется системой как устройство класса HID. С одной стороны, для данного класса имеется стандартный драйвер. С другой стороны, за счёт обширного функционала, которым наделён данный класс, возможно реализовать взаимодействие компьютера с устройствами абсолютно любого назначения. Однако, в силу всё той же разносторонности HID, для эффективного написания прикладного программного обеспечения требуется библиотека LibFT260.dll от производителя. Библиотека является закрытой и в некотором смысле является тем же самым драйвером.

Уместно упомянуть череду скандалов, связанных с драйверами мостов USB‑UART

В 2011 году компания Prolific выложила новый драйвер для своих мостов PL2303 взамен старого. И внезапно мосты разделились на те, что работают с новым драйвером и те, что нет. Prolific утверждала, что это её маленький крестовый поход против контрафактных чипов и напоминала, что только она имеет право распространять свои драйверы. А скачивать их друг у друга или делиться ссылками — незаконно.

Please be warned that counterfeit (fake) PL-2303HX (Chip Rev A) USB to Serial Controller ICs using Prolific’s trademark logo, brandname, and device drivers, were being sold in the China market. Counterfeit IC products show exactly the same outside chip markings but generally are of poor quality and causes Windows driver compatibility issues (Yellow Mark Error Code 10 in Device Manager). We issue this warning to all our customers and consumers to avoid confusion and false purchase.

Please be warned that selling counterfeit products are illegal and punishable by civil and criminal courts according to the trademark, copyright, and intellectual properties laws and regulations. Prolific will take proper and severe actions to cease and confiscate these counterfeit products. Prolific also prohibits the distribution of any PL-2303 drivers (including download links) without written permission from Prolific.

В сообществе, правда, появилась и альтернативная точка зрения, что в данном случае имеет место быть попытка «выдать баг за фичу». Что инженеры Prolific потеряли некоторые компетенции в части написания драйверов. А когда, наставив в коде костылей, они наконец запустили новый драйвер и выложили его в публичный доступ, то он самым позитивным (для Prolific) образом отказался работать с контрафактными изделиями.

Как бы то ни было, в 2014 году происходит самый известный случай подобного рода. Компания FTDI выпустила драйвер, который по ряду недокументированных особенностей распознавал контрафактную микросхему и изменял в её встроенной памяти PID — идентификатор продукта из пары VID/PID (Vendor ID/Product ID). В результате микросхема переставала распознаваться не только новым драйвером, но и всеми предыдущими. Хотя подобное действие имело обратимый характер (в сети в скором времени появились инструкции по «раскирпичиванию» мостов FTDI), оно было воспринято сообществом крайне негативно. По некоторым сообщениям, «вишенкой на торте» была попытка протолкнуть данный драйвер в ядро Linux.

Спустя всего два года появились сообщения, что FTDI сделало «второй подход к снаряду». По словам очевидцев, драйвер 2016 года не «окирпичивал» мост, но начинал периодически рассылать случайные символы по линии TX. Ещё пикантней ситуацию делает возможность тихой установки драйверов. Как написано в инструкции FTDI Driver Installation Guide for Windows 10/11:

3 Installing CDM Drivers

To install CDM drivers for an FTDI device under Windows 10/11, follow the instructions below: Connect the device to a spare USB port on your PC.

3.1 Windows Update

If there is an available internet connection, Windows 10/11 will silently connect to the Windows Update service and install any suitable driver it finds for the device.

Назначение выводов

Типовая схема подключения моста USB-UART

Типовая схема подключения моста USB-UART

Количество выводов моста USB‑UART, которые должны присутствовать в обязательном порядке, равно шести: линии D+/D− интерфейса USB, линии Tx/Rx интерфейса UART, питание и земля.

Дополнять этот минимальный набор можно достаточно широко. Так, у мостов MCP2221A имеются встроенные аналого‑цифровые и цифро‑аналоговые (!) преобразователи, входы (для ЦАП — выходы) которых можно назначить на выводы моста. В рамках же специфики UART субъективно можно выделить следующие дополнительные выводы:

  • VREGIN/VREGOUT. Некоторые мосты снабжают регуляторами напряжения 5,0 В → 3,3 В для возможности построения законченного устройства на базе моста без использования дополнительных микросхем питания. Для корректной работы подобных регуляторов, на их входе и выходе должны стоять достаточно большие ёмкости. Поэтому, даже в случае, если шины питания внутренней логики и выходных буферов соединены с выходом регулятора внутри корпуса моста, данный выход всё равно соединяется с отдельным выводом микросхемы, чтобы обеспечить требуемую ёмкость внешним конденсатором. Именно так, к примеру, сделан мост MCP2221A‑I/P. Кроме того, выход VREGOUT в данном мосте называется VBUS, хотя обычно вывод с подобным названием имеет иной функционал.

  • VI/O. Внутренняя логика мостов работает при фиксированном напряжении питания. Однако для сопряжения моста с максимально возможным количеством типов микросхем без использования дополнительных трансляторов уровня сигнала, в некоторых мостах предусмотрена возможность отдельного питания выходных буферов.

  • VBUS. Мосты могут применяться в портативных устройствах с питанием от аккумулятора. И напряжение на входе питания моста может присутствовать независимо от того, подключен ли интерфейс USB к устройству или нет. В последнем случае является уместным гарантированное отключение моста с целью сберечь заряд аккумулятора. Вывод VBUS позволяет при помощи резистивного делителя определять наличие напряжения на линии +5 В интерфейса USB и отключать устройство, если этого напряжения на линии нет. Иногда данный вывод устойчив к входному напряжению +5 В и шину питания можно подключать к нему напрямую.

  • nRST. Позволяет устройству отключить мост при необходимости. Соответственно, если устройство состоит только из моста, данный вывод (как и вывод VBUS) должны быть соответствующим образом подтянуты. В некоторых микросхемах (например, в CH340T этот вывод называется NOS#) имеется внутренняя подтяжка, позволяющая обойтись без подключения данного вывода куда бы то ни было. В других мостах без внешней подтяжки микросхема не запустится. Особенно много внешних подтяжек нужно мосту FT260Q.

  • OSCI/OSCO. Микросхемы мостов могут иметь как внутренний источник тактирования на основе RC-генератора, так и внешний на основе кварцевого резонатора. В большинстве случаев доступен лишь один из этих вариантов. То есть если данные выводы имеются, они должны быть подключены к кварцевому резонатору (обычно его резонансная частота равна 12 МГц). Иначе мост не заработает. Исключение — FT232RL, у него доступны оба варианта тактирования. Если его выводы OSCI/OSCO не подключены к внешнему резонатору, он автоматически работает от внутреннего генератора. Также, при наличии в устройстве микросхемы, способной выдавать опорный сигнал с подходящей частотой, можно не использовать кварцевый резонатор, а завести этот сигнал на вход OSCI моста USB‑UART.

  • LED_TX/LED_RX. Данные выводы применяются для индикации передачи и приёма отдельных символов. Выводы работают в режиме open‑drain. То есть когда происходит приём/передача очередного символа, они соединяются с землёй. Если приём/передача не ведётся, то они находятся в состоянии HiZ — отрезаны как от земли, так и от питания. Получается, чтобы светодиоды светили как надо, их необходимо расположить между питанием и данными выводами, катодом («стрелкой») в вывод.

Количество и функционал выводов различных мостов может быть весьма обширен и включать в себя такие дополнительные линии, как RTS/CTS и DTR/DSR. Однако, говоря субъективно, для задачи соединения ПЛИС с компьютером через мост USB‑UART, знание о назначении этих выводов не даст никаких преимуществ перед незнанием.

Сравнение наборов типовых выводов у исследуемых мостов

Сравнение наборов типовых выводов у исследуемых мостов

Временные характеристики: погрешность делителя

Как уже говорилось, документа под названием «стандарт UART», в котором были бы прописаны стандартные битрейты, не существует. Однако некоторым подобием стандарта может служить список констант из заголовочного файла winbase.h для WinAPI:

#define CBR_110 110
#define CBR_300 300
#define CBR_600 600
#define CBR_1200 1200
#define CBR_2400 2400
#define CBR_4800 4800
#define CBR_9600 9600
#define CBR_14400 14400
#define CBR_19200 19200
#define CBR_38400 38400
#define CBR_56000 56000
#define CBR_57600 57600
#define CBR_115200 115200
#define CBR_128000 128000
#define CBR_256000 256000

Мосты USB‑UART получают заданный битрейт путём деления фиксированной опорной частоты тактового генератора. В некоторых случаях формула для вычисления битрейта приводится в документации в явном виде. К примеру, у моста FT232RL битрейт равен:

BAUD= \frac {3000000}{(n+x)}

где «n» — это целое число в интервале от 2 до 16384, а «x» принимает значения от 0 до 0,875 с шагом 0,125.

Если взять «n», равное 312, и «x», равный 0,5, то получится битрейт, строго равный 9600 бит/с. Однако, попытка подобрать делители для другого стандартного битрейта — 115200 бит/с — будет не столь успешной. Ближайшим достижимым значением окажется 115384,6 бит/с. Погрешность кажется небольшой, всего 0,16%. Но она будет накапливаться с каждым битом. И если в символе 8 бит данных, то к последнему биту она составит 1,44%.

Сравнение принципов формирования делителя частоты у моста FT232RL и PL2303TA

Сравнение принципов формирования делителя частоты у моста FT232RL и PL2303TA

Формула вычисления битрейта приводится далеко не для всех мостов. Однако в некоторых случаях можно проследить принцип, по которому это деление происходит. Так, в мостах PL2303TA и CH340T, по всей видимости, имеется фиксированный делитель на 13, подключаемый делитель на 3 и множество D‑триггеров, которыми очень удобно делить частоту на 2. Данный подход создаёт фиксированную погрешность в 0,16% для длительности каждого бита и не позволяет задавать произвольные битрейты. Но он проще с точки зрения схемотехники.

Механизм деления тактовой частоты при помощи D-триггеров

Механизм деления тактовой частоты при помощи D-триггеров

Также, помимо погрешности от деления, на точность битрейта влияет номинал опорного генератора и ряд иных особенностей конструкции мостов. Поэтому уместно будет экспериментально измерить погрешности номинальных значений для стандартных битрейтов.

Накопление погрешности длительности бита за символ

Накопление погрешности длительности бита за символ

В таблицах ниже указаны отношения накопленной за весь символ погрешности к длительности последнего бита в процентах для передачи в конфигурации 8N1 (8 бит данных, бита чётности отсутствует, один стоп-бит).

b48cf7bf8fc87cd9c40116fda0de9cd5.pngbb1e0e3316a873c226a17d51be620e2c.png17a22019ca77abe82cdd5fdce338fdfa.pngcc53592a954ac44f19b73a2ab581032d.png

Временные характеристики: случайная погрешность

Помимо систематической составляющей погрешности временных параметров имеется также и случайная, обусловленная погрешностью опорной частоты.

Здесь следует сказать несколько слов про нормальное распределение. Оно характеризуется математическим ожиданием (или иначе говоря, средним значением) и стандартным отклонением. Стандартное отклонение отвечает за уровень разброса значений. Чем оно меньше, тем меньше разброс. Так же, квадрат стандартного отклонения имеет своё собственное название — «дисперсия». Или же дисперсия отвечает за разброс значений, а квадратный корень из неё имеет своё название — «стандартное отклонение».

Нормальные распределения с различным математическим ожиданием μ и различным стандартным отклонением σ

Нормальные распределения с различным математическим ожиданием μ и различным стандартным отклонением σ

Если имеется нормально распределённая случайная величина с известным математическим ожиданием μ и стандартным отклонением σ, то можно найти допуск, из которого случайная величина будет выходить с заданной вероятностью. Так, из допуска в μ ± σ нормально распределённая случайная величина выходит с вероятностью 31,74%. Из знаменитого допуска μ ± 3σ — с вероятностью 0,28%. Для вероятности выхода «один-на-тысячу» допуск будет равен μ ± 3,2905σ. Для «один-на-миллион» — μ ± 4,8916σ.

Влияние ширины допуска, выраженного в стандартных отклонениях, на вероятность выхода нормально распределённой величины из этого допуска

Влияние ширины допуска, выраженного в стандартных отклонениях, на вероятность выхода нормально распределённой величины из этого допуска

Математическое ожидание суммы двух нормально распределённых величин равно сумме их математических ожиданий, что в целом интуитивно понятно.

Со стандартным отклонением всё несколько сложнее. При суммировании двух случайных, нормально распределённых величин складываются квадраты стандартных отклонений, то есть дисперсии.

В контексте передачи бит, если второй фронт старт-бита «дрожит» с относительным стандартным отклонением σ/T, то фронт N-го бита (если за первый бит считать старт-бит) будет «дрожать» относительно длительности суммы длительностей всех предыдущих битов, как указано в этой формуле:

\frac{\sqrt{N}σ}{NT}

А относительно длительности последнего бита, последний фронт будет «дрожать» как указано в этой формуле:

\frac{\sqrt{N}σ}{T}«Дрожание» последнего фронта символа в сравнении с «дрожанием» первого фронта символа

«Дрожание» последнего фронта символа в сравнении с «дрожанием» первого фронта символа

Нельзя сказать, что полная вероятность хотя бы одной ошибки в символе по причине «сползшего» фронта в любом из N бит в точности равна вероятности выхода за заданный интервал именно в последнем, N-ом бите. Однако с уменьшением целевой вероятности ошибки, полная вероятность достаточно быстро стремится именно к вероятности выхода из допуска последнего бита. Так, при вероятности ошибки в последнем бите, равной 1×10−3, полная вероятность ошибки будет равна 1,191×10−3.

Рассмотрим реальное распределение длительности символов. Зададим битрейт, равный 1200 бит/с, длину символа — 8 бит, без бита чётности, стоп‑бит — одинарный. Если передать символ, содержащий данные 00h (то есть девять логических нулей, включая старт‑бит) с такими настройками, то номинально линия TX должна оказаться в состоянии логического нуля на 7500 мкс. При этом длительность одного бита будет равна 833,333 мкс. Если с подобными настройками попытаться выдать несколько миллионов символов, к примеру, через мост CH340N, то получится следующее распределение:

Нормально распределённая длительность символа у моста CH340N

Нормально распределённая длительность символа у моста CH340N

Если целевым показателем уровня ошибок будет, например, 1 ошибка на 1012 символов, то допуск по длительности, который необходимо обеспечить, будет примерно ±7σ. Или ±11,77 мкс для данного распределения. Если в процентах от длительности одного бита, то ±1,41%.

Следует, однако, заметить, что реальные источники тактирования мостов далеко не всегда имеют нормально распределённый разброс частоты. Так, распределение длительности символа для моста FT232RL, работающего от внутреннего RC‑генератора, будет иметь характерный пик, торчащий слегка сбоку из «колокола» нормального распределения. Предположительно, данный пик возникает в результате подстройки внутренней системы тактирования моста по синхроимпульсам, идущим в начале каждого пакета USB:

Распределение длительности символа у моста FT232RL (смещённый пик уходит далеко за пределы графика)

Распределение длительности символа у моста FT232RL
(смещённый пик уходит далеко за пределы графика)

Тем не менее, можно грубо сравнить точностные характеристики систем тактирования мостов, полагая, что частота синхроимпульсов, выдаваемых ими, распределена нормально. Ниже в таблице приведен допуск в процентах от длительности одного бита при уровне ошибок «одна ошибка в год при непрерывной передаче данных и битрейте 9600 бит/с»:

Сравнение точности системы тактирования у исследуемых мостов

Сравнение точности системы тактирования у исследуемых мостов

Электрические характеристики

При передаче данных, на стороне ПЛИС мост USB‑UART должен своевременно устанавливать заданные напряжения логического нуля или логической единицы. Если с номинальным напряжением логической единицы всё достаточно прозрачно — данную характеристику можно прочесть в технической документации — то со своевременностью всё несколько сложнее.

Ниже приведены осциллограммы передачи старт‑бита мостами FT260Q и XR21V1410IL16 через двухметровый 50‑омный коаксиальный кабель при скорости 12 Мбит/с. Также осциллограммы передачи старт‑бита мостами PL2303TA и FT232RL через тот же кабель при скорости 3 Мбит/с.

Осциллограммы передачи единичного бита для мостов FT260Q и XR21V1410 при 12 Мбит/с

Осциллограммы передачи единичного бита для мостов FT260Q и XR21V1410 при 12 Мбит/с

Осциллограммы передачи единичного бита для мостов PL2303TA и FT232RL при 3 Мбит/с

Осциллограммы передачи единичного бита для мостов PL2303TA и FT232RL при 3 Мбит/с

Налицо проблемы с согласованием импедансов (подробнее о согласовании вот в этом цикле), которые вполне способны привести к ошибкам в передаче данных. Хотя на реальной плате импеданс дорожек будет ближе к 100 Омам (то есть чуть ближе к выходному сопротивлению выходных буферов данных мостов), а длина в разы, а то и на порядки меньше, тем не менее в отдельных пограничных случаях рассогласование может сыграть свою негативную роль.

Как видно на графиках, для некоторых микросхем выходное сопротивление будет сильно различно для восходящего и нисходящего фронта. Соответственно, выбор импеданса дорожки станет компромиссом. Подобное различие объяснимо структурой выходного буфера, который условно можно считать логическим элементом НЕ. В таком буфере за восходящий и нисходящий фронты отвечают транзисторы разных типов проводимости (NMOS и PMOS) и их характеристики могут значительно отличаться.

Направление тока через транзисторы выходного буфера при передаче логической единицы и логического нуля

Направление тока через транзисторы выходного буфера
при передаче логической единицы и логического нуля

Наиболее полно вольт-амперные и временные характеристики выходных буферов приводятся в моделях IBIS (подробнее о моделях IBIS и том, как ими пользоваться вот в этой статье). Однако корректное снятие показаний для этих моделей является дорогостоящим процессом, за результаты которого (даже в случае предварительного отказа от последствий) так или иначе компания‑производитель несёт репутационную ответственность. Поэтому далеко не все производители предоставляют модели IBIS.

Тем не менее, возможно замерить некое усреднённое значение внутреннего сопротивления выходного буфера, которое окажется полезным, если не для точной симуляции, то хотя бы для качественной оценки согласования на реальной плате.

Электрические характеристики выходного буфера линии Tx у исследуемых мостов

Электрические характеристики выходного буфера линии Tx у исследуемых мостов

Оверсемплинг и коррекция ошибок

Традиционно, оверсемплинг, как характеристика приёмника сигнала UART, указывается только для модулей UART в микроконтроллерах. Соответственно, из всех исследуемых мостов данная характеристика указана лишь для STM32F070. Однако оценить оверсемплинг и, в целом, принцип работы приёмника UART, возможно при помощи специальных тестовых сигналов.

Представим, что приёмник UART исследуемого моста имеет 8-кратный оверсемплинг, а логическое значение бита фиксируется на четвёртом семпле. Допустим, возможно осуществить передачу битов символа UART с точностью временны́х параметров значительно большей, чем временная точность исследуемого моста. И в рамках этой передачи можно сформировать тестовый импульс, длительность которого меньше, чем длительность бита. Причём сам импульс можно произвольно сдвинуть относительно начала бита.

Механизм появления интервала считывания значения.Синий маркер – первый семпл, красный маркер - семпл считывания.

Механизм появления интервала считывания значения.
Синий маркер — первый семпл, красный маркер — семпл считывания.

Если тестовый импульс не пересекается с временным интервалом от 3T⁄8 до 4T⁄8 (где T — длительность бита), то он не будет считан приёмником UART. Если тестовый импульс полностью накрывает указанный интервал, то&nb

© Habrahabr.ru