Sensitech T11012087 PART 15 CLASS B COMPUTING DEVICE PERIPHERAL User Manual

Sensitech, INC. PART 15 CLASS B COMPUTING DEVICE PERIPHERAL Users Manual

Users Manual

© SENSITECH INC.                               CONFIDENTIAL – CONTROLLED DOCUMENT Page 1 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A             TripStrip II   Hardware Specification Document       Sensitech Inc. 800 Cummings Center • Suite 258X Beverly, MA 01915-6197
© SENSITECH INC.                               CONFIDENTIAL – CONTROLLED DOCUMENT Page 2 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Federal Communications Commission (FCC) Statement You are cautioned that changes or modifications not expressly approved by the part responsible for compliance could void the user’s authority to operate the equipment  FCC-Class B This equipment has been tested and found to comply with the limits for a class B digital device, pursuant to part 15 of the FCC Rules. These limits are designed to provide reasonable protection against harmful interference in a communications. However, there is no guarantee that interference will not occur in particular installation. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures: - Reorient or relocate the receiving antenna. - Increase the separation between the equipment and receiver. - Connect the equipment into an outlet on a circuit different from that to which the receiver is connected. - Consult the dealer or an experienced radio/TV technician for help.
© SENSITECH INC.                               CONFIDENTIAL – CONTROLLED DOCUMENT Page 3 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 4 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  APPROVALS Engineering: Name:                ______________________________ Date:    ____________________________________________ Signature:  ____________________________________________  Quality: Name:    _                     ______________________  Date:                   Signature:  ______________________________________________  Manufacturing: Name:                _______________________________   Date:                   Signature:  ______________________________________________  Marketing: Name:                       _____________________________   Date:                   Signature:  _________________________________________ ____     Technical Services: Name:                       _____________________________   Date:                   Signature:  _________________________________________ ____
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 5 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Document Version Information ........................................................................................ 9 Organization of this Document ......................................................................................... 9 Executive Summary ........................................................................................................... 9 Device General Description............................................................................................... 9 Functional Description .............................................................................................................. 9 User Interface........................................................................................................................... 10 FRS in brief .............................................................................................................................. 12 Device Hardware Structure ............................................................................................. 13 General Hardware Information ............................................................................................. 13 Electrical Specification............................................................................................................ 13 Mode of Operation................................................................................................................... 13 Power Save Mode “Suspend State”........................................................................................ 15 Power Supply ........................................................................................................................... 15 Qty............................................................................................................................................17 Vendor .....................................................................................................................................17 SEIKO .................................................................................................................................17 SANYO ...............................................................................................................................17 PCB......................................................................................................................................17 Li-ION Charging...................................................................................................................... 21 LogicPD Card Engine.............................................................................................................. 23 Memory Controller Reset and Initialization......................................................................... 23 Memory Controller.................................................................................................................. 23 Memory Controller Operation ............................................................................................... 24 Stacked SDRAM and Flash Memory..................................................................................... 24 Stacked SDRAM...................................................................................................................... 24 Stacked Flash Memory............................................................................................................ 24 Synchronous Dynamic Memory (SDRAM) Interface........................................................... 26 Maximum Row Active Time (TRAS)..................................................................................... 26 Programmable Larger SDRAM Memory Space................................................................... 26 SDRAM State Machine ........................................................................................................... 27 Synchronous, Static, and Variable-Latency I/O (VLIO)...................................................... 29 Interfaces .................................................................................................................................. 29 Asynchronous Static Operation.............................................................................................. 29
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 6 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Asynchronous Flash Memory Interface................................................................................. 31 Memory Controller.................................................................................................................. 31 Synchronous Flash Memory ................................................................................................... 32 ROM Interface......................................................................................................................... 32 SRAM Interface Overview...................................................................................................... 33 Variable-Latency I/O Interface Overview............................................................................. 33 Memory Controller.................................................................................................................. 33 UARTs ...................................................................................................................................... 34 Overview................................................................................................................................... 34 Full-Function UART................................................................................................................ 35 Bluetooth UART ...................................................................................................................... 35 Compatibility with 16550A and 16750................................................................................... 35 Features .................................................................................................................................... 35 Signal Descriptions .................................................................................................................. 36 Operation.................................................................................................................................. 37 Reset.......................................................................................................................................... 38 USB Client Controller:............................................................................................................ 39 Overview................................................................................................................................... 39 Features .................................................................................................................................... 40 Signal Descriptions .................................................................................................................. 40 Bidirectional Signals................................................................................................................ 40 Operation.................................................................................................................................. 41 Peripheral Bus Interface and Control/Status Registers....................................................... 41 Suspend and Resume............................................................................................................... 43 Sleep Mode Operation............................................................................................................. 44 USB On-The-Go Operation .................................................................................................... 44 On-Chip OTG Transceiver Operation................................................................................... 45 Interface to External OTG Transceiver ................................................................................ 46 Interface to External Charge Pump Device........................................................................... 47 Memory Stick........................................................................................................................... 48 Overview................................................................................................................................... 48 Features .................................................................................................................................... 48 Signal Descriptions .................................................................................................................. 48
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 7 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Operation.................................................................................................................................. 48 Functional Description ............................................................................................................ 49 Interrupts.................................................................................................................................. 49 Memory Stick Insertion and Removal................................................................................... 49 Reset.......................................................................................................................................... 50 Power-Save Mode .................................................................................................................... 50 LogicPD Card Engine:................................................................................................51 Note: Our current Card Engine does support Ethernet...............................................54 TempTale Mini......................................................................................................................... 55 TempTale 4 (Epson TT4)........................................................................................................ 59 Command Transmission Paradigm........................................................................................ 59 Status Byte Definitions ............................................................................................................ 59 Communication Layer Descriptions ...................................................................................... 60 Data Recording Layer ............................................................................................................. 60 TempTale 4 (OKI TT4).................................................................................................... 62 Communications .............................................................................................................. 62 Establishing a Connection....................................................................................................... 63 Command Protocol.................................................................................................................. 65 TT4 Optical Interface Circuit................................................................................................. 69 LCD........................................................................................................................................... 69 Keypad...................................................................................................................................... 71 9.0 Battery Low Alert Function:.................................................................................72 10.0 Line Thermal Head Printer:.................................................................................72 11.0 Control Board......................................................................................................73 Device System Configuration Information............................................................................ 76 LogicLoader (LoLoTM).......................................................................................................... 76 LogicLoader Overview............................................................................................................ 76 LogicLoader Basics.................................................................................................................. 76 Using LogicLoader for Debugging......................................................................................... 76 Manufacturing Advantages with LoLo.................................................................................. 76 The LogicLoader Shell (loshTM).................................................................................... 77 Losh Overview.......................................................................................................................... 77 Losh Basics ............................................................................................................................... 77 Using Losh..................................................................................................................77
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 8 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Program Loading.............................................................................................................. 77 4.1 Understanding the Load Command ..................................................................................... 78 YAFFS (Yet Another Flash File System)........................................................................... 79 8.1 YAFFS Overview ................................................................................................................ 79 8.2 Working with YAFFS in LogicLoader................................................................................ 79 8.2.1 Developing a Partition Scheme..........................................................................79 8.2.2 Formatting YAFFS Partitions............................................................................80 8.2.3 Adding YAFFS Type Partitions.........................................................................80 8.2.4 Mounting the Partition.......................................................................................80 8.2.5 Accessing YAFFS Partitions in an OS..............................................................81 8.3 Summary.................................................................................................................................. Device System Configuration/Programming.............................................................................  Explanation of Script...................................................................................................................  Appendix: ..................................................................................................................................... SAMPLE PRINT-OUT............................................................................................................................... List of Error Messages (12.9.08).................................................................................................
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 9 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Document Version Information  Document  Version Functional Requirement Specifications  T85000530, Rev. A Hardware Specifications  T82002163, Rev. A Firmware         Organization of this Document This document outlines the TripStripII’s specifications in detail. It describes each aspect of the unit’s functionality and how the hardware is configured.   Executive Summary  The TripStrip II is a handheld thermal printer which is capable of portable or desktop use. This particular model supersedes the previous TripStrip platform with many functional enhancements such as it will allow the download of 16K TempTale data loggers, TempTale Mini and all TempTale variants. An integral monochrome 4 inch LCD was added to provide the user with a quick view of the monitor data such as display summary and graph as well as menu navigation for unit functionality. The TripStrip II also has a USB host and client to allow further communication channels.  Device General Description    Functional Description  The following is an overview of the TripStrip II and its features.  Note: Input voltage range is 12VDC – 24VDC.  The TripStrip II remote data printer generates graphs from all TempTale 4 variants (2k and 16k) and TempTale Mini 2k. To be specific, TT4 Ambient, TT4 Humidity, TT4 Probe and Dual Sensor, TT4 BIO, TT4 Dry Ice Probe, TT4 Probeless Dry Ice, and TT4 RF.  The TripStrip II is available as a Li-ION rechargeable battery-powered unit, shipped fully charged and ready for use.  The battery may be recharged by the 15VDC switcher adapter, 12VDC automobile car adapter, or 24VDC Trailer Truck adapter.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 10 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  User Interface                       Power          Charge         Paper Out   Low Batt   User presses the Power Button and the unit is powered ON and the Power LED is ON. The Sensitech application program appears momentarily. The user is now able to download any TT4 (2k/16k) or TTmini; except TT4 USB. To download a TT4 unit, the user may place a TT4 on the optical interface and press START. To download a TTmini, the user may connect the TTmini to the RS232 DB9 connector and press START.  Once the user presses START, the TSII auto-detects which UART to begin downloading from. The summary data will appear first and the unit will begin printing (if option is enabled via Menu), then the user will have an option of displaying the graph on the LCD by pressing the ENTER key which defaults to Auto Scale Mode. The user will have the ability to Zoom In/Out of the graph. Zoom interval will be Max Trip Length / 5, regardless of the EEPROM size or monitor type. Please note: For the ZOOM feature, no matter what type of monitor or EEPROM size, the TSII will take the max trip length and divide it by 5. However, please note due to the resolution, if the monitor data size is less than (approximately) 512K then this will not apply. The user will only see the graph screen and will not be able to ZOOM. (If the EEPROM has more than or equal to 64 points then it will have the zoom feature).
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 11 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 12 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  FRS in brief   To re-design the current TripStrip TempTale Remote Printer that provides hardcopy printouts of time/temperature data and related information from TempTale monitors.    The current version of the product, while suitable in many applications for most customers has several deficiencies that impede further adoption of TempTale monitoring programs. In addition, the product is RoHS compliant.    The TripStrip is an ancillary product, designed purely as an accessory in support of in-bound and closed loop TempTale monitoring programs, primarily in the food and supermarket segments. In many cases the product is offered to customers as a free or deeply discounted instrument in support of large volume TempTale programs. Within this context product volumes are anticipated to be in the 100-500 units/year range.     The objectives of this project are: • Eliminate the current TripStrip deficiencies and upgrade the product feature set per the requirements described below. • Maintain or reduce product costs at/from current level • Provide product/system “architectural” features consistent with current and potential future product line strategies. • Minimize development and tooling/capital expense (the product is low-volume, with in-direct ROI potential)
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 13 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Device Hardware Structure    General Hardware Information Electrical Specification 1.1 SWITCHING POWER SUPPLY Input Voltage: AC 100~240V Frequency:50/60Hz Input Current: 1500mA. Output Voltage: DC 15V Output Current: DC 4000mA 1.2 DC Input: 12-24V * 15VDC Wall Adapter * 12 VDC automobile DC adapter * 24 VDC trailer truck DC adapter 1.2.1 Input current: 2-5A 1.2.2Power Consumption: approximately 15W 1.3. Charging Max Charging Current:3A Charging Voltage: 8.4V +/- 0.1V Charging Time: 3.5hr Discharging current: 2-6A Discharging time: 3hr/2A Environment Specification Operating Temperature: 0-45°C Storage Temperature:   0-45°C Operating Humidity:    0-99% Mechanical Specification Cabinet Size: 270(L)*135(W)*110(H) mm Weight: Approximately 1100g Color: Grey Mode of Operation The user presses the platen release button on the unit to load a 50mm paper roll into the frontend of the TripStripII unit. The user will then Power ON device using the POWER button on the Keypad. SENSITECH, INC. window appears. Now, the user is able to navigate through the menus or download/print a TempTale 4 monitor or TempTale Mini. A hand strap located on the rear of the unit provides the user optimal portability support.LED status indicators are visible on the front end of the unit or Power, LowBatt, Charging, and Paper out.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 14 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    2k monitor = 11 seconds to download the data and an additional 49 seconds to print 16k monitor = 1 minute to download and an additional 6 minutes to print
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 15 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Power Save Mode “Suspend State” Suspend state is the PXA270 SOM’s hardware power down state, allowing for lower power consumption. The Suspend state is designed to reduce power consumption while the PXA270 is waiting for an event such as a keyboard input. The suspend state is entered using Logic BSP’s by asserting the nSUSPEND signal or through software. The PXA270 processor is put into Standby Mode. All power supplies remain active. System context is retained. Internal clocks are stopped except RTC. An internal or external wakeup event can cause the processor to transition back to Run Mode.   IMPORTANT NOTE: Although Suspend consumes less power than Run state, it consumes more power than the Standby state. Thus, on a power failure, the PXA270 system will actually leave the Suspend state and transition to the Standby state (the same thing occurs on a SW_nRESET).   During suspend state, the unit powers OFF the LCD backlight, printer head, and printer control board. When user reinitiates activity, the unit returns to full active state of all devices.  If needed, user may engage the Reset Button located on the right-side of the unit.   Power Supply The following are methods a user is able to supply power to the TripStripII device to charge/operate: 1. Dual Voltage 120/60 Hz (220/50 Hz) – 15VDC Wall Adapter 2. 12 VDC automobile DC adapter 3. 24 VDC trailer truck DC adapter  Internally, the TripStripII power supply consists of:  1. LT4356-1, Overvoltage Protection Regulator and Inrush Limiter IC • The LT4356-1 surge stopper protects loads from high voltage transients.  • It regulates the output during an overvoltage event, such as load dump in automobiles, by controlling the gate of an external N-Channel MOSFET.  • The output is limited to a safe value thereby allowing the loads to continue functioning.  • The LT4356-1 also monitors the voltage drop between the VCC and SNS pins to protect against overcurrent faults.  • An internal amplifier limits the current sense voltage to 50mV.  • In either fault condition, a timer is started inversely proportional to MOSFET stress. • If the timer expires, the /FLT pin pulls low to warn of an impending power down. If the condition persists, the MOSFET is turned off.  2. LTC4006, 4A, High Efficiency, Standalone Li-Ion Battery Charger • The LTC4006 is a complete constant-current/constant voltage charger controller for 2-, 3- or 4-cell lithium batteries. • The PWM controller is a synchronous, quasi-constant frequency, constant off-time architecture that will not generate audible noise even when using ceramic capacitors. • Charging current is programmable with a single sense resistor to ±4% typical accuracy. • Charging current can be monitored as a representative voltage at the IMON pin.  • A timer, programmed by an external resistor, sets the total charge time or is reset to 25% of total charge time after C/10 charging current is reached.  • Charging automatically resumes when the cell voltage falls below 3.9V/cell.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 16 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  • Fully discharged cells are automatically trickle charged at 10% of the programmed current until the cell voltage exceeds 2.5V/cell.  • Charging terminates if the low-battery condition persists for more than 25% of the total charge time. • The LTC4006 includes a thermistor sensor input that suspends charging if an unsafe temperature condition is detected and automatically resumes charging when the battery temperature returns to within safe limits. • The LTC4006 charges a 7.4VDC/6A battery pack.  • The battery pack contains 6 Li-ION cells (2S3P topology).  • The battery pack internally contains a Li-ION protection circuit.  Design Note:   Note during prototype testing, we supplied 15VDC input to the TSII and the L105 inductor on the LTC4006 Charger Circuit reaches approximately 60-62C during charging (in open air). We will look into adding a passive heat sink to dissipate some of the heat. This was also the case when we supplied 24VDC input to the TSII.   After charge is complete, the L105 inductor will reach 29-30 degrees C (in open air). An NTC Thermistor was used to measure the temperature of the L105 inductor.  3. LM339 Low Power Low Offset Voltage Quad Comparator. (Low-battery detection): • The circuit is comprised of two Compartors. If the Vin(+) terminal is Low and the Vin(-) terminal is High, then the output is Low (current will flow). However if the Vin(+) terminal is High and the Vin(-) terminal is Low, then the output is High (current will not flow).  Therefore, If the Load in the variable input (5 – 27VDC) is <= 6.5VDC, then the Low Batt LED will be ON. However, if the variable input is >6.8VDC, then the Low Batt LED is OFF. The other input VB = 3.3VDC, which is a fixed voltage input.   4. Battery Pack Protection Circuit (model: 033A-BXA) • Function: Over charge detection, Over discharge detection, Over current detection, Short detection. • ELECTRIC CHARACTERISTICS (@ 25C) 1) Over charge detection voltage: 8.5V +/- 50mV  2) Over charge release voltage: 8.1V +/- 100mV  3) Over discharge detection voltage: 4.8V +/- 160mV  4) Over current detection: 4.00A ~ 7.00A  5) Over charge detection delay time: 0.55S~2.06S  6) Over discharge detection delay time:  67~141ms  7) Over current detection delay time: 6.3~14.7ms  8) Consumption current – Operating mode : Max 14.2 µA – Power - saving mode : Max0.2µA.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 17 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  PARTS LIST  Location  Description  Specification  Size  Qty  Vendor   U1  PROTECTION IC  S-8232ABFT-T2  TSSOP-8  1  SEIKO   Q1  N-CH FET  FTD2017A  TSSOP-8  1  SANYO   R1,R2R3,R4 CHIP RESISTOR  1Kohm (J)  1608 Size  4  R5  CHIP RESISTOR  4.7Mohm (J)  1608 Size  1 YAGEO,TAMA, KAMAYA, ROHM ,SEM , Any Approved Vendor  R6  CHIP POWER RESISTOR  R020ohm  6331 Size  1 YAGEO,TAMA, KAMAYA, ROHM ,SEM , Any Approved Vendor  C1,C2,C3  CHIP      CAPACITOR  0.1uF 25V (Z )  1608 Size  3 YAGEO,PHYCOMP, KYOCERA,ROHM, SAMWHA,SEM, Any Approved Vendor  PCB   FR-4,1oz,0.6t, 2Layer  40*7  1      5.  LM25116 Wide Range Synchronous Buck Controller  • The LM25116 is a synchronous buck controller intended for step-down regulator applications from a high voltage or widely varying input supply.  • The control method is based upon current mode control utilizing an emulated current ramp.  • Current mode control provides inherent line feed-forward, cycle by cycle current limiting and ease of loop compensation.  • The use of an emulated control ramp reduces noise sensitivity of the pulse-width modulation circuit, allowing reliable control of very small duty cycles necessary in high input voltage applications. • The LM25116 drives external high-side and low-side NMOS power switches with adaptive dead-time control. • A user-selectable diode emulation mode enables discontinuous mode operation for improved efficiency at light load conditions.  • A low quiescent current shutdown disables the controller and consumes less than 10µA of total input current.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 18 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  • Additional features include a high voltage bias regulator, automatic switch-over to external bias for improved efficiency, thermal shutdown, frequency synchronization, cycle by cycle current limit and adjustable line under-voltage lockout.  • The device is available in a power enhanced TSSOP-20 package featuring an exposed die attach pad to aid thermal dissipation • 7-42VDC input voltage and converts it to 6.25VDC/7A.  • This voltage output is for the Print Head.   6. LT1940, Dual Monolithic 1.4A, 1.1MHz Step-Down Switching Regulator  • The LT1940 is a dual current mode PWM step-down DC/DC converter with internal 2A power switches.  • Both converters are synchronized to a single 1.1MHz oscillator and run with opposite phases, reducing input ripple current.  • The output voltages are set with external resistor dividers, and each regulator has independent shutdown and soft-start circuits.  • Each regulator generates a power-good signal when its output is in regulation, easing power supply sequencing and interfacing with microcontrollers and DSPs. • The LT1940’s 1.1MHz switching frequency allows the use of tiny inductors and capacitors, resulting in a very small dual 1.4A output solution.  • Constant frequency and ceramic capacitors combine to produce low, predictable output ripple voltage.  • With its wide input range of 3.6V to 25V • Converts it to 3.3V/1.4A and 1.45V/1.4A. 1.45V is for VCORE which is the processor’s core voltage.  • 3.3V is for the remaining voltages such as I/O and peripheral supply voltage.   7. LM2940, 1A Low Dropout Regulator • The LM2940 positive voltage regulator features the ability to source 1A of output current with a dropout voltage of typically 0.5V and a maximum of 1V over the entire temperature range.  • Furthermore, a quiescent current reduction circuit has been included which reduces the ground current when the differential between the input voltage and the output voltage exceeds approximately 3V.  • The quiescent current with 1A of output current and an input-output differential of 5V is therefore only 30 mA.  • Higher quiescent currents only exist when the regulator is in the dropout mode (VIN − VOUT ≤ 3V). • The linear regulator (LDO) take a maximum of 26VDC input voltage and converts it to 5V/1A.  • This voltage output is for printer control board logic and boost converter.   8. LM2733, 0.6/1.6 MHz Boost Converters With 40V Internal FET Switch in SOT-23  • The LM2733 switching regulators are current-mode boost converters operating fixed frequency of 1.6 MHz (“X” option). • The use of SOT-23 package, made possible by the minimal power loss of the internal 1A switch, and use of small inductors and capacitors result in the industry's highest power density.  • Protection is provided through cycle-by-cycle current limiting and thermal shutdown.  • Internal compensation simplifies design and reduces component count. • Boost Converter takes 3.3VDC from the Buck Converter and boosts the voltage output to 17.8VDC to 25.5VDC.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 19 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    9. The CAT5113 is a single digitally programmable 10K potentiometer designed as a electronic replacement for mechanical potentiometers.  • The CAT5113 contains a 100-tap series resistor array connected between two terminals RH and RL.  • An up/down counter and decoder that are controlled by three input pins, determines which tap is connected to the wiper, RW.  • The wiper setting, stored in nonvolatile memory, is not lost when the device is powered down and is automatically reinstated when power is returned.  • The wiper can be adjusted to test new system values without affecting the stored setting. • Wiper-control of the CAT5113 is accomplished with three input control pins, /CS, U/D, and /INC.  • The /INC input increments the wiper in the direction which is determined by the logic state of the U/D input. • The /CS input is used to select the device and also store the wiper position prior to power down. • The digitally programmable potentiometer can be used as a three-terminal resistive divider or as a two terminal variable resistor.   During the event of transitioning the Chip Select from a low to a high state, this will Store the LCD Contrast Voltage in Memory.  During the event of transitioning the Chip Select from a low to a high state and Increment low, this will not store the value and return to standby.  (J1C.23 Card Engine) GPIO 99 = Up/Down (J1C.88 Card Engine) GPIO 36 = Chip Select (J1C.25 Card Engine) GPIO 27 = Increment  See block diagram below:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 20 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 21 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Li-ION Charging  1.Charging cycle evaluation (Battery is empty before this charge) Chager IC is 4006 and CHG indicator available only  Conditions: Fully Discharge the battery before the charging cycle test. The input power supply is 15V and charging current is 3A    Remark: The Max. charging time is around 3 hours. According to specification the charging time is limited to 3 hours ,when charge current is 1/10c then  the timer is auto reset ¼ T; So the total time max  is 3:45 hours ;and the CHG LED will turn off when charging completed.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 22 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Charging Current Vs time00.511.522.533.500:00 01:00 02:00 02:40 03:10 03:32Current (A)00:0000:1000:3001:0001:3001:40:0002:0002:10:0002:3002:4002:5003:0003:1003:2003:3003:32 Battery Voltage During charging 66.577.588.5900:0000:3001:3002:0002:3002:5003:1003:30Battery Voltage (V)00:0000:1000:3001:0001:3001:40:0002:0002:10:0002:3002:4002:5003:0003:1003:2003:3003:32   1) Power suppply efficiency evaluationInput Voltage   (V) Input Current  (A) Input PD(W) Output Voltage (V) Output Current(A) Output PD(W) Efficiency(%)12 2.630 31.56 7.2 3.88 27.936 88.5171102724 1.400 33.6 7.5 3.8 28.5 84.821428578.4 3.530 29.652 7.14 4 28.56 96.3172804524 1.330 31.92 7.14 4 28.56 89.473684217.13 1.120 7.9856 4.98 1 4.98 62.362252057.14 0.550 3.927 4.98 0.5 2.49 63.407181057.08 0.300 2.124 3.29 0.5 1.645 77.448210927.06 0.570 4.0242 3.28 1 3.28 81.506883367.09 0.162 1.14858 1.44 0.5 0.72 62.686099367.08 0.304 2.15232 1.436 1 1.436 66.718703541.45VOutput(LT1940)CHARGE7.2V Output (LM3075)5V output(LM2940s-5.0)3.3V Output(LT1940) NOTE: THIS WILL NEED TO CHANGE BECAUSE THE LM3075 BUCK CONVERTER HAS BEEN REPLACED.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 23 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  2) External Power adapter loading evaluation Charging at 3A onlyCharging3A+Loading1.45v&0.5ACharging3A+Loading1.45v&0.5A+3.3V&0.5ACharging3A+Loading3.3V&1A+7.2V&3.0ACharging3A+Loading3.3V&1A+7.2V&3.3AAC/DC Adapter  Outpout  Voltage(V)14.9 14.770 14.89 14.71 14.58AC/DC ADAPTER OUTPUT CURRENT (A)2.32 2.390 2.56 4.58 4.74PD(W) 34.568 35.300 38.1184 67.3718 69.1092Note:The adapter 's max PD is 70W.  LogicPD Card Engine  Memory Controller Reset and Initialization The SDRAM interface is disabled on reset. Reset values for the boot ROM are determined by BOOT_SEL. BOOT ROM is immediately available for reading upon exit from reset, and all memory interface control registers are available for writing.   Memory Controller The internal and external memory-interface structures for the PXA27x processor will be described in detail below. Memory-related registers that configure the memory controller for data transfers to and from static and dynamic memory devices are also described.  The external memory-bus interface for the PXA27x processor supports SDRAM, synchronous, and asynchronous burst-mode and page-mode flash memory, page-mode ROM, SRAM, variable latency I/O (VLIO) memory, PC Card, and CompactFlash expansion memory. Memory types are programmable through the memory-interface configuration registers (see Table 6-44). Memory requests are placed in a four-deep processing queue and processed in the order they are received. Features The memory controller provides the following features: • Interfaces to internal synchronous flash and SDRAM devices • Interfaces to four partitions of SDRAM • Interfaces to up to 1.0 Gbytes of SDRAM • Supports 1.8-V JEDEC LP-SDRAM operation at 104 MHz • Interfaces to six partitions of static memory. Four of these six partitions can be synchronous flash memory. • Interfaces to up to 384 Mbytes of flash memory • Interfaces to two sockets of PC Card memory • Allows an alternate bus master to take control of the bus • Places the SDRAMs into self-refresh mode before entering sleep, standby, deep-sleep, and
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 24 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  frequency-change modes • Provides signals and controls for fly-by DMA transfers • Supports non-volatile memory configured as bank 0 from either 16- or 32-bit devices • Provides three independent output clocks (SDCLK<2:0>) that can be turned on/off separately and can be programmed to be free-running. The clocks can be the same frequency or half the frequency of the input clock, CLK_MEM. One clock (SDCLK<0>) can also be programmed as one quarter of the input-clock frequency. A fourth output clock (SDCLK<3>) depends on configuration bits used to control SDCLK<0>. • Provides a programmable power-down mode for saving power     Memory Controller Operation The processor has three different memory spaces: SDRAM, static memory, and PC Card space. SDRAM has four partitions, static memory has six partitions, and PC Card space has two partitions (or sockets). When user software performs a memory burst across the boundary between any two adjacent partitions, the configurations for each partition must be identical. They must have the same external bus width, burst length, and so forth. In theory, the partitions can be different types of memory sharing the same configuration characteristics. In practice, cross-partition memory bursts are conducted only when the two partitions hold the same memory type. A typical case is a transfer across two SDRAM partitions, 0 and 1, which are mandated to have the same characteristics. Figure 6-1 is a block diagram of the maximum configuration of the memory controller. Stacked SDRAM and Flash Memory This section describes memory types that may be supported in the PXA271 and PXA272 processors. Stacked SDRAM On the Intel® PXA271 processor, SDRAM is stacked and connected to SDRAM partition 0. On systems using the Intel® PXA271 processor, external SDRAM memory chips must not exist within the same SDRAM partition pair as that of the internal stacked SDRAM. This could cause negative signal reflection to the stacked SDRAM device.  For the Intel® PXA271 processor stacked SDRAM, the Intel® PXA27x processor memory controller must be programmed to multiplex the SDRAM address lines out differently because the address lines to the stacked SDRAM are not connected to the usual MA<24:10> lines. The MDCNFG[STACKx] field on a Intel® PXA271 processor must be programmed to 0b01 to send the SDRAM address out on MA<24:23,13:1> for stacked 16-bit SDRAM of this product. For a non stacked part (Intel® PXA270 processor) or flash only stacked part (Intel® PXA272 processor) the MDCNFG[STACKx] field must be programmed to 0b00 to send the SDRAM address out on MA<24:10>.    Stacked Flash Memory A fourth SDCLK, SDCLK<3> is driven by the memory controller, to be used in the PXA271 and PXA272 processors containing stacked flash devices. SDCLK<3> is a buffer duplicate of
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 25 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  SDCLK<0> and does not have any control bits of its own to turn it on or off. Use the buffer strength field associated with SDCLK<3> to turn off SDCLK<3> if there is no stacked flash in the system. This buffer strength setting is located in the BSCNTR2 register.   Static partitions 0 and 1 may contain stacked flash. The memory controller must be aware of which static memory partitions contain stacked flash. This is programmed in the SA1111[SXSTACK] field. When a flash device is being written to, the nCS and nWE signals swap functionality from a normal flash write to an off-chip device. This is shown by timing diagrams in the Intel® PXA27x Processor Family EMTS.   Figure 6-1. General Memory Interface Configuration
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 26 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    Synchronous Dynamic Memory (SDRAM) Interface   The processor supports the JEDEC synchronous dynamic memory (SDRAM) interface. The SDRAM interface supports four 16-bit or 32-bit wide partitions of SDRAM. Each partition is allocated 64 or 256 Mbytes of the internal memory map. The actual size of each partition depends on the SDRAM configuration used. The four partitions are divided into two partition pairs: the 0/1 pair and the 2/3 pair. Both partitions in a pair must be identical in size and configuration. Pairs 0/1 and 2/3 can be different. For example, the 0/1 pair can be 100-MHz SDRAM on a 32-bit data bus, while the 2/3 pair can be 50-MHz SDRAM on a 16-bit data bus. The SDRAM interface includes the following: • Four partition selects, nSDCS<3:0> • Four byte mask signals, DQM<3:0> • 15 multiplexed bank/row/column address signals, MA<24:10>, MA<24:23,14:2>, or MA<24:23,13:1>, depending on the MDCNFG[STACKx] setting • One write enable, nWE • One column-address strobe (nSDCAS) • One row-address strobe (nSDRAS) • One clock enable (SDCKE) • Two clocks (SDCLK<2:1>) The processor performs auto-refresh (CBR) during normal operation and supports self-refreshing SDRAM during sleep, deep-sleep, standby, and frequency-change modes. An SDRAM autopower- down mode bit (MDREFR[APD]) can be set so that the two clocks (SDCLK<2:1>) and the clock-enable signal (SDCKE) to SDRAM are automatically de-asserted whenever none of the corresponding partitions is being accessed. Each possible SDRAM section of the memory map is referred to as a partition, to distinguish them from banks internal to SDRAM devices. Maximum Row Active Time (TRAS) The maximum amount of time that any SDRAM row can be active is defined as TRASMAX. When programming MDREFR[DRI], ensure that the refresh cycle time is less than TRASMAX because it is not monitored by the memory controller.  Programmable Larger SDRAM Memory Space The read/write MDCNFG register contains control bits for configuring the SDRAM for larger SDRAM configurations than fit in the 64-Mbyte SDRAM partitions. Refer to Table 6-23 for configuration programming. Figure 6-2 shows the programmable option for the SDRAM memory space.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 27 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Programmable SDRAM Memory Map Options (Figure below):   SDRAM State Machine Figure 6-4 shows the SDRAM controller states and transitions associated with powering on the PXA27x processor and the SDRAMs properly. Transitions are determined by the overall memory controller state and a few SDRAM power-down, self-refresh status, and control bits. The states that involve multiple SDRAM devices are self-refresh and clock-stop, self-refresh, SLFRSH, PWRDNX, power-down, power-down and clock-stop, PWRDN, PALL, and MRS. The states that involve single SDRAM partitions are ACT, PRE, READ, and WRITE. The MRS command is sent once to configure partition pair 0/1 and a separate MRS command is sent only once to configure partition pair 2/3. The auto-refresh command is issued to memory in the same partition pair at the same time. Therefore, the chip-select signals representing the partition pair are asserted at the same time when the MRS command and auto-refresh is issued from the memory controller to a specific partition pair.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 28 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  SDRAM Power-ON State Machine (figure below):  Sleep, deep-sleep, standby, or frequency-change requests cause the SDRAM state machine to enter the self-refresh and clock-stop state. Software must then complete the appropriate reset procedure. Clearing MDREFR[E1PIN] and MDREFR[KnRUN] provides software control of the SDRAM memory system low-power modes.  Note: (1) Use these modes with extreme caution, because the resulting states prohibit automatic toggles from mode register set, read, write, and refresh commands. The Auto_Power_Down and Auto_Power_Up transitions (made possible by setting the APD bit in MDREFR) provide a completely automatic alternative for minimizing power consumption in the SDRAM system. (2) Some companion chips require the clock to be present at all times. Use the following prioritization scheme for transitions out of the NOP state. If enabled with the APD bit, the Auto_Power_Down transition occurs when none of the higher priority transitions are asserted. The Auto_Power_Up transitions occur when refresh, New_MRS, or read/write is asserted during the Power_Down state.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 29 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Highest Priority- ”Enter Sleep” “Set_SLFRSH” “Clear_E1PIN” “Refresh” “New_MRS” “Read/Write” Lowest Priority - “Auto_Power_Down” KnRUN = MDREFR[K1RUN] OR MDREFR[K2RUN] Auto_Power_Down = MDREFR[APD] Clear_E1PIN = !(MDREFR[E1PIN]) Set_SLFRSH = MDREFR[SLFRSH] Enter_Sleep = Sleep/Deep-Sleep/Standby/ Frequency Change Request and no more transactions to process Auto_Power_Up = Read/Write is asserted during the power-down state OR New_MRS OR Refresh OR !(MDREFR[APD])  Synchronous, Static, and Variable-Latency I/O (VLIO) Interfaces The static memory and VLIO interfaces have six chip selects (nCS<5:0>) and 26 bits of byte address (MA<25:0>) for accesses of up to 64 Mbytes of memory in each of six banks. Alternately, a mode is available to support up to two 128-Mbyte chip selects (nCS<1:0>) with 26 bits of halfword address (MA<0>, MA<25:1>) and two 64-Mbyte chip selects (nCS<5:4>) with 25 bits of byte address (MA<25:0>). This programmable option resides in the Static Memory Configuration register SA1110[SXENX]. Each chip select is individually programmed to select one of the supported static memory types. • Non-burst ROM or flash memory (Section 6.4.3.2) is supported on each of nCS<5:0> • Burst ROM or flash memory with non-burst writes (Section 6.4.3.2) is supported on each of nCS<5:0> • SRAM is supported on each of nCS<5:0> • Variable-latency I/O is supported on each of nCS<5:0> • Synchronous flash memory is supported on each of nCS<3:0> The four synchronous-flash memory partitions (nCS<3:0>) are divided into two partition pairs: the 0/1 pair and the 2/3 pair. Both partitions in a pair must be identical in size and configuration. The two pairs can be different. For example, the 0/1 pair can be 66-MHz synchronous flash memory on a 32-bit data bus while the 2/3 pair is 33-MHz synchronous flash memory on a 16-bit data bus. The VLIO interface differs from SRAM in that it allows the use of the data-ready input signal, RDY, to insert a variable number of wait states. For all static memory types, each chip select can be configured individually to a 16-bit or 32-bit wide data bus. The nOE signal is asserted on reads, the nPWE signal is asserted on writes to VLIO devices, and the nWE signal is asserted on writes to all other static devices, both synchronous and asynchronous. For SRAM and VLIO, DQM<3:0> are byte enables for both reads and writes. When the processor comes out of reset, it begins to fetch and execute instructions at address 0x00, which corresponds to memory selected by nCS<0>, which is the required location of the boot ROM. The BOOT_SEL pin determines the width of the boot memory. Asynchronous Static Operation The static-memory interface is comprised of six chip selects, nCS<5:0>. These six chip selects are
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 30 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  configurable for the following: • Non-burst ROM or flash memory  • Burst ROM or flash memory • SRAM  • VLIO devices  The VLIO interface differs from SRAM in that it allows the use of a data-ready input signal, RDY, to insert a variable number of memory-cycle wait states. The data bus width for each chip-select region can be programmed to be 16- or 32-bit. The nCS<3:0> signals are also configurable for synchronous static memory. The following list describes the use of nOE, nWE, and nPWE: • nOE is asserted for all reads. • nWE is asserted for flash memory and SRAM writes. • nPWE is asserted for VLIO writes. For SRAM and VLIO implementations, DQM<3:0> are used for the write byte-enables, where DQM<3> corresponds to the MSB. The processor supplies 26 bits of byte address for access of up to 64 Mbytes per chip select. This byte address is sent out on the 26 external address pins. If the byte address is unimportant for an application, the lower bit must be truncated for 16-bit systems and the lower two bits must be truncated for 32-bit systems. For reads, the byte address bits is 0. For writes, the byte address bits are summarized in Table 6-10 and Table 6-11.   Table 6-10. 32 Bit Byte Address Bits MA <1.0> for Writes Based on DQM <3.0>  Transaction   DQM<3:0>   MA<1:0>  Word   0b0000   0b00  Byte 0   0b1110   0b00  Byte 1   0b1101   0b01  Byte 2   0b1011   0b10  Byte 3   0b0111   0b11  Lower half word   0b1100   0b00  Upper half word   0b0011   0b10    Table 6-11. 16-Bit Byte Address Bit MA <0> for Writes Based on DQM <1.0>  Transaction   DQM<1:0>   MA<0>  Half word   0b00   0b0  Byte 0   0b10   0b0  Byte 1   0b01   0b1   The MSCx[RTx] fields specify the type of memory: • Non-burst ROM or flash memory • SRAM • VLIO • Burst-of-four ROM or flash memory
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 31 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  • Burst-of-eight ROM or flash memory The MSCx[RBWx] fields specify the bus width for the memory space selected by nCS<5:0>. If a 16-bit bus width is specified, transactions occur across data pins MD<15:0>. Use the BOOT_SEL pin or SXCNFG register to configure nCS<3:0> for synchronous static memory. Asynchronous Flash Memory Interface The MSCx[RDFx] bit fields define the latency for each read access of non-burst flash memory or the first read access of burst flash memory. The same bit field also controls the nWE de-assertion time during a write cycle to flash memory. The MSCx[RDN] field controls subsequent read access times to burst flash memory. The MSCx[RRR] bit field calculates the minimum period from the nCS signal de-assertion following a read or write and before the start of the read from a different memory. The following requirements apply to reads from flash memory: • Because flash memory defaults to read-array mode, burst reads from it are permitted, which allows instruction caching and burst reads (DMA and USB host) from flash memory. • Some areas of flash memory might not permit burst reads. When attempting to read from these areas, do not attempt burst reads. Consult the flash-memory data sheet for more information. Table 6-10. 32-Bit Byte Address Bits MA<1:0> for Writes Based on DQM<3:0> Transaction DQM<3:0> MA<1:0> Word 0b0000 0b00 Byte 0 0b1110 0b00 Byte 1 0b1101 0b01 Byte 2 0b1011 0b10 Byte 3 0b0111 0b11 Lower half word 0b1100 0b00 Upper half word 0b0011 0b10 Table 6-11. 16-Bit Byte Address Bit MA<0> for Writes Based on DQM<1:0> Transaction DQM<1:0> MA<0> Half word 0b00 0b0 Byte 0 0b10 0b0 Byte 1 0b01 0b1  Memory Controller • Software must partition commands and data, then write the commands to flash memory before a read. The memory controller does not insert any commands before flash-memory reads. The following requirements apply to writes to flash memory: • Flash memory space must be uncacheable and unbuffered. • Burst writes to flash memory do not exist. Writes to flash memory must be exactly the width of the populated flash devices on the data bus and must be a burst length of one write (for instance, no byte writes to a 32-bit bus, no word writes to a 16-bit bus, no writes of 2 bytes to a 32-bit bus, no writes of 1 byte to a 16-bit bus). The allowable writes are 2 bytes to a 16-bit bus and 4 bytes to a 32-bit bus. • For writes to flash memory, the command and data must be given to the memory controller in separate write instructions. The first instruction carries the command; the next carries the data. • Software must partition commands and data and write them to flash memory in the appropriate sequence. The memory controller does not insert any commands before flash-memory writes. • Because burst writes to flash memory cannot occur, the DMA controller and USB host controller must never write to flash memory. Burst writes to flash memory are not performed.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 32 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Synchronous Flash Memory This section describes how to interface with synchronous flash memory. Synchronous flashmemory operation resets to asynchronous mode (page mode for reads and asynchronous singleword writes). The only way the system can enter synchronous mode (burst-timing synchronous reads and asynchronous single-word writes) is through the Read Configuration register (RCR). Therefore, at boot time, synchronous flash memory operates the same as asynchronous boot ROM. Table 6-12 shows sample programming values for the RCR Synchronous Flash Memory register to ensure proper operation of synchronous flash memory. Use the values in Table 6-12 as a reference only. Consult the data sheet for the actual part being used. Determine the frequency-configuration code based on the CLK-to-output delay, the CLK period, and the nADV-to-output delay timing parameters for the flash device. Table 6-12. Sample Read Programming Values for Synchronous Flash Memory (Sheet 1 of 2)  Bits   Field Name   Value to Program†  2:0   BURST LENGTH   0b010 = 8-word burst  5:3   reserved   0b000  6   CLOCK CONFIGURATION  0b1 = Use rising edge of clock  7   BURST SEQUENCE   0b1 = Linear burst order (Intel burst order is not supported)  8   WAIT CONFIGURATION   Not applicable—The processor ignores nWAIT from the flash device.  9   DATA OUTPUT CONFIGURATION   0b0 = Hold data for one clock  10   reserved   0b0  †  for configuration register   Table 6-12. Sample Read Programming Values for Synchronous Flash Memory (Sheet 2 of 2)  Bits   Field Name   Value to Program†      0b010 -> Code 2 (CAS latency 3)      0b011 -> Code 3 (CAS latency 4)      0b100 -> Code 4 (CAS latency 5)  13:11  FREQUENCY CONFIGURATION   0b101 -> Code 5 (CAS latency 6)      0b110 -> Code 6 (CAS latency 7)      Choose this value based on the “AC Characteristics—Read-Only      Operation” section of the flash-memory device data sheet.  14   reserved   0b0  15   READ MODE   0b0 = Synchronous operation 0b1 = Asynchronous operation  †  for configuration register   ROM Interface The processor provides programmable timing for both burst and non-burst ROMs. The value of
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 33 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  MSCx[RDF] defines the latency (in memory clock cycles) for the first and all subsequent data beats from non-burst ROMs and the first data beat from a burst ROM. The value of MSCx[RDN] defines the latency for the burst data beats after the first for burst ROMs. Specifying the MSCx[RRR] value allows a delay on the next access to a different memory space to allow time for the current ROM to three-state the data bus. MSCx[RRR] must be programmed with the maximum TOFF value divided by two, as specified by the ROM manufacturer. MSC0<15:0> is selected when the address space corresponding to nCS<0> is accessed. SRAM Interface Overview The processor provides a 16- or 32-bit synchronous SRAM interface that uses the DQM pins for byte enables on writes. Bits nCS<5:0> select the SRAM bank to be used. nOE is asserted on reads and nWE is asserted on writes. Address bits MA<25:0> allow up to 64 Mbytes of SRAM per bank to be addressed. The RDF fields in the MSCx registers define the latencies for a read access. The MSCx[RDN] field controls the nWE low time during a write cycle. MSCx[RRR] is defined as the minimum time from nCS de-assertion to the beginning of a read or write access of any memory bank Any DMA mode that does not increment the address is not supported for SRAM reads or writes. DCMDx[INCSRCADDR] and DCMDx[INCTRGADDR] clear cause the address not to be incremented. This DMA mode is not supported for SRAM. The only valid memory types for this mode are VLIO and PC Card/CompactFlash devices.   Variable-Latency I/O Interface Overview When a companion chip is used as a VLIO device, its functionality is similar to that of an SRAM with the additional ability to insert a variable number of wait states through the RDY pin. VLIO can be used in the memory space for any of the six static memory locations (nCS<5:0>) by programming the corresponding MSCx[RTx] to 0b100. 13:11 FREQUENCY CONFIGURATION 0b010 -> Code 2 (CAS latency 3) 0b011 -> Code 3 (CAS latency 4) 0b100 -> Code 4 (CAS latency 5) 0b101 -> Code 5 (CAS latency 6) 0b110 -> Code 6 (CAS latency 7) Choose this value based on the “AC Characteristics—Read-Only Operation” section of the flash-memory device data sheet. 14 reserved 0b0 15 READ MODE 0b0 = Synchronous operation 0b1 = Asynchronous operation  Table 6-12. Sample Read Programming Values for Synchronous Flash Memory  Bits Field Name Value to Program    Memory Controller VLIO read accesses differ from SRAM read accesses in that nOE toggles for each beat of a burst. The first nOE assertion occurs two CLK_MEM cycles after the chip select, nCSx, is asserted. For VLIO writes, nPWE is used instead of nWE, which allows SDRAM refreshes to execute while performing the VLIO transfers.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 34 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  For both reads and writes from and to VLIO, clearing DCMDx[INCSRCADDR] and DCMDx[INCTRGADDR] causes the source and target addresses not to be incremented to the VLIO interface, which allows port-type VLIO chips to interface with the processor. The only valid memory types for this DMA mode are VLIO and PC Card/CompactFlash devices.   For writes to VLIO, if all byte enables are turned off (masking out the data, DQM = 0b1111), then the write enable is suppressed (nPWE = 1) for this write-beat to VLIO. This suppression can cause a period when nCS is asserted but neither nOE nor nPWE is asserted, which would happen if there is a write of one beat to VLIO with all byte enables turned off. In this case, the memory controller ignores the RDY signal. The RDY signal must not be asserted late if it is to still be asserted, which could interfere with any following transfers. If the VLIO device does not see an nOE or a nPWE, it must not change the state of RDY, keeping it either asserted or de-asserted. With the exception of the case above, and when entering a frequency change, the memory controller indefinitely waits for the RDY signal to be asserted, which can hang the system if the external VLIO is not responding. To prevent indefinite hangs, set the watchdog timer when starting a VLIO transfer; a watchdog reset occurs if no response is received from the VLIO device. Figure 6-5. Variable-Latency I/O Diagram   UARTs This chapter describes the universal asynchronous receiver/transmitter (UART) serial ports included in the PXA27x processor. The serial ports are controlled using direct-memory access (DMA) or programmed I/O. The PXA27x processor has three UARTs: full-function (FFUART), Bluetooth (BTUART), and standard (STUART). All UARTs use the same programming model. Overview Each serial port contains a UART and a slow infrared-transmit encoder and receive decoder that conform to the IrDA serial-infrared specification.1 Each UART performs serial-to-parallel conversion on data characters received from a peripheral device or a modem and parallel-to-serial conversion on data characters received from the processor. The processor can read a UART’s complete status during functional operation. Status information includes the type and condition of transfer operations and error conditions (parity, overrun, framing, or break interrupt) associated with the UART. Each serial port operates in either FIFO or non-FIFO mode. In FIFO mode, a 64-byte transmit FIFO holds data from the processor until it is transmitted on the serial link, and a 64-byte receive
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 35 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  FIFO buffers data from the serial link until it is read by the processor. In non-FIFO mode, the transmit and receive FIFOs are bypassed. Each UART includes a programmable baud-rate generator that can divide the input clock by 1 to (216 – 1). This produces a 16X clock that can be used to drive the internal transmit and receive logic. Software can program interrupts to meet its requirements, which minimizes the number of computations required to handle the communications link. Each UART operates in an environment that is either controlled by software and can be polled or is interrupt-driven. All three UARTs support the 16550A and 167502 functions, but are slightly different in the features supported. Full-Function UART The FFUART supports modem-control capability. The maximum baud rate is 921,600 bps. Bluetooth UART The BTUART is a high-speed UART that supports baud rates up to 921,600 bps and can be connected to a Bluetooth module. It supports the functions in the feature list, but supports only two modem control pins (nCTS and nRTS). 1. Infrared Data Association, Serial Infrared Physical Layer Link Specification, October 17, 1995, Version 1.1 2. The 16550A was originally produced by National Semiconductor Inc. The 16750 is produced as the TL16C750 by Texas Instruments.  The STUART supports all functions in the feature list, but does not support modem-control capability. The maximum baud rate is 921,600 bps. Compatibility with 16550A and 16750 The UARTs are functionally compatible with the 16550A and 16750 industry standards. Each UART supports most of the 16550A and 16750 functions, as well as the following features: • DMA requests for transmit and receive data services • Slow infrared-asynchronous interface • Non-return-to-zero (NRZ) encoding/decoding function • 64-byte transmit/receive FIFO buffers • Programmable receive FIFO trigger threshold • Auto baud-rate detection • Auto flow Features The UARTs share the following features: • Functionally compatible with the 16550A and 16750 • Ability to add or delete standard asynchronous communication bits (start, stop, and parity) in the serial data • Independently controlled transmit, receive, line status, and data-set interrupts • Programmable baud-rate generator that allows the internal clock to be divided by 1 to (216 – 1) to generate an internal 16X clock • Modem control functions (nCTS, nRTS, nDSR, nDTR, nRI, and nDCD) • Auto-flow capability controls data I/O without generating interrupts: — nRTS (output) controlled by UART receive FIFO — nCTS (input) from modem controls UART transmitter • Fully programmable serial interface: — 5-, 6-, 7-, or 8-bit characters — Even, odd, and no-parity detection
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 36 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  — 1, 1½, or 2 stop-bit generation — Baud-rate generation up to 921 kbps for all UARTs — False start-bit detection • 64-byte transmit FIFO • 64-byte receive FIFO • Complete status-reporting capability • Ability to generate and detect line breaks • Internal diagnostic capabilities that include: — Loopback controls for communications-link fault isolation — Break, parity, and framing-error simulation • Fully prioritized interrupt system controls • Separate DMA requests for transmit and receive data services • Slow infrared asynchronous interface that conforms to the Infrared Data Association (IrDA) specification Signal Descriptions Table 10-1 lists and describes each external signal that is connected to a UART module. The pins transmit digital CMOS-level signals and are connected to the PXA27x processor through GPIOs. Refer to Section 24, “General-Purpose I/O Controller” for details on the GPIOs.    Table 10-1. UARTs I/O Signal Descriptions (Sheet 1 of 2)  Name  Type   Description  RXD   Input    Serial Input- Serial data input to the receive shit register. In infrared mode, it is connected to the infrared receiver input. This signal is present on all three UARTs.        TXD   Output  Serial Output—Serial data output to the communications-link peripheral, modem, or data set. The TXD signal is set to the logic 1 state upon a reset operation. It is connected to the output of the infrared transmitter in infrared mode. This signal is present on all three UARTs.  nCTS  Input  Clear to Send—When low, indicates that the modem or data set is ready to exchange data. The nCTS signal is a modem status input, and its condition can be tested by reading bit 4 (CTS) of the Modem Status register (MSR). MSR[CTS] is the complement of the nCTS signal. MSR[DCTS] indicates whether the nCTS input has changed state since the last time MSR was read. nCTS has no effect on the transmitter. This signal is present on the FFUART and BTUART. When MSR[CTS] changes state and the modem-status interrupt is enabled, an interrupt is generated. Non-Auto-Flow Mode—When not in auto-flow mode, MSR[CTS] indicates the state of nCTS. MSR[DCTS] indicates whether the nCTS input has changed state since the previous reading of MSR. nCTS has no effect on the transmitter. The user can program the UART to interrupt the processor when DCTS changes state. Software can then stall the outgoing data stream by starving the transmit FIFO or disabling the UART with the IER register. NOTE: If UART transmission is stalled by disabling the UART, no MSR interrupt is received when nCTS reasserts, because disabling the UART also disables interrupts. To get around this, either use auto-CTS in auto-flow mode or program the nCTS GPIO pin to interrupt. Auto-Flow Mode—In this mode, the UART transmit circuity checks the state of nCTS before transmitting each byte. IF nCTS is high, no data is transmitted.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 37 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  nDSR  Input  Data Set Ready—When low, indicates that the modem or data set is ready to establish a communications link with a UART. The nDSR signal is a modem-status input. Its condition can be tested by reading MSR[DSR], which is the complement of nDSR. MSR[DDSR] indicates whether the nDSR input has changed state since MSR was last read. This signal is present only on the FFUART. When MSR[DSR] changes state, an interrupt is generated if the modem-status interrupt is enabled.  nDCD  Input  Data Carrier Detect—When low, indicates that the data carrier has been detected by the modem or data set. The nDCD signal is a modem-status input. Its condition can be tested by reading MSR[DCD], which is the complement of the nDCD signal. MSR[DDCD] indicates whether the nDCD input has changed state since the previous reading of MSR. nDCD has no effect on the receiver. This signal is present only on the FFUART. When the DCD bit changes state and the modem-status interrupt is enabled, an interrupt is generated.    Table 10-1. UARTs I/O Signal Descriptions (Sheet 2 of 2)  Name  Type   Description  nRI   Input  Ring Indicator—When low, indicates that the modem or data set has received a telephone ringing signal. The nRI signal is a modem-status input. Its condition can be tested by reading MSR[RI], which is the complement of the nRI signal. MSR[TERI] (trailing-edge-of-ring indicator) indicates whether the nRI input has changed from low to high since MSR was last read. This signal is present only on the FFUART. When the RI bit of the MSR changes from a high to low state and the modem-status interrupt is enabled, an interrupt is generated.  nDTR  Output  Data Terminal Ready—When low, signals the modem or the data set that the UART is ready to establish a communications link. To assert the nDTR output (active low), set MSR[DTR], which is the complement of the output signal. A reset operation deasserts this signal (high). Loopback-mode operation holds nDTR deasserted. This signal is present only on the FFUART.  nRTS  Output  Request to Send—When low, signals the modem or the data set that the UART is ready to exchange data. To assert the nRTS output (active low), set MSR[RTS], which is the complement of the output signal. A reset operation deasserts this signal (high). Loopback-mode operation holds nRTS deasserted. This signal is used by the FFUART and BTUART. Non-Auto-Flow Mode—To assert the nRTS output (active low), set MSR[RTS]. Auto-Flow Mode—nRTS is automatically asserted by the auto-flow circuitry when the receive buffer exceeds its programmed trigger threshold. It is deasserted when enough bytes are removed from the buffer to lower the data level back to the trigger threshold.   Operation Figure 10-1 shows the format of a UART data frame. Figure 10-1. Example UART Data Frame
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 38 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A      The receive-data sample counter frequency is 16 times the value of the bit frequency. The 16X clock is created by the baud-rate generator. Each bit is sampled three times in the middle. Shaded bits in Figure 10-1 are optional and can be programmed by software. Each data frame is between 7 and 12 bits long, depending on the size of the data programmed, whether parity is enabled, and the number of stop bits. A data frame begins by transmitting a start bit that is represented by a high-to-low transition. The start bit is followed by from 5 to 8 bits of data that begin with the least significant bit (LSB). The data bits are followed by an optional parity bit. The parity bit is set if even-parity is enabled and the data byte has an odd number of ones, or if odd parity is enabled and the data byte has an even number of ones. The data frame ends with 1, 1½, or 2 stop bits, as programmed by software. The stop bits are represented by 1, 1½, or 2 successive bit periods of logic 1. Each UART has two FIFOs: one transmit and one receive. The transmit FIFO is 64 bytes deep and 8 bits wide. The receive FIFO is 64 bytes deep and 11 bits wide. Three bits are used for tracking errors. The UART can use non-return-to-zero (NRZ) coding to represent individual bit values. To enable NRZ coding, set IER[5]. A bit value of 0b1 is represented by a line transition, and 0b0 is represented by no line transition. Figure 10-2 shows the data byte 0b0100_1011 in NRZ coding. The byte’s LSB is transmitted first. Figure 10-2. Example NRZ Bit Encoding—0b0100_1011  Reset The UARTs are disabled on reset. To enable a UART, software must program the GPIO registers (see Section 24, “General-Purpose I/O Controller”), then set IER[UUE]. When the UART is enabled, the receiver waits for a frame-start bit and the transmitter sends data if it is available in the Transmit Holding register. Transmit data can be written to the Transmit Holding register before the UART unit is enabled. In FIFO mode, data is transmitted from the FIFO to the Transmit Holding
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 39 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  register before it goes to the pin. When the UART unit is disabled, the transmitter or receiver finishes the current byte and stops transmitting or receiving more data. Data in the FIFO is not cleared, and transmission resumes when the UART is enabled. USB Client Controller: Overview The UDC supports 24 endpoints (endpoint 0 plus 23 programmable endpoints). The UDC is a USB Revision 1.1-compliant, full-speed device that operates half-duplex at a baud rate of 12 Mbps (as a slave only, not as a host or hub controller). The serial information transmitted and received by the USB client controller contains layers of communications protocols as defined by Universal Serial Bus Specification, Revision 1.1, the most basic of which are fields. • USB fields include: sync, packet identifier, address, endpoint, frame number, data, and CRC. Fields are used to produce packets. Depending on the packet function, a different combination and number of fields can be used. • Packet types include: token, start of frame, data, and handshake. Packets are assembled into groups to produce transfers, transactions, and frames. • Transfers fall into four groups: bulk, control, interrupt, and isochronous. • Transactions fall into four groups: IN, OUT, SOF, and SETUP. Data flow is relative to the USB host controller. IN packets represent data flow from the USB client controller to the host controller. OUT packets represent data flow from the USB host controller to the client controller. Figure 12-1 graphically represents the communications layers in the protocol. See the Universal Serial Bus Specification, Revision 1.1 for more details on USB protocol. The UDC uses single-ported memory to support FIFO operations. Bulk, isochronous, and interrupt endpoint FIFO structures can be double-buffered to enable the endpoint to process one packet while assembling another. Use either DMA or the Intel XScale® core to fill and empty the FIFOs. An interrupt, DMA service request, or polling can be used to detect packet receipt.  The USB host controller referenced in this chapter refers to any USB host controller that is compliant to the Universal Serial Bus Specification, Revision 1.1, including the PXA27x processor’s internal USB host controller.  Figure 12-1. Communications Protocol Layers in the USB Client Controller
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 40 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Features • USB Revision 1.1, full-speed compliant device • 23 programmable endpoints — Type: bulk, isochronous, or interrupt — Direction: in or out — Maximum packet size — Programmable configuration, interface and alternate interface setting numbers • Endpoint 0 for control IN and OUT • Four configurations: — Three programmable configurations with up to seven interfaces with seven alternate interface settings — Default configuration 0 with one interface and control endpoint 0 • Configurable 4-Kbyte memory for endpoint data storage    Signal Descriptions This section describes the signals used by the USB client controller (See Table 12-1).  Table 12-1. USB Client Controller Interface I/O Signal Descriptions  Bidirectional Signals USBC_P and USBC_N are the differential lines of the USB cable. Using differential signaling allows transmitting multiple states on the serial bus. These states are combined to transmit data as well as various bus conditions, including: idle, resume, start-of-packet (SOP), end-of-packet (EOP), disconnect, connect, and reset. Four distinct states are represented using differential data by decoding the polarity of the USBC_P and USBC_N pins. Two of the four states are used to represent data. A one is represented when USBC_P is high and USBC_N is low; a zero is represented when USBC_P is low and USBC_N is high. The remaining two states and pairings of the four encodings are decoded further to represent the current state of the USB. Table 12-2 shows how seven different bus states as well as one and zero are represented using differential signaling.  Table 12-2. USB States Using Differential Signaling
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 41 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Operation The UDC consists of four major components: the peripheral bus interface, endpoint memory, endpoint control, and USB interface. The peripheral bus interface contains the UDC control and status registers for the endpoint configuration data and provides the interface between the PXA27x processor and the USB data. The endpoint memory is a 4-Kbyte SRAM used for USB endpoint data storage. It has 32 bytes dedicated to endpoint 0, allowing the remainder of its memory to be allocated to any of the 23 programmable endpoints. The endpoint control and USB interface blocks provide the USB functionality. Figure 12-2 is a block diagram of the USB client controller and its dedicated I/O.    Figure 12-2. USB Client Controller Block Diagram   Peripheral Bus Interface and Control/Status Registers The UDC is a slave peripheral device that is connected to the internal peripheral bus. All userinitiated accesses to the UDC registers and endpoint memory are completed using the internal peripheral bus. The control and status registers include registers for frame-number storage, UDC top-level control and status, interrupt control and status, endpoint control, status, and data transfer. The UDC Control register (UDCCR) provides control and status of internal UDC functions. The UDCCR status bits indicate the current USB configuration, interface, and alternate interface setting numbers assigned the UDC by the USB host controller. The UDCCR also contains a status bit to indicate if the UDC is actively communicating on the USB, and a status bit to indicate an unusable endpoint memory configuration. The UDCCR also allows selection of UDC enable for USB operation, UDC resume, and endpoint memory configuration control   Either processor interrupts or polling can be used to determine whether USB activity occurs. The Frame Number register (UDCFNR) holds the frame number contained in the last received start-offrame (SOF) packet.  Although the UDC can generate only a single interrupt to the processor’s interrupt controller, there
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 42 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  are 53 sources for this interrupt. Each of the 24 endpoints (0 and A–X) has two interrupts: packet complete and FIFO error. In addition, the UDC has five interrupts that can be generated based on USB activity. The interrupt sources are shown in the UDC Interrupt Status registers, which must be read to determine the cause of the interrupt being generated. In addition, USB activity can be determined by reading the UDC Interrupt Status registers. If polling is used, the Endpoint Control/ Status registers can be read to determine activity on the USB. The UDC Interrupt Control registers contain interrupt-enable bits that enable the generation of the UDC interrupt. When an interruptible event occurs, the appropriate status bit in the Endpoint Control/Status register is set, and if the corresponding interrupt-enable bit in the Interrupt Control register is set, then the appropriate bit in the Interrupt Status register is set and an interrupt is generated. An interrupt is cleared by setting the appropriate bit in the Interrupt Status registers  Endpoint 0 is the only control endpoint and the only bidirectional endpoint in the UDC, and has characteristics different from the programmable endpoints A–X. Key characteristics of endpoint 0 include the following: • Control/Status, Byte Count, and Data registers • Configuration is fixed and does not use a configuration register • Enabled for every USB configuration and interface • Bidirectional endpoint with 32 bytes of USB data-storage space allocated in the endpoint memory: 16 bytes of FIFO memory are used for IN data and 16 bytes are used for OUT data • USB data space is not double-buffered. • Only endpoint configured and available for USB operation after USB reset, and before the USB host controller has enumerated the UDC The Endpoint 0 Control/Status and Byte Count registers provide the status of the endpoint 0 IN and OUT buffers. The Receive FIFO Not Empty bit (UDCCSR0[RNE]) and OUT Packet Complete bit (UDCCSR0[OPC]) are set when a complete data packet has been received from the USB host controller. If the packet is part of a SETUP transaction, the Setup Active bit (UDCCSR0[SA]) is also set. The endpoint 0 transmit FIFO is flushed by the UDC after receiving an OUT data packet from the USB host controller. The Byte Count register (UDCBCR0) indicates the number of bytes of data that need to be unloaded from the receive buffer. As data is read from the endpoint 0 receive buffer using the Endpoint 0 Data register UDCDR0, the Byte Count register value is decremented to indicate the number of bytes remaining in the buffer. When all of the data has been unloaded from the receive buffer, UDCCSR0[RNE] is cleared by the UDC to indicate the receive buffer is empty. After reading all of the data from the endpoint 0 receive buffer, software must clear UDCCSR0[OPC] to enable the buffer to receive another USB data packet. Loading a maximum packet size of 16 bytes into the endpoint 0 transmit FIFO automatically sets UDCCSR0[IPR]. If less than 16 bytes are loaded into the endpoint 0 transmit FIFO, UDCCSR0[IPR] must be explicitly set to indicate a complete packet has been loaded. When the data has been transmitted to the USB host controller, the UDC clears UDCCSR0[IPR] to indicate the packet has been sent   Each of the 23 programmable endpoints, referred to as endpoints A–X, has a Configuration register, Control/Status register, Byte Count register, and a Data register. The Configuration registers set the configuration, interface, alternate setting and endpoint numbers, and maximum packet size, as well as enable double-buffering for each endpoint. The Configuration registers can be written only when the UDC is not enabled (UDCCR[UDE] is clear). When UDCCR[UDE] is set, the endpoint configurations are loaded into the USB interface block and are set to read-only access.  The Control/Status, Byte Count, and Data registers control the operation of each endpoint after enumeration. If an endpoint has double-buffering disabled, the Control/Status and Byte Count registers provide the status of the endpoint buffer. If the endpoint is configured as an OUT
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 43 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  endpoint, the FIFO Service (FS) and Packet Complete (PC) bits in the Endpoint Control/Status register are set when a complete data packet has been received from the USB host controller. The Byte Count register of each endpoint indicates the number of data bytes that need to be unloaded from the buffer. As data is read from the FIFO memory using the Data register, the corresponding Byte Count register value is decremented to indicate the number of bytes remaining in the buffer. When all of the data has been unloaded from the FIFO memory, the FS and Buffer Not Empty/Buffer Not Full (BNE/BNF) bits in the Control/Status register and the Byte Count (BC) in the Byte Count register are cleared by the UDC to indicate the current buffer is empty. After reading all of the data from the endpoint buffer, software must clear the PC bit in the corresponding Control/Status register.  If an OUT endpoint has double-buffering enabled, the Control/Status and Byte Count registers provide the status of the endpoint buffer that is currently active. The FS, PC, and BNE/BNF bits in the Endpoint Control/Status register are set when the first buffer has received a complete data packet. The short-packet (SP) bit indicates a packet smaller than the maximum packet size has been received and is ready for unloading, or has been loaded and is ready for transmission. The Data register unloads data from the first buffer. The Control/Status and Byte Count registers continue to hold the status of the first buffer until software clears the PC bit in the Control/Status register. As the data is read from the first receive buffer, the value in the Byte Count register is decremented and indicates the number of data bytes that still need to be read from the first buffer in the FIFO memory. When all of the data in the first buffer has been read, the Byte Count register and the BNE/BNF bit in the Control/Status register are cleared. If a second packet is received before all of the data has been read from the first buffer, the FS bit continues to be set after the first buffer is been read, but the second packet of data does not set the PC bit until after software has cleared the PC bit. The status of the second buffer cannot be determined until the PC bit is cleared. The PC bit must be set to update the Control/Status and Byte Count registers with the status of the second buffer. If the PC bit is set before reading all of the data in the first receive buffer, the data in the first receive buffer is lost. If the second buffer has received a complete data packet, the PC bit is again set to indicate that the endpoint FIFO has data ready to be unloaded, and the BNE/BNF and Byte Count registers indicate the amount of data present in the second buffer. At this point, the Data register unloads data from the second buffer. The Control/Status and Byte Count registers continue to hold the status of the second buffer until software again clears the PC bit. Only after all of the data has been read from the second buffer must the PC bit be set. Doing so updates the Control/Status and Byte Count registers to reflect the status of the first buffer.   Suspend and Resume If idle persists on the USB for more than 3 ms, the UDC detects the suspend state, and (if the suspend interrupt is enabled) an interrupt is sent to the processor. When the UDC enters the suspend state, the processor stops the 48-MHz clock to the UDC and enables the UDC pins USBC_P and USBC_N to detect the resume state. If the processor does not enter sleep mode, the state of the UDC is preserved and is ready for resume detection. Note: The presence of SOF packets prevents the UDC from entering suspend mode. The UDC can exit suspend in three ways: • Resume initiated by the UDC • Resume initiated by the USB host controller • USB reset If the USB host controller has executed the SET_FEATURE command and enabled the device
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 44 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  remote wake-up feature of the UDC, after the UDC has entered the suspend state, sending a wakeup signal to the USB host controller is performed by setting UDCCR[UDR]. Doing so forces the UDC to drive a non-idle state (K state) onto the USB for 3 milliseconds without further user intervention. The UDC hardware then clears UDCCR[UDR]. The UDC waits for the resume signal to be reflected back to it by the USB host controller, and when the resume state is detected on the USB, if the resume interrupt is enabled, an interrupt is sent to the processor. The USB host controller can wake up the UDC by driving the non-idle state (K state) either by driving a resume or USB reset onto the USB. When the UDC pads detect this non-idle state on the USB, they signal the processor clock manager module to start the 48-MHz clock to the UDC, and (if the resume interrupt is enabled) an interrupt is sent to the processor. Software must take the appropriate action to resume activity.    Sleep Mode Operation If the UDC has entered the suspend state before the PXA27x processor is in sleep mode, the UDC pins USBC_P and USBC_N are used to detect the resume state on the USB and resume operation while the processor is in sleep mode. If the USB host controller tries to access the UDC when the processor is in sleep mode, the USBC_P and USBC_N pins detect the resume state and signal the processor to begin the wake-up sequence. The UDC will have lost all state information and the UDC Configuration registers must be reloaded prior to setting UDCCR[UDE]. The USB host controller must issue a USB reset and re-enumerate the UDC.   If the UDC has been disconnected from the USB and the processor is in sleep mode, a GPIO pin must be programmed to detect connection to the USB and to signal the processor to begin the wake-up sequence. The GPIO pin must be connected through a level-shifter to the USB power signal to detect connect/disconnect to the USB. The UDC will have lost all state information and users must load the UDC Configuration register and enable the UDC before the UDC is ready for USB operation. USB On-The-Go Operation The processor USB device and host controllers can be used to provide A- and B-device On-The-Go (OTG) operation as specified in the On-The-Go Supplement to the USB 2.0 Specification. The onchip OTG transceivers provide on-chip pull-up and pull-down resistors as specified in the Pull-up/ Pull-down Engineering Change Notice to the USB 2.0 Specification. OTG operation requires user intervention but interrupts are provided to notify the user of OTG activities including Vbus changes, session detection, and OTG ID changes. The user must use these interrupts along with the OTG control and status registers to operate as an OTG device. The UDC OTG support includes the following: • Decoding of SET_FEATURE commands with OTG specific selector values • Control for on-chip OTG transceiver with multiplexing between UDC and USB host controller (UHC) port 2 • Control for multiplexing between UDC, UHC port 2 and UHC port 3 data through GPIOs • Control, status and interrupt registers for interfacing to off-chip OTG transceivers • Control, status and interrupt registers for interfacing to off-chip charge pump devices • OTG ID support Figure 12-15 shows each of the configurations provided to support OTG operation. Each of these is
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 45 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  discussed in detail. Note: The processor does not provide direct connection to or control of the USB Vbus. Figure 12-15. USB OTG Configurations     On-Chip OTG Transceiver Operation The USB host port 2 transceiver is designed in accordance with the Pull-up/Pull-down Resistors Engineering Change Notice to the USB 2.0 Specification to provide on-chip resistors and OTGcompliant transceiver operation. The USB host controller port 2 multiplexor is a bidirectional I/O multiplexor that connects to the USB host port 2 transceiver and the single-ended I/O through the GPIO. The port 2 multiplexor provides an interface that allows the UDC port or UHC port 2 to connect to the UHC port 2 transceiver for direct bidirectional connection to the USB. The port 2 multiplexor also provides an interface that allows the UDC port, UHC port 2, and the UHC port 3 to connect to single-ended I/O through the GPIOs. The OTG transceiver contains two pull-up resistors and one pull-down resistor on each D+ and D– that can be enabled using the USB Port 2 Output Control Register (UP2OCR) pull-up/pull-down enable bits (DPPUBE, DMPUBE, DPPUE, DMPUE, DPPDE, DMPDE). Figure 12-16 illustrates the on-chip host port 2 transceiver pad with the pull-up and pull-down resistors. • Enable SW3 for both D+ and D– when host port 2 is being used for USB host controller data. • Enable SW1 on the D+ pad and disable SW1 on the D– pad when host port 2 is being used for USB device controller data. • Disable SW2 on the D+ and D– pads when host port 2 is being used for USB device controller data. • SW2 is enabled and disabled by hardware when the UDC is idle and receiving data from an upstream device as specified in the Pull-up/Pull-down Resistors Engineering Change Notice to the USB 2.0 Specification. Table 12-9 lists the switch settings used for the USB host and USB device controller I/O.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 46 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Figure 12-16. Host Port 2 OTG Transceiver   Interface to External OTG Transceiver In the case where the user does not use the internal OTG transceiver, the UDC contains control, status, and interrupt registers to provide seamless interfacing to external transceivers. External transceivers can be used to provide D+, D–, and Vbus driver to the USB. In this mode, the USB D+ and D– signals are output through GPIO pads with UP2OCR[SEOS] used to control multiplexors to select between UDC and USB host controller D+, D–, and transmit enable signals. In addition, the USB Port 2 Output Control Register (UP2OCR) provides the external transceiver suspend (EXSUS) and external transceiver speed (EXSP) control output bits, and the external transceiver interrupt input to interface to the external transceiver. Figure 12-17 illustrates the OTG connection to an external transceiver. Figure 12-17. Connection to External OTG Transceiver
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 47 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Note: For Figure 12-17, UP2OCR[SEOS] = 4 for USB client and UP2OCR[SEOS] = 5 for USB host.  Interface to External Charge Pump Device In addition to the interface options described in Section 12.5.4, the UDC provides control outputs and interrupt inputs to drive and monitor an external charge pump device. To do so, the USB D+ and D– signals can be output using the on-chip OTG transceiver and the Vbus interface provided by an external charge pump device. In this mode, UP2OCR[HXS] is used control multiplexors to select between UDC and USB host controller D+, D–, and transmit enable signals to be output through the USB host controller port 2 transceiver. In addition, USB Port 2 Output Control Register (UP2OCR) provides the charge pump Vbus enable (CPVEN) and charge pump Vbus pulse enable (CPVPE) control output bits used to enable the driving of Vbus and to enable the driving of pulses on Vbus, respectively. Additionally, USB Port 2 Output Control Register (UP2OCR) provides the Vbus valid 4.0-V, Vbus valid 4.4-V, session valid, and session request protocol detected interrupt inputs to interface to the external charge pump device. Figure 12-18 illustrates the OTG connections to an external charge pump device.  Figure 12-18. Connection to External OTG Charge Pump
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 48 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    Memory Stick Overview The Memory Stick is a medium for storing and transferring data. In its simplest form, the Memory Stick is a small, pluggable card containing flash (or other similar) memory. This memory can store multiple content types—for example, audio data or stored image data. In addition to this basic form, other devices are available that use the standard Memory Stick definition (for example, camera modules). The memory stick host controller provides the interface between the PXA27x processor and one Memory Stick. Note: The Sony Memory Stick Standard, Format Specification Version 1.3 (the Sony MS standard) defines the Memory Stick interface and provides the basis for this chapter. For all details of Memory Stick operation, refer to this Sony standard.  Features • Compliance with the Sony Memory Stick standard • Built-in transmit and receive FIFO buffers • Built-in CRC calculation and checking • Transfer clock up to 20 MHz • Data transfer using programmed I/O, interrupt to processor, and DMA • Automatic command execution when an interrupt from the Memory Stick is detected   Signal Descriptions Table 17-1 summarizes the signals used by the memory stick host controller.    Operation The memory stick host controller communicates with the Memory Stick using a half-duplex serial protocol. This section presents an overview of the protocol. Always refer to the Sony MS standard for details.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 49 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Functional Description The Memory Stick system, depicted in Figure 17-1, consists of the memory stick host controller and an attached Memory Stick card. Figure 17-1. Memory Stick System Block Diagram   The memory stick host controller interfaces with the Memory Stick using a 32-bit internal application interface. It allows: • Sending of transfer protocol commands (TPCs) to the Memory Stick using the MSHC Command register. • Data transfer using the two separate receive (RX) and transmit (TX) FIFOs (this data can be transferred using polling, interrupts to the processor, or DMA). • Responding directly to Memory Stick interrupts by issuing a predefined command, the AutoCommand (ACD). • Placing the card into a low-power mode. Interrupts The memory stick host controller generates a single interrupt to the interrupt controller. The cause of the interrupt can be determined by reading the Interrupt and Status register. Status bits in this register indicate which event caused the interrupt to be generated. Interrupts can be disabled (either individually or in total) by setting bits in the Interrupt Enable register.  To process an interrupt, MSINTEN[INTEN] must be set, and the enable bit for the specific interrupt in register MSINTEN must be set. It is possible for multiple secondary interrupts to occur if more than one MSINTEN register bit besides INTEN are set. To determine the specific cause of the interrupt, read the Interrupt and Status register, MSINT. To handle more than one interrupt at a time, set MSINTEN[INTEN] and the specific MSINTEN interrupt enable bits.  Memory Stick Insertion and Removal The nMSINS signal indicates the insertion and removal of a Memory Stick. nMSINS is connected to the interrupt controller, but not to the memory stick host controller. Thus, the interrupt controller must be programmed to generate an nMSINS interrupt.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 50 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Software must monitor the nMSINS interrupt. When an interrupt occurs due to the removal of the memory stick, the software must halt all MHSC activity and reset the memory stick host controller.  Reset The memory stick host controller is reset in either of two ways: • Any PXA27x processor reset causes all of the MSHC registers to be reset. • Setting MSCRSR[RST] causes the memory stick host controller to enter and remain in reset until MSCRSR[RST] is cleared. In this case, all of the registers except for the RST bit are reset, and the output signals BS, SDIO, and SCLK are driven low. Any currently-executing protocol is terminated when MSCRSR[RST] is asserted. These methods do not cause a reset TPC to be sent to the Memory Stick. Note: Before writing any of the control registers for a new bus protocol, always set MSCRSR[RST] and then clear it.  Power-Save Mode When the memory stick is not being used, software may optionally place it into a low-power mode. This is controlled entirely by software and is not related in any way to the PXA27x processor lowpower modes.  Figure 17-2 shows how to enter and exit the Memory Stick power-save mode. To maximize overall system power saving, software must place the Memory Stick in power-save mode prior to entering any of the system low-power modes.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 51 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A       LogicPD Card Engine:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 52 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 53 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 54 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Note: Our current Card Engine does support Ethernet.  Card Engine:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 55 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    TempTale Mini  During normal monitor operation, communications mode is disabled.  In order to enable the communications mode by means of the communications enable pin on the RS232 connector located inside the monitor.  This pin must be held during the entire communications session.  The monitor communicates via a standard RS232, 9600 baud rate, 8 bit, No Parity, 2 Stop bit protocol. (9600,8,N,2) Once the monitor has entered communications mode, the host PC is responsible for establishing a connection with the monitor.  If the host PC does not establish a connection within one minute’s time, the microcontroller within the monitor will disable communications mode thus terminating communications.  If this occurs, it will be necessary to re-enable the communications mode by re-triggering the communications enable line.  To establish a connection with the monitor, the host PC must send a sequence of Bytes to the monitor and receive the correct responses back from the monitor.  This sequence is designed to give the monitor time to wake-up and allow the host to log in. If any of the bytes are sent or received incorrectly or at the wrong time during the connection attempt, both the host and monitor should assume bad communications and return to their previous states.  The following table shows the steps that are taken to connect to the monitor:  Table 1 Step #  Host PC’s Action  Monitor’s Action  Action Description 1  Toggle Communications Enable Line (DTR) Detect Com Line toggle and enter in Comm. Mode Wake-up Monitor via RS232 line toggle 2  Send 00h   Rcv 00h and Send Product ID of 02h to host   Host send 00h Monitor replies by sending 2 byte Product ID of 02h, low byte 02h, high byte 00h, LSB first 3  Rcv ID and set-up for correct protocol Send Next Command Rcv command from host and act accordingly Host determines monitor type via ID value and sends next action command.  As can be seen in Table 2 above, the first thing to happen is the monitor enters communications mode via a change in state in the “detect” line from the RS232 connector. (“Detect” = Pin 4 (DTE Ready) of the DB9 connector) The host PC initiates communications by transmitting a 1-byte hex value of 0h to the monitor.   When the monitor is able to respond, it will reply by transmitting a 2-byte (16 bit) protocol ID hex value of 2h back to the host computer.  It does this by sending the low byte first and the high byte second.   The host PC then looks at the value that it got back for the protocol ID and determines what command protocol to use for communicating with the monitor. Once the host PC has successfully logged in and has established a connection with the monitor.  The host PC may now send predefined commands to the monitor, which allows it to do things such as, configure the monitor or download the data.  The command protocol and a list of the commands with their definitions are described in a later section.  It is also important to note that once a connection has been established, a 3-minute timeout timer is established within the monitor in place of the 1-minute timeout
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 56 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  timer.  This timer is used as a count down timer that determines the timeout period for communications between the monitor and host PC. Effectively what this means is that as long as this timer is refreshed and not allowed to expire, communications mode will stay active allowing commands to be sent.  The monitor refreshes this timer any time valid command is sent, so as long as commands continue to be sent, the monitor will continue to refresh the timer.  If no commands are sent to the monitor within 3 minutes, communications mode within the monitor will be terminated.  The reason for the 3-minute timeout timer is to maximize the battery life of the monitor. Because of the power drain associated with the communications mode, if the communications mode were allowed to continue indefinitely, the battery would be drained very quickly.   Once the parameters or the 0h have been received, the monitor will then internally execute the command and return a status byte followed by any additional data.   A status byte is always returned from the monitor upon completing a command whether or not there is any additional data.  The status byte is always a single byte value.  A 0h value indicates successful completion of the command while a non-zero value indicates an error. A list of valid status codes with their names and descriptions are in the table below:    Status name  Code  Description CMD_SUCCESSFUL  0x00  Returned upon successful completion of command. CMD_UNKNOWN  0x02  The requested command is not part of the unit's API.  This is returned when a command does not exist.   PARAMETER ERROR  0x03  Parameter errors which are sent from the PC BAD_TEMP  0x04  When an immediate temperature is requested,  this value will be returned if the conversion process did not complete successfully. RESERVED (UNUSED)  0x05   BAD_INIT  0x07  The unit can not be initialized due to erroneous information having been stored in its configuration pages. UNIT_NEW  0x0A  The unit is newly manufactured and un-configured. UNIT_SLEEPING  0x0B  The unit is sleeping prior to activation. UNIT_SDELAY  0x0C  The unit has been activated and is waiting through the startup delay. UNIT_RUNNING  0x0D  The unit has completed the startup delay and is actively recording data. UNIT_STOPPED  0x0E  The unit has been stopped after running.   Depending on the command that was sent, the monitor may or may not send data after the status code.  For instance, if the high-speed download command is sent to the monitor, the monitor will send all of the temperature data after the status code has been sent.  The ULCM also supports a packet based command protocol which uses the same basic structure as the ULCM standard commands with the exception that the command parameters and return data are in packet form with a checksum attached.  If the command has parameters then the host sends the command parameter packet just after the monitor echoes back the command value.  If the command returns any data, then the monitor will return the data packet just after the status is sent.   The following figure illustrates this:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 57 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Figure 1  Executes Command Command Echo back command 0x00 or  Parameter Packet Status HOST PC  MONITOR ULCM PACKET COMMAND PROTOCOL Data Packet  Note: All data packets will consist of a 3 byte checksum position followed by the requested data ending with a Checksum     The command parameter packet and data packet use the same packet format, which is shown below:  Packet Data  Checksum 3 byte count of the number of parameters or data bytes to follow  Parameter or Data bytes   B0  B1  B2  D0, D1, D2, D3, ……….Dn  1Byte  For instance if a ULCM command to download all the data is sent to the monitor, the monitor will send (after the status byte) a packet containing a 3-byte value representing the number of data bytes to follow, the data (which includes summary information and temperature data), and a checksum.   For any packet, the checksum is the least significant byte of the sum of all the data in the packet including the 3-byte checksum position.  This is shown in the example below:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 58 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A                                                      If the packet contains 1120 data bytes and the value of all the bytes is a hex 76 then the sum of the count bytes and data bytes is as follows:  Count Byte 0  0x60 Count Byte 1 0x04 Count Byte 2  0x00 460H (1120D) Data Byte 0  0x76 Data Byte 1 0x76 Data Byte 2 0x76 . . . . . . Data Byte 1119 0x76 Data Byte 1120  0x76 Data Packet Data Sum equals   0x208A0  Sum Once the sum has been calculated, only the least significant byte, in this case 0xA0, is used as the checksum.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 59 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  TempTale 4 (Epson TT4)   Command Transmission Paradigm As a method of ensuring data integrity, the unit will always echo commands back to the host computer as it receives them. In this way the external device will know that the unit received a specific command correctly.   This method allows the host computer to respond in the fastest way.  If the unit echoes back the wrong command, the host computer merely disables communications, thereby forcing the unit to timeout while waiting for a go signal. If the command is to be followed by a series of data bytes, such as when the host computer is writing to the Scratchpad, that data is sent by the host computer upon receiving the echoed back command.  Otherwise a 0 is sent by the host to act as a go command.  The unit will then perform the requested action and return an action status byte.  Any data or information as required by the requested action will follow this byte.   commandExternalDevice TempTaleecho back command0x00 or parametersexecutecommandcommand statusany additional response data Status Byte Definitions A status byte is always returned from the unit upon completing a command.  This is a single byte value.  A '0' value indicates successful completion while a non-'0' indicates an error code.  Certain commands require the unit to be in a specific operating mode.  If that condition is not satisfied, the present mode is sent back as an error code.  Status bytes are listed in the table below.     Status name  Code  Description CMD_SUCCESSFUL  0x00  Returned upon successful completion of command. Deleted: RS232 Deleted:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 60 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  CMD_UNKNOWN  0x02  The requested command is not part of the unit's API.  This is returned when a command does not exist.  This error code is also returned if a command that is sent requires a higher access level than the user is presently in. BAD_PASSWORD  0x03  During the course of logging into the unit, the supplied password is incorrect. BAD_TEMP  0x04  When an immediate temperature is requested,  this value will be returned if the conversion process did not complete successfully. IIC_TIMEOUT  0x05  During the course of accessing the internally paged memory, either a read or write time out occurred. BAD_INIT  0x07  The unit can not be initialized due to erroneous information having been stored in its configuration pages. UNIT_NEW  0x0A  The unit is newly manufactured and un-configured. UNIT_SLEEPING  0x0B  The unit is sleeping prior to activation. UNIT_SDELAY  0x0C  The unit has been activated and is waiting through the startup delay. UNIT_RUNNING  0x0D  The unit has completed the startup delay and is actively recording data. UNIT_STOPPED  0x0E  The unit has been stopped after running.   Communication Layer Descriptions The unit utilizes a layered communications protocol.  The default layer is no-communications or Data Recorder mode (unit recording temperature data).  The host computer moves from layer 0 to layer 1 and succeeding layers by successfully sending the appropriate command or sequence of commands.  Presently there are a total of 5 layers.  The following table lists the layers by name and description.      Layer #  Layer Name  Layer Description 0  Data Recorder   No communications - Awaiting communication initialization sequence. 1  Identification/ Networking  Communications Established – Awaiting unit identification/networking commands. 2  Login/Status  Unit Identified - networking issues handled - awaiting user login. 3  Customer Login (password disabled.) Logged in Customer privilege - all general user commands available. 4  Sensitech login  (password req.)  Logged in with Sensitech privilege.  All unit commands available including test and general commands.  Data Recording Layer There is no  way of telling what the unit  may be doing when the  host computer tries to initiate communications.  It may be recording data in which case communications are disabled.  It may be in sleep mode, in which case waking up can take 500 milliseconds. One last issue that the unit has
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 61 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  to deal with erroneous communication attempts.  Movement from layer 0 to layer 1 is designed to eliminate these issues.  Communication is initiated by transmitting a startup sequence of bytes to the unit.  This sequence is designed to give the unit time to wake-up, respond, and synchronize to the host computer’s baud rate.  Unless all steps are performed correctly, the unit will assume bad communications and return to what it was doing.  The bytes transmitted are as follows.  The host computer initiates communications by transmitting a 0x00 to the unit.  When the unit is able to respond to the attempt it will reply by transmitting a 0x00 back to the host computer.  At this  point  the  baud  rate  has  not  been  established  and  the  computer  will  receive  back  garbage.  Possibly more than one byte.  Even though the computer will probably not receive a 0x00, any returned value(s) should be accepted as an indication to continue.  The unit having sent the 0x00, then sets up to receive a 0x55 hex value from the host computer.  The host computer having received the acknowledging 0x00 (or the best approximation thereof) will  have  ≈500msec  to  transmit  the  next  byte  in  the  sequence  before  the  unit  terminates  the communications attempt. The host then transmits a 0x55.  The unit will use this pattern of 0’s and 1’s  to  lock  onto  the  host  computer’s  baud  rate.    If  any  other  value  is  received  the  unit  will terminate communications and return to what it was doing previously.  Communications will then be disabled until the next temperature is taken.  This prevents the unit from constantly responding to a bad communications attempt.  Having received the 0x55 correctly the unit will respond by again transmitting a 0x00 back to the host.  This time the baud rate is correct and the host computer should correctly receive the 0x00.  The host uses this received 0x00 as an indication to transmit the final 4-byte sequence.  Again the host must  transmit the  final 4  bytes  in  less  than  ≈1.0  second  or  the  unit will terminate what  it thinks is a bad communications attempt.   The final sequence of 4 bytes is 0x7A, 0x5E, 0x8A, and 0xA1.  This last action accomplishes two goals.  It verifies that the unit has indeed locked onto to the correct baud rate and it acts as a simple password against a bogus communications attempt.  If the  unit  does  not  receive  the  correct  4-byte  sequence  either  due  to  bad  communications  or improper baud rate, it will again end communications and return to what it was doing previously.  The unit having received the final four-byte sequence correctly responds by transmitting a 0x00 for a third and final time to the host.  The unit is now set to the Network/Identification or layer 1 communications.  The table below shows the sequence of events required to initiate communications with the unit.     Computer Action  Unit Response  Action Description xmit 0x00  Reply 0x00  Get unit’s attention Rcv something  -  signal to xmit next byte within .5 seconds xmit 0x55  Reply 0x00  Unit establishes baud rate and responds rcv 0x00    signal to xmit final 4 byte sequence within 1 second xmit 0x7A  -  Sanity check on baud rate detection xmit 0x5E  -   xmit 0x8A  -   xmit 0xA1  Reply 0x00  Sanity check successful – respond rcv 0x00  -
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 62 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    TempTale 4 (OKI TT4)  Communications The Monitor has an Infrared optical interface as its primary means for communication to the outside world.  There are also provisions made on the PCB for a hard-wired asynchronous 0 to +3 volt logic level output.  On the optical port, an infrared phototransistor is used to sense data being input to the device and an infrared LED is used to transmit data out of the device. This interface will be used for communicating between an external device (PC w/Interface Plus and TripStrip) and the Monitor.  The hard-wired connection is currently not used but is available for future peripherals.  Any peripheral device that plans to use this connection will be responsible for any added circuitry that may be required such as voltage level translation, static protection, drivers, etc.  It will also be the peripheral devices responsibility to supply any power that is needed to operate the added circuitry. On both interfaces, the data will be transmitted asynchronously using standard RS232 serial protocol.  This allows the monitor to connect to a standard RS232 serial port with very little effort. The monitor UART is setup to receive/transmit data at 9600 Baud with 8 data bits, no parity bit and two stop bits.  This can be seen in the diagram below.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 63 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Establishing a Connection During normal monitor operation, communications mode is disabled.  There are two ways to enable the monitor’s communications mode.  The first method is for an external device to trigger the monitor’s internal reed switch by means of a magnet.  If this approach is used, the magnet must keep the reed switch triggered during the entire communications session. The second method is to enable the communications mode by means of the communications enable pin on the J2 connector located inside the monitor.  This pin must be pulled to ground and held there during the entire communications session. Once the monitor has entered communications mode, the host PC is responsible for establishing a connection with the monitor.  If the host PC does not establish a connection within one minute’s time, the microcontroller within the monitor will disable communications mode thus terminating communications.  If this occurs, it will be necessary to re-enable the communications mode by either re-triggering the reed switch by removing it from the magnet for approximately 500msec and then placing it back near the magnet or by pulling the communications enable pin high for approximately 500msec and then back to ground. To establish a connection with the monitor, the host PC must send a sequence of Bytes to the monitor and receive the correct responses back from the monitor.  This sequence is designed to give the monitor time to wake-up and allow the host to log in. If any of the bytes are sent or received incorrectly or at the wrong time during the connection attempt, both the host and monitor should assume bad communications and return to their previous states.  The following table shows the steps that are taken to connect to the monitor:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 64 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    Step #  Host PC’s Action  Monitor’s Action  Action Description 1  Send 00h  Rcv 00h and discard  Wake-up Monitor by sending 1 byte 2  Rcv Protocol ID and set-up for correct protocol Send Protocol ID, low byte 01h, high byte 00h Acknowledge wake-up by sending back a 2 byte protocol ID of 1 3  Send 55h  Rcv value and verify it is a 55h  Send 1-byte value so monitor can verify correct baud rate. 4  Rcv 00h byte or timeout and start over Send 00h byte or terminate login process If check for 55h is good, acknowledge by sending back a 00h, otherwise terminate login process and start over. 5  Send 4 byte login value  Rcv 4 byte login value and verify  Send 4-byte login value. 7Ah, 5Eh, 8Ah, A1h to verify access to the monitor 6  Rcv 00h byte or timeout and start over Send 00h byte or terminate login process If check for login values is good, acknowledge by sending back a 00h, otherwise terminate login process and start over.    As can be seen in Table above, the first thing to happen is the host PC initiates communications by transmitting a 1-byte hex value of 0h to the monitor.  This byte is sent to generate an interrupt in the monitor causing it to wake up.  When the monitor is able to respond, it will reply by transmitting a 2-byte (16 bit) protocol ID hex value of 1h back to the host computer.  It does this by sending the low byte first and the high byte second.  At this point, the host PC looks at the value that it got back for the protocol ID and determines what command protocol to use for communicating with the monitor. Next, the host PC sends a 1-byte hex value of 55hto the monitor.  The monitor then receives the value from the host computer and verifies whether it received a 55h or not.  If it determines that the 55h was received correctly, it will send back a 1-byte value of 0h.  If it does not receive the 55h correctly then it will terminate the login process, return to what it was doing, and wait for the host to start over.  If the host does not retry, then the monitor will timeout after 1 minute and the monitor will ignore any attempts to communicate with it.  If the timeout occurs it will be necessary to re-enable the communications mode and start the whole connection process over again.  The purpose of sending a 55h to the monitor is to verify the baud rate is correct by letting the host PC know that it understood what was sent.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 65 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  In the case above where the host computer correctly receives a 0h back from the monitor, the host will then send the final 4-byte login sequence to the monitor.  The final sequence of 4 bytes is 7Ah, 5Eh, 8Ah, and A1h. The monitor should receive the 4 values from the host computer and verify whether or not they are correct.  If it determines the values were received correctly, it will send back a 1-byte value of 0h.  If the monitor receives any of the bytes incorrectly, it will terminate the login process, return to what it was doing, and wait for the host to start the whole login process over.  If the host does not retry, then the monitor will timeout after approx. 1 minute and will ignore any attempts by the host to communicate with it.  At this point it would be necessary to re-enable the communications mode and start the whole connection process over again.  This last action of sending 4 consecutive bytes accomplishes two goals.  It again verifies that the unit is indeed receiving data at the correct baud rate and it acts as a simple password against any bogus communications attempts.  Once the host PC has successfully logged in and has established a connection with the monitor.  The host PC may now send predefined commands to the monitor, which allows it to do things such as, configure the monitor or download the data.  The command protocol and a list of the commands with their definitions are described in a later section.  It is also important to note that once a connection has been established, a 15-minute timeout timer is established within the monitor in place of the 1-minute timeout timer.  This timer is used as a count down timer that determines the timeout period for communications between the monitor and host PC. Effectively what this means is that as long as this timer is refreshed and not allowed to expire, communications mode will stay active allowing commands to be sent.  The monitor refreshes this timer any time valid command is sent, so as long as commands continue to be sent, the monitor will continue to refresh the timer.  If no commands are sent to the monitor within 15 minutes, communications mode within the monitor will be terminated.  The reason for the 15-minute timeout timer is to maximize the battery life of the monitor. Because of the power drain associated with the communications mode, if the communications mode were allowed to continue indefinitely, the battery would be drained very quickly.  A battery that would last a year under normal operation may only last a few days if the communications mode were enabled continuously. Command Protocol The Omega TT4 command protocol is based on a Command/Response type architecture.  This approach works on the principle were the host is in charge of the communications session and issues commands for the monitor to act on.  The Omega TT4 supports all of the same commands as its predecessor the TT4 (which will be referred to as “Omega TT4 Standard Commands”) as well as new commands (referred to as “Omega TT4 Extended Commands”), which use the same basic format with the exception that the command parameters and return data are in packet format with a checksum.  This packet format was implemented to increase the speed of the
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 66 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  communications.  The figure below illustrates a typical Omega TT4 Standard Command exchange between the host and monitor:     Executes Command Command Echo back command 0x00 or parameters Status Any additional data HOST PC  MONITOR TT4 PLUS STANDARD COMMAND PROTOCOL      As can be seen in the diagram, the host initiates a command by sending a command value to the monitor.  The monitor then echoes back the same command value. This way the host device will know that the unit received a specific command value correctly.  If the unit echoes back the wrong command value, the host computer merely ends communications, thereby forcing the monitor to timeout. If the host receives the correct command value back from the monitor, the host will send either a 0h or command parameters.  If a command requires parameters, such as the “Write Scratchpad” command, the host computer upon receiving the echoed back command would send the parameters at this time.  For commands that do not require any parameters, the host will send a 0h to act as a go signal. Once the parameters or the 0h have been received, the monitor will then internally execute the command and return a status byte followed by any additional data.   A status byte is always returned from the monitor upon completing a command whether or not there is any additional data.  The status byte is always a single byte value.  A 0h value indicates successful completion of the command while a non-zero value
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 67 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  indicates an error. A list of valid status codes with their names and descriptions are in the table below:  Status name  Code  Description CMD_SUCCESSFUL  0x00  Returned upon successful completion of command. CMD_UNKNOWN  0x02  The requested command is not part of the unit's API.  This is returned when a command does not exist.   BAD_INIT  0x07  The unit cannot be initialized due to erroneous information having been stored in its configuration pages.  Depending on the command that was sent, the monitor may or may not send data after the status code.  For instance, if the high-speed download command is sent to the monitor, the monitor will send all of the temperature data after the status code has been sent.  The Omega TT4 also supports a new packet based command protocol which uses the same basic structure as the Omega TT4 standard commands with the exception that the command parameters and return data are in packet form with a checksum attached.  If the command has parameters then the host sends the command parameter packet just after the monitor echoes back the command value.  If the command returns any data, then the monitor will return the data packet just after the status is sent.   The following figure illustrates this:   Executes Command Command Echo back command 0x00 or  Parameter Packet with Checksum Status HOST PC  MONITOR TT4 Plus PACKET COMMAND PROTOCOL Data Packet With Checksum
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 68 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  The command parameter packet and data packet use the same packet format, which is shown below:  Packet Packet Data  Checksum 3 byte count of the number of parameters or data bytes to follow  Parameter or Data bytes   B0  B1  B2  D0, D1, D2, D3, ……….Dn  1Byte  For instance if a Omega TT4 command to download all the data is sent to the monitor, the monitor will send (after the status byte) a packet containing a 3-byte value representing the number of data bytes to follow, the data (which includes summary information and temperature data), and a checksum.   For any packet, the checksum is the least significant byte of the sum of all the data in the packet including the 3-byte count.  This is shown in the example below:                                If the packet contains 1120 data bytes and the value of all the bytes is a hex 76 then the sum of the count bytes and data bytes is as follows:  Count Byte 0  0x60 Count Byte 1  0x04 Count Byte 2  0x00 460H (1120D) Data Byte 0  0x76 Data Byte 1  0x76 Data Byte 2  0x76 .  . .  . .  . Data Byte 1119  0x76 Data Byte 1120  0x76 Data Packet Data Sum equals   0x208A0 Sum Once the sum has been calculated, only the least significant byte, in this case 0xA0, is used as the checksum.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 69 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   TT4 Optical Interface Circuit The circuit consists of a NAND gate IC which inverts the TX signal (input).   The input UP_UARTC_TX (B) is High and the input (A) is High, then the output is Low and the LED will not conduct. However, when the TX line transitions from a High to Low state, then the NAND gate output is High which the LED will begin to conduct.  The UP_UARTC_RX line is Low when light turns the Phototransistor ON. However, when there is no light, the Phototransistor is OFF; therefore, the UP_UARTC_RX line is High.    LCD The Trip Strip II will incorporate a monochrome FSTN 320 x 240 Transflective LCD display which will allow the user to display the temperature/humidity graph of a downloaded monitor.         EDT LCD LogicPD Evaluation Board (J11)    VDD  1  4  3.3V VSS  2  1  DGND VLCD  3  Booster Power Supply  VLCD (boost/pot output)  FLM  4  28  LCD_VSYNC n/c  5  n/c    CL1  6  30  LCD_HSYNC CL2  7  32  LCD_DCLK D0  8  26  B4 D1  9  24  B3 D2  10  23  B2 D3  11  22  B1 DISPOFF  12  35  LCD_MDISP VLED  13  3  5V VLSS  14  1  DGND
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 70 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Interface Signals:  Pin No.  Symbol  Function 1  VDD  POWER SUPPLY FOR LOGIC CIRCUIT 2  VSS  GROUND 3  VLCD  POWER SUPPLY FOR LCD DRIVING VOLTAGE 4  FLM  THE FLM SIGNAL INDICATING THE BEGINNING OF EACH DISPLAY CYCLE 5  N/C  N/C 6  CL1  DISPLAY DATA LATCH 7  CL2  DISPLAY DATA SHIFT 8  D0  DISPLAY DATA 9  D1  DISPLAY DATA 10  D2  DISPLAY DATA 11  D3  DISPLAY DATA 12  /DISPOFF  CONTROL LCD ON/OFF  “L”: DISPLAY OFF,  “H” DISPLAY ON 13  VLED  POWER SUPPLY FOR LED B.L 14  VLSS  POWER SUPPLY FOR LED B.L  Switching Characteristics:  PARAMETER  SYMBOL  MIN.  TYP.  MAX  UNIT CL1 PULSE WIDTH  tw1  30  -  -  ns CL2 PULSE  tw  51  -  -  ns RISE, FALL TIME  tr, tf  -  -  50  ns DATA SETUP TIME  tDSU  30  -  -  ns DATA HOLD TIME  tDHD  40  -  -  ns CL1 SETUP TIME  tLSU  51  -  -  ns CL1 to CL2 TIME  tLC   51  -  -  ns FLM SETUP TIME  tsetup  30  -  -  ns FLM HOLD TIME  thold  50  -  -  ns   LCD Power ON Sequencing:  1. Logic Circuit Power Supply 3.3VDC (no GPIO) 2. Data Signals (no GPIO) 3. LED Back Light Power Supply 5VDC (GPIO 22, LCD_BL_EN) 4. LCD Contrast Power Supply 3.3VDC (GPIO 12, VLCD_EN) 5. LCD Enable Signal “CONTROL LCD ON/OFF” (GPIO 77, LCD_MDISP)
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 71 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Keypad  The keypad will consist of 8 buttons which will provide control of the following functions.  There are 5 keys that will be dedicated to the navigation of the LCD selections consisting of an up, down, right, left and OK or select. The three remaining keys will control the power (ON/OFF), Print (START), and BACK. The method of communication with the Logic PD from the keypad will be in the form of GPIO interrupts. See the chart below for clarification:   TSII Keypad rows0-2 and columns0-2 identification 06/20/08 Reference:  Schematics V3.4.7 KEY IDs:                    row X, column Y  BACK             row 0, column 1 PRINTER       row 0, column 2  UP                    row 1, column 0 DOWN             row 1, column 1 ENTER/OK                row 1, column 2  LEFT             row 2, column 0 RIGHT                        row 2, column 1     Power       Charge    Paper   Low Batt Rev 5.27.08 BUTTONS  FUNCTIONS 1. BACK  1. Navigate to previous window or selection. Cancel. 2. ENTER  2. Execute command/entry. Executes menu structure. 3. UP Arrow  3. Navigate up 4. DOWN Arrow  4. Navigate down 5. LEFT Arrow  5. Navigate left 6. RIGHT Arrow  6. Navigate right 7. START   7. Download TT4 or TTmini and Print data 8. POWER  8. Initiate power to the unit or power OFF
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 72 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    9.0 Battery Low Alert Function: The Trip Strip II has a LED indicator which will indicate a low battery condition by steady red LED.  The circuit is comprised of two Comparators. If the Vin(+) terminal is Low and the Vin(-) terminal is High, then the output is Low (current will flow). However if the Vin(+) terminal is High and the Vin(-) terminal is Low, then the output is High (current will not flow).  Therefore, If the Load in the variable input (5 – 27VDC) is <= 6.5VDC, then the Low Batt LED will be ON. However, if the variable input is >6.8VDC, then the Low Batt LED is OFF. The other input VB = 3.3VDC, which is a fixed input.  If the variable input voltage (Load) is <=6.0VDC, then the Q107 FET (P-Channel) will close.   10.0 Line Thermal Head Printer: Citizen model # MLT-289 50mm thermal print head without the paper cutting functionality.   Head Temperature Detection  Thermistor Paper End Detection  Photointerruptor (LED Indication) Head-Up Detection  Mechanical Switch  Vp = 6.25VDC Vdd = 5VDC  The thermal head is comprised of heating elements and the head drivers that drive the heating elements. Serial print data, fed to the SI input, is shifted into the register synchronized with the Shift clock, then is latched into the latch register at the active edge of the LATCH signal. The Head Drive signal (Print commands STR1-6) opens the gate to energize the heating elements reflecting the print data.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 73 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Motor driving pulse rate:    Motor driving speed varies with driving voltage. It is determined with the following formula:  Motor driving speed (pps) = [200 * (Vp) – 600] Therefore, for our application Vp = 6.25VDC. As a result, [200 * (6.25) – 600] = 650 pps    11.0 Control Board       Dip Switch Setting:  Pin No.  Function  ON  OFF DS1-1  Auto Cutter    X 1-2  CR Selection  X   1-3  Print Density    X 1-4  DTR/XON-XOFF  X   1-5  Baud Rate  X   1-6  Baud Rate    X 1-7  Baud Rate  X   1-8  Baud Rate    X
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 74 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Note: 1-5 to 1-8 configurations (above) indicate 19,200 bps Baud Rate.     When BUSY signal is “LOW”, data from the host can be received. During a “HIGH” state, data cannot be received.  This control board incorporates a 2K byte buffer. Therefore, large amount of data can be buffered in input buffer and the Host side can be released immediately.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 75 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Printer Control Board Pinouts:
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 76 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A   Device System Configuration Information  LogicLoader (LoLoTM)  LogicLoader Overview  The  LogicLoader  (LoLo)  is  a  bootloader/firmware-monitor  program  developed  by  Logic  Product Development.  LogicLoader  is  designed  to  initialize  an  embedded  device,  load  and  bootstrap  an operating system, and provide a low-level firmware monitor with debugging functionality.  LogicLoader Basics  Most operating systems rely on an underlying bootloader to initialize a device from its reset condition. In general, operating systems are designed with the assumption that the system will be in a specific pre-defined state before the operating system is started. Some example assumptions might be that system RAM  has  been  initialized  and  cleared,  processor  interrupts  are  disabled,  and  a  timer  has  been initialized  to  provide  a  system  tick  for the OS.  The  LogicLoader  program initializes  Logic Product Development’s SOM platforms and prepares them for use by an operating system.  Another basic function of LogicLoader is the capability to upgrade device software (flash memory, CPLD firmware,  serial  EEPROM  contents)  after  deployment.  This  “in-field  upgrade”  ability  requires  a bootloader  program  that  is  capable  of  loading  software  images  from  various  sources  as  well  as committing loaded images to non-volatile memory. LogicLoader implements this by giving the system the ability to load system software from flash  memory, a  CompactFlash  storage card,  a  Local Area Network, or even from a device attached to the system’s serial port. LogicLoader also has the ability to upgrade an existing operating system residing in system flash.  LogicLoader was developed to fulfill the need for an OS and processor independent bootloader that can interface  with  a  variety  of  hardware  transports.  The  GNU  development  tool  chain  used  to  build LogicLoader is cross-platform capable.   Using LogicLoader for Debugging  LogicLoader implements a  feature-rich firmware monitor. Included with LoLo is the  LogicLoader shell, also  known  as  “losh.”  Losh  is  a  command  interpreter  providing  control  over  system  state  prior  to loading  an  OS  image.  It  has  features  such  as  command  recall,  command-line  editing,  automated control via scripting, and diagnostic routines.  Losh includes many commands designed specifically to help software and hardware engineers debug low-level  interfaces.  For  example,  formatted  data  in  arbitrary  memory  locations  can  be  read  from,  and written to, by using the 'x' and 'w' commands. Other commands run specific tests designed to verify Logic’s SOM hardware platforms. All commands return a value to the command line that can be used to conditionally evaluate the command result. Refer to the LogicLoader Command Description Manual on Logic’s downloads page for a complete description of available commands.  Developers may code their own test programs using the provided GNU development tool chain and use the LogicLoader to load and run their software. This provides the  ability to  verify and debug hardware interfaces without the overhead of building, downloading, and running large operating system images.   Manufacturing Advantages with LoLo  LogicLoader  can  be  used  with  a  desktop  software  utility  to  load  a  device’s  system  software  on  the manufacturing line. This utility is customizable to suit your desired transfer mechanism and additional
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 77 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  needs. LogicLoader can also be augmented with functional test software to completely verify a device before  it  leaves  the  manufacturing  line.  Here  is  an  example  scenario:  LogicLoader  could  launch  a device’s  final  functional  test  at  the  end  of  a  manufacturing  line,  and  then  load  the  device’s  final software  image  before  packaging.  Contact  Logic  for  more  information  on  using  LogicLoader  to streamline manufacturing.    The LogicLoader Shell (loshTM)  Losh Overview  Losh  is  a  command  interpreter  similar  to  those  found  in  Unix  environments.  Losh  implements  a rudimentary  network  and  file  system  command  set,  enhanced  with  custom  diagnostic  and  memory manipulation commands for debugging hardware.  Developers familiar with a Unix-like command line interface should find the losh implementation familiar and easy to work with. Many of losh’s commands are patterned after their Unix counterparts and share the same syntax.   Losh Basics  Losh uses a standard output stream (stdout). By default, stdout refers to a SOM’s debug serial port. The output of any command that  displays information to stdout  (i.e. the ‘cat’  command) can  be viewed using  the  terminal  emulation  program  connected  to  the  SOM’s  debug  serial  port.  Likewise,  the standard input stream (stdin) by default also refers to the SOM’s debug serial port.  The LogicLoader Shell includes a virtual file system that uses standard Unix path names. The highest-level (or root) directory is designated by the identifier ‘/’. A special sub-directory of the root with the name ‘dev’ is used to enumerate and interact with system’s various peripherals and their associated device drivers.   Using Losh  The losh shell includes a basic command line editing feature and a command history feature. This provides users with a quick way to repeat commands. Using the up and down arrow keys, the user can scroll through the list of previously executed commands. When a desired command is displayed, press the return key to repeat the command. The right and left arrow keys allow a user to position the cursor as desired on the current line so that text can be modified, deleted, or inserted at the appropriate location without having to “backspace” the entire line to access the portion of the command or command set being entered.  Losh includes a user help feature through the ‘help’ command. Typing ‘help’ followed by any command name  at  the  losh prompt  will  display  the  command’s  syntax,  usage,  and  an  example.  This  may  be especially helpful to users who are just becoming familiar with the LogicLoader shell.  Commands may be run in the background by adding a ‘&’ suffix.    Program Loading  Using  LogicLoader  to  download  any  application,  operating  system,  or  update  to  a  device  requires  an understanding  of  the  interaction  between  the  ‘load’,  ‘burn’,  ‘jump’,  and  ‘exec’  commands.  The purpose of this section is to explain the interaction of these commands.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 78 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  4.1 Understanding the Load Command   The purpose of the ‘load’ command is to transfer an executable image to a device. The image must be in one  of  the  following  supported  formats:  ELF,  SREC,  RAW,  or  BIN.  The  ‘load’  command  uses information inherent to the supported formats (or as entered as part of the command for RAW format) to determine where in the device’s memory the downloaded image should be stored. The image must be destined to run from either flash memory, system RAM, or on-chip SRAM.  If an image is destined for system RAM or on-chip SRAM, the ‘load’ command stores the image directly to its run-time location. Refer to Figure 4.1: Downloading to RAM for a graphic representation of this process.  If  a  downloaded application  is destined  for  flash  memory, the  ‘load’  command  transfers  the  file  into  a temporary RAM buffer on the device. The transferred image may be programmed into flash using the ‘burn’ command after the transfer is complete. Refer to Figure 4.2: Downloading to Flash for a graphic representation of this process.  Figure 4.1: Downloading to RAM  Figure 4.2: Downloading to Flash
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 79 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A    YAFFS (Yet Another Flash File System)   8.1 YAFFS Overview  The acronym YAFFS stands for the phrase "Yet Another Flash Filing System." YAFFS was developed by a company named Aleph One Limited and incorporated by Logic Product Development into the LogicLoader (LoLo) software program.  Logic  selected YAFFS to fill its file system  requirements  due to  the flexible nature  of  the  program, its licensing  scheme, and the fact that it is available for Linux,  Windows  CE, and other operating systems. YAFFS also allows  LogicLoader  and  an  RTOS  to view and  modify the same partition. It also  makes  it easier for customers to work with embedded flash technology and perform in-field updates.  Note: The partition entries for YAFFS partitions are not persistent -- they must be restored on each boot. However, the partitions and data remain persistent.   8.2 Working with YAFFS in LogicLoader   8.2.1 Developing a Partition Scheme   The LogicLoader may mount up to four YAFFS partitions at a time. Customers should design a partitioning scheme which suits their individual needs. The following limits are imposed on partitions:   • Each partition must have a unique name.   • Each partition must exist on local flash accessible from LogicLoader’s '/dev/flashx' device file (where ‘x’ is an instance index). For example: /dev/flash0 or /dev/flash1.   • Each partition must span at least 4 physical flash blocks.   • A partition must not overlap the flash blocks that contain LogicLoader or its configuration block. For information about the location of these items, check the LogicLoader User's Manual addendum for your hardware.   For the remainder of this document, the following partitioning scheme for demonstration purposes will be used:   • A partition named 'boot' which contains a bitmap and operating   system image and spans the address space below:  * start: 0x000C0000  * length: 0x00800000 (8 MBytes)   • A partition named 'data' which contains customer specific data.   * start: 0x00900000  * length: 0x00400000 (4 MBytes)
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 80 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  8.2.2 Formatting YAFFS Partitions   All file systems need to be formatted before they can be mounted. Because YAFFS was designed from the ground up to work with embedded flash technologies, it understands an 'erased' flash device to be both formatted and empty. To prepare your partition for mounting, simply use LogicLoader's 'erase' command to erase the area of flash where the partition is to be located.  Using the example partition scheme in the “Developing a Partition Scheme” section, above, the partitions could be prepared for initial use by erasing the regions of the flash device spanned by them.  For example (LH7A404-11 system address used): losh> erase 0x000C0000 0x00800000  losh > erase 0x00900000 0x00400000  Warning: Erasing flash blocks that will be used for YAFFS partitions will erase everything in those areas of flash. It is not required to format the partition every time the device is rebooted. The partition should only be formatted when an entirely new YAFFS partition is created, or when the data on a stored partition needs to be completely erased.   8.2.3 Adding YAFFS Type Partitions   LogicLoader  maintains a partition table in RAM. Before a YAFFS partition can be  mounted, it must be added to the partition table. To do this, the 'add-yaffs' command is used. The 'add-yaffs' command takes the following arguments:   • <name> a unique string which identifies the partition   • <type> type of flash device the partition resides on   • <start> the physical starting address of the partition   • <length> the length (in bytes) of the partition   Continuing  with  the  example  partitions  above,  LogicLoader  can  be  instructed  to  add  the  partitions  by executing the commands as shown below (LH7A404-11 system address used):  losh> add-yaffs boot nor 0x000C0000 0x00800000  losh> add-yaffs data nor 0x00900000 0x00400000  Note: The above steps must be performed every time LogicLoader boots. Because LogicLoader keeps the partition table in RAM, the existence and locations of YAFFS partitions does not persist across resets or power cycles.   8.2.4 Mounting the Partition   To mount a partition in the partition table, the 'mount' command is used. That command takes the following arguments:   • <fstype> the type of filesystem being mounted (‘yaffs’ here)   • [drive addr] not used when mounting a YAFFS partition   • <point> the name of the YAFFS partition   For example:  losh> mount yaffs /boot
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 81 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  losh> mount yaffs /data  Of note is that the 'drive addr' argument is not used when mounting a YAFFS partition. Also of note is that the  'point'  argument  needs  to  correspond  to  the  name  of  the  partition  (as  defined  by  the  add-yaffs command)  preceded by a  forward  slash.  LogicLoader  needs to  mount  all YAFFS  partitions at the root-directory level. Thus, a partition added using:  'add-yaffs boot ...'  will be mounted using:  'mount ... /boot'.  Note the absence of the '/' character during the 'add-yaffs' command and its presence during the 'mount' command.  8.2.5 Accessing YAFFS Partitions in an OS   A key advantage of the read/write YAFFS filesystem capability at the LogicLoader level is the ability to share data stored in the filesystem with an OS environment. If an OS environment (e.g. Linux, WinCE, VxWorks) implements YAFFS as an OS-accessible file-system, any files available to LogicLoader are also available to the OS, and vice-versa.  This contributes to significant benefits in the areas of system software upgrades (including OS upgrades) splash screen changes, script modifications, and other boot-time data that may need to be updated.   8.3 Summary   To use the YAFFS file system within LogicLoader, follow these steps:  1) Decide on a partitioning scheme.  2) Format the partitions by erasing the associated flash blocks.  3) Add the partitions to LogicLoader using the 'add-yaffs' command.  4) Mount the partitions using the 'mount' command.  Steps 3 and 4 must be repeated every time the system is booted. If the YAFFS partitions are frequently accessed, consider implementing steps 3 and 4 via a boot script. Step 2 only needs to be performed when creating a brand new partition or when the contents of an existing partition need to be completely erased.  Note: a partition is persistent. Re-adding a partition at boot-time restores access to previously saved data. Flash blocks must be erased to permanently remove a partition; otherwise, it can be recovered across boots.  Keep in mind the following when working with YAFFS and LogicLoader:   • Ensure that a partition name does not begin with a '/'. LogicLoader’s virtual filesystem uses the forward slash to indicate the root directory.   • Ensure partitions do not overlap each other, LogicLoader, or the configuration block.   • Ensure that a partition is erased before it is mounted for the first time.
 © SENSITECH INC. CONFIDENTIAL – CONTROLLED DOCUMENT   Page 82 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  Explanation of Script  losh> erase B10 B256 /dev/nand0 Purpose of erase command:  This command erases non-volatile <device>. When using a memory mapped device (such as NOR flash) the <start address> and <length> parameters indicate the memory address and the length in bytes. When using a block device (such as NAND flash) the <start block> and <number of blocks> indicate the first block number and the number of blocks to erase. Note; some devices, such as NAND flash, are marked with bad blocks by the device manufacturer, these blocks will not be erased and the erase command will indicate which blocks have been marked bad.  losh> add-yaffs boot nand B10 B256\ Purpose of add-yaffs command: This command adds a YAFFS partition into LoLo's partition table. You must execute this command before attempting to mount the YAFFS partition itself. When creating a partition in a NOR flash device, the start location is a memory address and the length is in bytes. When creating a partition in a NAND flash device, the start location is the start block and the length indicates the number of blocks.  This command must be called after a reset in order to make LoLo aware of a YAFFS partition. To create a new YAFFS partition, use the erase command to erase the range of addresses containing the YAFFS file system in flash memory before calling add-yaffs.  losh> mount yaffs /boot Purpose of mount command: This command mounts a filesytem of type <fstype> onto LoLo's root filesystem at point <point>. If the mount command is successful, you may use other shell commands to access the new filesystem.  losh> erase B267 B128 /dev/nand0 Purpose of erase command:  This command erases non-volatile <device>. When using a memory mapped device (such as NOR flash) the <start address> and <length> parameters indicate the memory address and the length in bytes. When using a block device (such as NAND flash) the <start block> and <number of blocks> indicate the first block number and the number of blocks to erase. Note; some devices, such as NAND flash, are marked with bad blocks by the device manufacturer, these blocks will not be erased and the erase command will indicate which blocks have been marked bad.  losh> add-yaffs data nand B267 B128 Purpose of add-yaffs command: This command adds a YAFFS partition into LoLo's partition table. You must execute this command before attempting to mount the YAFFS partition itself. When creating a partition in a NOR flash device, the start location is a memory address and the length is in bytes. When creating a partition in a NAND flash device, the start location is the start block and the length indicates the number of blocks.  This command must be called after a reset in order to make LoLo aware of a YAFFS partition. To create a new YAFFS partition, use the erase command to erase the range of addresses containing the YAFFS file system in flash memory before calling add-yaffs.  losh> mount yaffs /data Purpose of mount command: This command mounts a filesytem of type <fstype> onto LoLo's root filesystem at point <point>. If the mount command is successful, you may use other shell commands to access the new filesystem.
 © SENSITECH INC.     CONFIDENTIAL – CONTROLLED DOCUMENT                            Page 83 of 83 A Carrier Corp. Company PART NUMBER T82002163 REV A  losh> mount fatfs /cfs Purpose of mount command: This command mounts a filesytem of type <fstype> onto LoLo's root filesystem at point <point>. If the mount command is successful, you may use other shell commands to access the new filesystem.  losh> cp /cf/NK.BIN /boot/NK.BIN Purpose of cp command: This command is used to copy a file.  losh> config CREATE Purpose of Config command: This command saves and/or displays configuration information in the config device. The config device starts at offset 0x40000 in the boot flash device. The config device may be used to store a boot script, the debug port baud rate settings, user defined video settings, and the debug Ethernet settings. Please consult the LogicLoader User's Manual for a full explanation of the config block device.  Create creates a new config block  losh> echo "VOLOadd-yaffs boot nand B10 B256;mount yaffs /boot;add-yaffs data nand B267 B128; mount yaffs/data;load bin /boot/NK.BIN; exec rtc:rtc_pxa270:disp_num:0;exit;\n" /dev/config  Purpose of echo command: This command echoes a string to standard output or to a file. Note:  This command sets $@ to the number of characters written when no failure occurs.  Purpose of the exec command: This command allows the processor to jump to an OS image loaded in memory or to a given address. Before the jump, interrupts, memory caching, and mapping are disabled. Note:  Returns the return value of the executed code and sets $@ to the jump address when no losh errors occur.  The disp_num: value correlates to the LCD model being used. In this case, the disp_num is 0 for the EDT LCD. However, for the LogicPD evaluation board LCD, the value is 3.  losh> VOLOadd-yaffs boot nand B10 B256;mount yaffs /boot;add-yaffs data nand B267 B128; mount yaffs /data;load bin /boot/NK.BIN;exec rtc:rtc_pxa270:disp_num:0;exit;  This device complies with Part 15 of the FCC Rules. Operation is subject to the following two conditions: (1) This device may not cause harmful interference. and   (2) This device must accept any interference received, including interference that may cause undesired operation

Navigation menu