view doc/High-speed-serial @ 99:9214118ae941

target-utils: use of bcopy() changed to memcpy()
author Mychaela Falconia <falcon@freecalypso.org>
date Tue, 01 Nov 2016 00:05:31 +0000
parents e7502631a0f9
children 00805e7c4c45
line wrap: on
line source

The highest baud rate supported by "standard" PC serial ports is 115200 bps,
but Calypso UARTs can go quite a bit faster.  Being clocked with 13 MHz (a
standard frequency in the GSM world), these UARTs can produce non-standard
(outside of the GSM world) baud rates of 203125, 406250 and 812500 bps.  When
working with Motorola C1xx and Openmoko GTA01/02 phones which present a debug
and programming serial interface on a 2.5 mm headset jack, one can make use of
these high serial baud rates by using a USB to headset jack programming cable
based on one of the better USB-serial chips that can support these GSM special
baud rates well above 115200.  The two USB-serial chips that are known to work
in this manner are CP2102 and FTDI, although each of the two requires its own
special quirks described below.  Other USB to serial cables use chips which
don't support the high baud rates in question, and therefore are limited to
115200 baud max like a "standard" PC serial port.

FreeCalypso tools can use these high serial baud rates in the following ways:

* When you use fc-loadtool to dump and program GSM device flash memory
  (flashing firmware images), the transfers get annoyingly slow at 115200 baud
  if you have to do it a lot.  Switching to 406250 or even better 812500 baud
  makes them go considerably faster.

* Some of our target devices have large enough RAM to execute a GSM firmware
  image entirely from RAM without flashing - very handy for development and
  experimentation.  The tool used to run these RAM-based images is fc-xram,
  and it also supports the option of using high serial baud rates for the image
  transfer for the same reason: repeatedly transferring 1.5 MiB images over
  115200 baud gets tiresome.

* If you are building your own GSM firmware (either FC GSM fw or one of our
  TCS211-based hacks), you can make it run its RVTMUX interface at 406250 or
  812500 baud.  We used this trick when we tried to make TCS211 with D-Sample-
  targeting UI (176x220 pix LCD, 16 bits per pixel) send its virtual LCD raster
  blits out the serial port.  Our rvtdump and rvinterf utilities support this
  mode of operation by providing options to select different baud rates.

Using CP2102 adapters
=====================

CP2102 chips have a built-in EEPROM that contains (among other things) a
32-entry table in which the supported serial baud rates are programmed.  In
order to support the special GSM baud rates, these rates need to be added to
that table, displacing some other entries.  The convention established by the
Pirelli DP-L10 phone (has a CP2102 built in and programmed at the factory for
GSM baud rates) is that 203120 baud takes the place of 230400, 406250 takes the
place of 460800, and 812500 takes the place of 921600.

Because you need a special cable anyway to make the necessary physical
connection to the debug/programming serial port presented on a 2.5 mm headset
jack, you will probably be buying the requisite cable from a specialized
professional vendor.  In that case it is that vendor's responsibility to sell
you the cable with the CP2102 chip already programmed with GSM baud rates:
because the physical construction of the cable (2.5 mm headset jack on the
serial end) makes it specific to GSM devices, and all known GSM devices use a
13 MHz clock or some integer multiple thereof, it is pointless for a
physically-GSM-specific cable to be set up for 230400/460800/921600 baud when
all known GSM devices will need 203125/406250/812500 baud instead.

If you making a CP2102-based serial cable yourself (either for your own personal
use or professionally/commercially), please follow these instructions for baud
rate programming:

http://bb.osmocom.org/trac/wiki/Hardware/CP210xTutorial

If you follow the procedure given on that page, your CP2102 will be programmed
the same way as the one in the Pirelli DP-L10 (Foxconn's original factory
programming).

The serial port handling code in FreeCalypso host tools is written to request
B230400 from termios when 203125 baud is desired, likewise B460800 for 406250
baud and B921600 for 812500 baud.  Therefore, if you have a CP2102-based cable
with properly programmed EEPROM, everything will Just Work.

Using FTDI adapters
===================

Unlike CP2102, FTDI adapters don't require any non-volatile EEPROM programming
for GSM baud rates, but they have a different pain point - arguably a worse one
- that is entirely a software issue.  The API which the Linux kernel provides
to userspace applications for opening and configuring serial ports provides no
clean, sensible way for an application to request a particular baud rate that
is not in the predefined-once-and-for-all list, and to make it unambiguous to
the in-kernel driver exactly what it wants.

The method provided by the ftdi_sio driver in the standard Linux kernel is
gross, and I (Space Falcon) refuse to use it.  The serial port handling code in
FreeCalypso host tools is written for the clean CP2102 way, and is *not* muddied
with the muck that would be necessary to get the high GSM baud rates with an
unpatched ftdi_sio driver.  Therefore, if you would like to use one of the high
GSM baud rates with FreeCalypso with an FTDI adapter, you will need to dirty
your Linux host system with a hacky kernel patch.  The patch provided in
linux-2.6.37.6-ftdi_sio.c.patch (made against Linux 2.6.37.6, which is what I
use - came with Slackware 13.37 - adapt as necessary for your kernel version)
makes the ftdi_sio driver behave like a GSM-programmed CP2102: termios B230400
turns into 203125 baud, B460800 turns into 406250 and B921600 turns into 812500.

This patch won't break other software (*cough* osmocom-bb *cough*) that does
use the "standard" ftdi_sio way of requesting high GSM baud rates, i.e., both
ways of selecting these baud rates should still work, but if you have other
(non-GSM) serial devices on the same system which need 230400, 460800 or 921600
baud, those will break.

Using adapters built into phones
================================

The Calypso chip has no native USB capabilities, thus if a Calypso phone
presents a USB charging+data port to the user, it must have a USB to serial
converter built in.  The only phone we currently know of that does this is
Pirelli DP-L10, and its built-in USB-serial adapter chip is CP2102.  It has
already been programmed with the correct GSM baud rates on Foxconn's original
production line, thus one can always use 812500 baud with FreeCalypso tools on
this phone and it will Just Work.