MICROCHIP DS41401A

F1 Evaluation Platform for
Enhanced PIC® Microcontrollers
User’s Guide
© 2009 Microchip Technology Inc.
DS41401A
Note the following details of the code protection feature on Microchip devices:
•
Microchip products meet the specification contained in their particular Microchip Data Sheet.
•
Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the
intended manner and under normal conditions.
•
There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our
knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip’s Data
Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
•
Microchip is willing to work with the customer who is concerned about the integrity of their code.
•
Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
mean that we are guaranteeing the product as “unbreakable.”
Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our
products. Attempts to break Microchip’s code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts
allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.
Information contained in this publication regarding device
applications and the like is provided only for your convenience
and may be superseded by updates. It is your responsibility to
ensure that your application meets with your specifications.
MICROCHIP MAKES NO REPRESENTATIONS OR
WARRANTIES OF ANY KIND WHETHER EXPRESS OR
IMPLIED, WRITTEN OR ORAL, STATUTORY OR
OTHERWISE, RELATED TO THE INFORMATION,
INCLUDING BUT NOT LIMITED TO ITS CONDITION,
QUALITY, PERFORMANCE, MERCHANTABILITY OR
FITNESS FOR PURPOSE. Microchip disclaims all liability
arising from this information and its use. Use of Microchip
devices in life support and/or safety applications is entirely at
the buyer’s risk, and the buyer agrees to defend, indemnify and
hold harmless Microchip from any and all damages, claims,
suits, or expenses resulting from such use. No licenses are
conveyed, implicitly or otherwise, under any Microchip
intellectual property rights.
Trademarks
The Microchip name and logo, the Microchip logo, dsPIC,
KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART,
rfPIC and UNI/O are registered trademarks of Microchip
Technology Incorporated in the U.S.A. and other countries.
FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor,
MXDEV, MXLAB, SEEVAL and The Embedded Control
Solutions Company are registered trademarks of Microchip
Technology Incorporated in the U.S.A.
Analog-for-the-Digital Age, Application Maestro, CodeGuard,
dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN,
ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial
Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified
logo, MPLIB, MPLINK, mTouch, Octopus, Omniscient Code
Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit,
PICtail, PIC32 logo, REAL ICE, rfLAB, Select Mode, Total
Endurance, TSHARC, UniWinDriver, WiperLock and ZENA
are trademarks of Microchip Technology Incorporated in the
U.S.A. and other countries.
SQTP is a service mark of Microchip Technology Incorporated
in the U.S.A.
All other trademarks mentioned herein are property of their
respective companies.
© 2009, Microchip Technology Incorporated, Printed in the
U.S.A., All Rights Reserved.
Printed on recycled paper.
Microchip received ISO/TS-16949:2002 certification for its worldwide
headquarters, design and wafer fabrication facilities in Chandler and
Tempe, Arizona; Gresham, Oregon and design centers in California
and India. The Company’s quality system processes and procedures
are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping
devices, Serial EEPROMs, microperipherals, nonvolatile memory and
analog products. In addition, Microchip’s quality system for the design
and manufacture of development systems is ISO 9001:2000 certified.
DS41401A-page 2
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Table of Contents
Preface ........................................................................................................................... 5
Chapter 1. F1 Evaluation Platform Overview
1.1 Introduction ................................................................................................... 11
1.2 Platform Contents ......................................................................................... 11
1.3 Hardware Features ....................................................................................... 11
Chapter 2. Getting Started
2.1 Introduction ................................................................................................... 13
2.2 Powering the F1 Evaluation Platform ........................................................... 13
2.3 Powering with PICkit™ 3 .............................................................................. 13
2.4 Powering with the Connector at JP3 ............................................................ 14
2.5 Powering with PICkit™ Serial ....................................................................... 14
2.6 Powering with the BLDC Expansion Header J3 ........................................... 15
2.7 Default Firmware .......................................................................................... 15
Chapter 3. Programming the F1 Evaluation Platform
3.1 Introduction ................................................................................................... 17
3.2 Programming/Development Tool Support .................................................... 17
3.3 Hardware Resources .................................................................................... 18
Chapter 4. Demo Code
4.1 Introduction ................................................................................................... 19
4.2 I2C™ Demo .................................................................................................. 19
4.3 LCD Demo .................................................................................................... 19
4.4 BLDC Demo ................................................................................................. 19
4.5 Combined Demo .......................................................................................... 19
Chapter 5. Hardware Libraries and Drivers
5.1 Introduction ................................................................................................... 21
5.2 I2C™ Driver .................................................................................................. 21
5.3 MCP9800 Driver ........................................................................................... 21
5.4 RTCC Driver ................................................................................................. 21
5.5 LCD Driver .................................................................................................... 21
5.6 Using the I2C™ Driver .................................................................................. 22
5.7 Using the LCD driver .................................................................................... 24
5.8 Using the RTCC Driver ................................................................................. 26
5.9 Using the MCP9800 Driver ........................................................................... 27
Chapter 6. Troubleshooting
6.1 Introduction ................................................................................................... 29
6.2 Common Problems ....................................................................................... 29
© 2009 Microchip Technology Inc.
DS41401A-page 3
F1 Evaluation Platform User’s Guide
Chapter 7. Schematics
7.1 Introduction .................................................................................................. 31
Index .............................................................................................................................39
Worldwide Sales and Service .....................................................................................42
DS41401A-page 4
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Preface
NOTICE TO CUSTOMERS
All documentation becomes dated, and this manual is no exception. Microchip tools and
documentation are constantly evolving to meet customer needs, so some actual dialogs
and/or tool descriptions may differ from those in this document. Please refer to our web site
(www.microchip.com) to obtain the latest documentation available.
Documents are identified with a “DS” number. This number is located on the bottom of each
page, in front of the page number. The numbering convention for the DS number is
“DSXXXXXA”, where “XXXXX” is the document number and “A” is the revision level of the
document.
For the most up-to-date information on development tools, see the MPLAB® IDE on-line help.
Select the Help menu, and then Topics to open a list of available on-line help files.
INTRODUCTION
This chapter contains general information that will be useful to know before using the
F1 Evaluation Platform User’s Guide. Items discussed in this chapter include:
•
•
•
•
•
•
•
•
Document Layout
Conventions Used in this Guide
Warranty Registration
Recommended Reading
The Microchip Web Site
Development Systems Customer Change Notification Service
Customer Support
Document Revision History
DOCUMENT LAYOUT
This document describes how to use the F1 Evaluation Platform User’s Guide as a
development tool to emulate and debug firmware on a target board. The manual layout
is as follows:
•
•
•
•
•
•
•
Chapter 1. “F1 Evaluation Platform Overview”
Chapter 2. “Getting Started”
Chapter 3. “Programming the F1 Evaluation Platform”
Chapter 4. “Demo Code”
Chapter 5. “Hardware Libraries and Drivers”
Chapter 6. “Troubleshooting”
Chapter 7. “Schematics”
© 2009 Microchip Technology Inc.
DS41401A-page 5
F1 Evaluation Platform User’s Guide
CONVENTIONS USED IN THIS GUIDE
This manual uses the following documentation conventions:
DOCUMENTATION CONVENTIONS
Description
Arial font:
Italic characters
Initial caps
Quotes
Underlined, italic text with
right angle bracket
Bold characters
N‘Rnnnn
Text in angle brackets < >
Courier New font:
Plain Courier New
Represents
Referenced books
Emphasized text
A window
A dialog
A menu selection
A field name in a window or
dialog
A menu path
MPLAB® IDE User’s Guide
...is the only compiler...
the Output window
the Settings dialog
select Enable Programmer
“Save project before build”
A dialog button
A tab
A number in verilog format,
where N is the total number of
digits, R is the radix and n is a
digit.
A key on the keyboard
Click OK
Click the Power tab
4‘b0010, 2‘hF1
Italic Courier New
Sample source code
Filenames
File paths
Keywords
Command-line options
Bit values
Constants
A variable argument
Square brackets [ ]
Optional arguments
Curly brackets and pipe
character: { | }
Ellipses...
Choice of mutually exclusive
arguments; an OR selection
Replaces repeated text
Represents code supplied by
user
DS41401A-page 6
Examples
File>Save
Press <Enter>, <F1>
#define START
autoexec.bat
c:\mcc18\h
_asm, _endasm, static
-Opa+, -Opa0, 1
0xFF, ‘A’
file.o, where file can be
any valid filename
mcc18 [options] file
[options]
errorlevel {0|1}
var_name [,
var_name...]
void main (void)
{ ...
}
© 2009 Microchip Technology Inc.
Preface
WARRANTY REGISTRATION
Please complete the enclosed Warranty Registration Card and mail it promptly.
Sending in the Warranty Registration Card entitles users to receive new product
updates. Interim software releases are available at the Microchip web site.
RECOMMENDED READING
This user’s guide describes how to use F1 Evaluation Platform User’s Guide. Other
useful documents are listed below. The following Microchip documents are available
and recommended as supplemental reference resources.
Readme for F1 Evaluation Platform User’s Guide
For the latest information on using F1 Evaluation Platform User’s Guide, read the
“Readme for F1 Evaluation Platform User’s Guide.txt” file (an ASCII text
file) in the Readmes subdirectory of the MPLAB IDE installation directory. The Readme
file contains update information and known issues that may not be included in this
user’s guide.
Readme Files
For the latest information on using other tools, read the tool-specific Readme files in
the Readmes subdirectory of the MPLAB IDE installation directory. The Readme files
contain update information and known issues that may not be included in this user’s
guide.
© 2009 Microchip Technology Inc.
DS41401A-page 7
F1 Evaluation Platform User’s Guide
THE MICROCHIP WEB SITE
Microchip provides online support via our web site at www.microchip.com. This web
site is used as a means to make files and information easily available to customers.
Accessible by using your favorite Internet browser, the web site contains the following
information:
• Product Support – Data sheets and errata, application notes and sample
programs, design resources, user’s guides and hardware support documents,
latest software releases and archived software
• General Technical Support – Frequently Asked Questions (FAQs), technical
support requests, online discussion groups, Microchip consultant program
member listing
• Business of Microchip – Product selector and ordering guides, latest Microchip
press releases, listing of seminars and events, listings of Microchip sales offices,
distributors and factory representatives
DEVELOPMENT SYSTEMS CUSTOMER CHANGE NOTIFICATION SERVICE
Microchip’s customer notification service helps keep customers current on Microchip
products. Subscribers will receive e-mail notification whenever there are changes,
updates, revisions or errata related to a specified product family or development tool of
interest.
To register, access the Microchip web site at www.microchip.com, click on Customer
Change Notification and follow the registration instructions.
The Development Systems product group categories are:
• Compilers – The latest information on Microchip C compilers and other language
tools. These include the MPLAB C18 and MPLAB C30 C compilers; MPASM™
and MPLAB ASM30 assemblers; MPLINK™ and MPLAB LINK30 object linkers;
and MPLIB™ and MPLAB LIB30 object librarians.
• Emulators – The latest information on Microchip in-circuit emulators.This
includes the MPLAB ICE 2000 and MPLAB ICE 4000.
• In-Circuit Debuggers – The latest information on the Microchip in-circuit
debugger, MPLAB ICD 2.
• MPLAB® IDE – The latest information on Microchip MPLAB IDE, the Windows®
Integrated Development Environment for development systems tools. This list is
focused on the MPLAB IDE, MPLAB SIM simulator, MPLAB IDE Project Manager
and general editing and debugging features.
• Programmers – The latest information on Microchip programmers. These include
the MPLAB PM3 and PRO MATE® II device programmers and the PICSTART®
Plus and PICkit™ 1 development programmers.
DS41401A-page 8
© 2009 Microchip Technology Inc.
Preface
CUSTOMER SUPPORT
Users of Microchip products can receive assistance through several channels:
•
•
•
•
Distributor or Representative
Local Sales Office
Field Application Engineer (FAE)
Technical Support
Customers should contact their distributor, representative or field application engineer
(FAE) for support. Local sales offices are also available to help customers. A listing of
sales offices and locations is included in the back of this document.
Technical support is available through the web site at: http://support.microchip.com
DOCUMENT REVISION HISTORY
Revision A (October 2009)
• Initial Release of this Document.
© 2009 Microchip Technology Inc.
DS41401A-page 9
F1 Evaluation Platform User’s Guide
NOTES:
DS41401A-page 10
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 1. F1 Evaluation Platform Overview
1.1
INTRODUCTION
Thank you for choosing the F1 Evaluation Platform. This kit allows you to begin
development on the PIC16LF1937.
The PIC16LF1937 is the first of the enhanced mid-range microcontrollers. These
architectural enhancements allow for more memory and faster computation than that
of legacy PIC16 microcontrollers.
The PIC16F1 and PIC12F1 family of microcontrollers are a series of 8-bit
microcontrollers derived from the popular PIC16 series of 8-bit PIC® microcontrollers.
The F1 derivatives feature an enhanced CPU, support for extended amounts of
memory, improved peripherals, and XLP low power. The F1 Evaluation Platform allows
you to evaluate these features for your application in a simple, low-cost platform.
This chapter introduces the F1 Evaluation Platform:
• Platform Contents
• Hardware Features
1.2
PLATFORM CONTENTS
The F1 Evaluation Platform contains the following items:
1. F1 Evaluation Platform Demo Board – www.microchip.com/F1Eval
1.3
HARDWARE FEATURES
The F1 Evaluation Platform has the following hardware features:
1.3.1
PIC16LF1937
The PIC16LF1937 is a 40-pin full-featured device, including:
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
Enhanced PIC16 instruction set
8K Words of Flash memory
512 bytes of RAM
256 bytes of EEPROM
3 ECCPs, 2 CCPs
MSSP (I2C™, SPI)
EUSART
8- and 16-bit timers
32 MHz internal oscillator
Low-power 32 kHz crystal oscillator and
LCD controller.
1.3.2
MCP9800 I2C Temperature Sensor
The MCP9800 is a low-power, selectable 8 to 12-bit I2C temperature sensor in a
SOT23-5 package.
© 2009 Microchip Technology Inc.
DS41401A-page 11
F1 Evaluation Platform User’s Guide
1.3.3
PICkit™ 3 Programming/debug Header
The PICkit 3 is a low-cost development tool that allows programming and debugging of
the PIC16LF1937 MCU.
1.3.4
PICkit Serial Communications Header
The PICkit serial is a low-cost development tool that allows I2C, SPI and USART
protocols to be monitored and debugged through a simple 6-pin connector.
1.3.5
1 Button, 1 Potentiometer, 4 LEDs
Simple applications need the basic user interface elements. The button, potentiometer
and 1 LED are available for any application. The remaining 3 LEDs are shared with the
20-bit motor control connector.
1.3.6
One 3.5 Digit LCD
The 3.5-digit LCD glass supplied on this board is a typical meter-type display with icons
for ohms, amps, etc. The PIC16LF1937 makes controlling this glass very simple.
1.3.7
20-pin Motor Control Expansion Connector
This connector allows the PIC16LF1937 to control an optional Sensorless BLCD
add-on board (DM164130-2). The PIC16LF1937 has complete control of 3 phases so
other 1, 2, or 3-phase motor topologies can also be controlled.
1.3.8
Current Monitoring Connector
To demonstrate the XLP features, a precision ammeter can be connected to the current
monitoring connector. This allows your application to be easily optimized for the lowest
possible current.
1.3.9
Generous Prototyping Area
Our circuits are not your circuits. A prototyping area has been provided to extend the
functionality of this demo board to demonstrate the utility of the PIC16LF1937 in your
application.
DS41401A-page 12
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 2. Getting Started
2.1
INTRODUCTION
This chapter gives instruction to get your F1 Evaluation Platform powered up and
running the default demonstration.
•
•
•
•
•
FIGURE 2-1:
2.2
Powering the F1 Evaluation Platform
Default Firmware
Programming the F1 Evaluation Platform with the PICkit™ 3
Attaching a PICkit Serial (optional)
Measuring the current consumption
F1 EVALUATION PLATFORM (DM164130-1)
POWERING THE F1 EVALUATION PLATFORM
The PIC16LF1937 supplied with your F1 Evaluation Platform requires a supply voltage
of 1.8V-3.6V. Voltages above 3.6V will degrade or damage the device. There are four
ways to supply the necessary power.
1.
2.
3.
4.
2.3
Use PICkit 3,
Use the power connector at JP3,
Use PICkit Serial, or
Use the BLCD Expansion Header J3.
POWERING WITH PICkit™ 3
To power with the PICkit 3, perform the following steps:
1. Make sure a jumper or an ammeter is connected across JP2.
2. If you are using a BLDC expansion, remove the jumper at JP1.
© 2009 Microchip Technology Inc.
DS41401A-page 13
F1 Evaluation Platform User’s Guide
3. Configure the PICkit 3 to supply a voltage between 1.8 and 3.6V. For proper LCD
contrast, the supply should be 3.3V.
4. Attach the PICkit 3 to the PICkit ICSP™ connector at the end of the board.
5. Activate the PICkit 3 power output.
2.4
POWERING WITH THE CONNECTOR AT JP3
To power with the connector at JP3, perform the following steps:
1. Make sure a jumper or an ammeter is connected across JP2.
2. If you are using a BLDC expansion, remove the jumper at JP1.
3. Verify the supply voltage to be between 1.8 and 3.6V. For proper LCD contrast,
the supply should be 3.3V.
4. Attach the power supply to JP3.
5. Turn on the power supply.
FIGURE 2-2:
2.5
POWERING WITH THE CONNECTOR AT JP3
POWERING WITH PICkit™ SERIAL
To power with the PICkit Serial, perform the following steps:
1. Make sure a jumper or an ammeter is connected across JP2.
2. If you are using a BLDC expansion, remove the jumper at JP1.
3. Configure the PICkit Serial to supply a voltage between 1.8 and 3.6V. For proper
LCD contrast, the supply should be 3.3V.
4. Attach the PICkit Serial to the PICkit Serial connector at the top corner of the
board.
5. Activate the PICkit Serial power output.
DS41401A-page 14
© 2009 Microchip Technology Inc.
Getting Started
2.6
POWERING WITH THE BLDC EXPANSION HEADER J3
The BLDC Expansion hardware contains a 3.3V linear regulator. This allows the 5-12V
motor power supply to power the PIC16LF1937. J3 pin 6 is the source for the 3.3V
power. To use this power perform the following steps.
1.
2.
3.
4.
5.
Make sure a jumper or an ammeter is connected across JP2.
Insert the shorting jumper at JP1.
Verify that any attached PICkit 3 or PICkit serial is not supplying power.
Verify that there is NO power supply or shorting jumper at JP3.
Verify that the BLDC expansion hardware provides less than 3.6V of power. (The
F1 BLDC add-on supplies 3.3V)
6. Attach the BLDC expansion board.
7. Supply power via the BLDC board.
2.7
DEFAULT FIRMWARE
The default firmware supplied with your F1 Evaluation Board Demo has the following
features:
1. Blink LEDs
2. Measure the ambient temperature
3. Run a BLDC motor (or try to if no motor is attached)
4. Display time/temperature/pot position/motor RPM on the LCD
5. User interface with a button and pot
For the latest firmware go to www.microchip.com/F1Eval
2.7.1
Blinking LEDs
The 4 LEDs indicate motor phase operation (D<2:4>) and the performance of the
primary state machine loop (D1).
2.7.2
Measuring the Ambient Temperature
The MCP9800 is polled when in Temperature Measurement mode. The measured
temperature is filtered, scaled to centigrade and displayed on the LCD.
2.7.3
BLDC Motor
One task of the demo code is to drive a BLDC motor attached to the BLDC Expansion
Header. The optional BLDC Controller board (DM164130-2) is required to drive the
motor. The code performs a series of forced commutation steps to attempt a sensorless
motor start. If no back EMF signal is detected, the code repeats the start-up sequence.
The LEDs blink at an increasing rate indicating the motor start attempts. If no motor
drive hardware is attached, this pattern can repeat or it may detect a BEMF signal in
the noise present on the BEMF sense inputs.
© 2009 Microchip Technology Inc.
DS41401A-page 15
F1 Evaluation Platform User’s Guide
2.7.4
LCD Display
The time, temperature, pot position and motor speed are displayed on the LCD. The
LCD is a 3.5-digit multimeter display with icons for amps, volts, ohms, etc. The display
uses 4 commons and 10 segment drives. The Timer1 oscillator is used to clock the
display peripheral and allow the display to show a picture even in Sleep. The LCD
peripheral was configured for a Type B waveform for this demo. This mode provides an
interrupt when the LCD can be updated. This interrupt is not required for Type A
waveforms, but the extra complexity of the interrupt allows the LCD peripheral to be
used to provide the real-time clock periodic interrupt. The different waveform types are
described in section 21.9 of the PIC16LF193X data sheet (DS41364). Normally, the
Timer1 counter would be used, but this timer is required for the BLDC software.
Because the LCD is clocked from the 32.768 kHz crystal, the LCDIF operates at a
multiple of the crystal frequency, providing a very accurate time base for the real-time
clock.
2.7.5
User Interface
Due to the extreme simplicity of this board, only a single button and a single pot are
available for user input. These two elements allow the user to cycle through the display
elements, change the motor speed and change the time.
Pressing and releasing the button cycles through the 4 display modes:
1. Time
2. Temperature
3. Pot ADC value
4. RPM
Turning the pot will change the motor speed or set the time.
If the display is showing the time, and the button is held down for 3 seconds, turning
the pot clockwise will increase the time, and counter clockwise will decrease the time.
Placing the pot in the center of the range will leave the time unchanged. A feature that
could be added as a simple programming exercise would be to allow the time change
to be faster or slower depending upon pot position.
DS41401A-page 16
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 3. Programming the F1 Evaluation Platform
3.1
INTRODUCTION
The F1 Evaluation Platform makes extensive use of the onboard peripherals of the
PIC16LF1937. This chapter provides guidance concerning the tools used for
programming the F1 evaluation board and a map of the board function to I/O pin and
pin function.
3.2
PROGRAMMING/DEVELOPMENT TOOL SUPPORT
The following development tools support the F1 Evaluation Platform:
1. PICkit™ 3
2. PICkit™ 2
3. REAL ICE™ in-circuit emulator (with adapter AC164110)
The PICkit™ tools can also power the F1 Evaluation Platform, therefore, no additional
hardware is required to get started. The ICSP™ pins of the PIC16LF1937 are
dedicated to the PICkit ICSP connector, eliminating interactions between the
Evaluation Platform and the programmer/debugger.
If you are developing with the REAL ICE emulator, you will need the AC164110 adaptor,
or the high-speed trace adaptor. These adaptors provide the inline 6 pin connector
required by the PICkit ICSP programming capability interface. You will also need a
power supply, please see Chapter 2. “Getting Started” for more on powering the F1
Evaluation Platform.
© 2009 Microchip Technology Inc.
DS41401A-page 17
F1 Evaluation Platform User’s Guide
3.3
HARDWARE RESOURCES
TABLE 3-1:
Pin Number
Pin Name
Pin Function Used
Board Function
1
RC7
EUSART RX
PICkit™ Serial Pin 1
2
RD4
Segment 17
LCD Pin 13, S1/S2/m/M
3
RD5
CCP1 Output B
BLDC pin 5, Phase U low drive
4
RD6
CCP1 Output C
BLDC pin 9, Phase V low drive
5
RD7
Segment 20
LCD pin 14, A/V/K/Omega
6
VSS
VSS
VSS
7
VDD
VDD
VDD
8
RB0
Segment 0
LCD pin 5, RC/BATT/-/AC
9
RB1
C12IN3-
BLDC pin 19, Phase V BEMF Zero Cross
10
RB2
AN8
Potentiometer
11
RB3
C12IN2-
BLDC pin 17, Phase U BEMF Zero Cross
14
RB4
COM1
LCD pin 1, Common 1
15
RB5
COM2
LCD pin 2, Common 2
16
RB6
PGC
PICkit 2 ICSP™ pin 5, PGC
17
RB7
PGD
PICkit 2 ICSP pin 4, PGD
18
MCLR
MCLR
PICkit ICSP Pin 1
19
RA0
Segment 12
LCD pin 11, 1A/1F/1E/1D
20
RA1
C12IN1-
BLDC pin 15, Phase W BEMF Zero Cross
21
RA2
COM3
LCD pin 3, Common 3
22
RA3
C1IN+
BLDC pin 16, BEMF Zero Cross Reference
23
RA4
Segment 4
LCD pin 8, 3B/3G/3C/3DP
24
RA5
Segment 5
LCD pin 9, 2A/2F/2E/2D
25
RE0
RE0
LED D4 and BLDC pin 3 Phase W high drive
26
RE1
RE1
LED D3 and BLDC pin 7 Phase U high drive
27
RE2
RE2
LED D2 and BLDC pin 11 Phase V high drive
28
VDD
VDD
VDD
29
VSS
VSS
VSS
30
RA7
Segment 2
LCD pin 7, 3A/3F/3E/3D
31
RA6
Segment 1
LCD pin 6, DH/RH/B-C/4DP
32
RC0
T1OSCO
32.768 kHz Crystal Drive
35
RC1
T1OSCI
32.768 kHz Crystal Drive
36
RC2
CCP1 Output A
BLDC pin 1, Phase W low drive
37
RC3
MSSP SCLK
MCP9800 SCLK and PICkit Serial pin 5
38
RD0
Common 4
LCD pin 4, Common 4
39
RD1
RD1
LED D1
40
RD2
RD2
Button Input
41
RD3
Segment 16
LCD pin 12, 1B/1G/1C/
42
RC4
MSSP SDA
MCP9800 SDA and PICkit Serial pin 4
43
RC5
Segment 10
LCD pin 10, 2B/2G/2C/2DP
44
RC6
EUSART TX
PICkit Serial pin 6
DS41401A-page 18
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 4. Demo Code
4.1
INTRODUCTION
The F1 Evaluation Platform demos are located at www.microchip.com/F1Eval. The
following demos are available:
1.
2.
3.
4.
I2C™ Demo
LCD Demo
BLDC Demo
Combined Demo
This chapter provides an overview to the functions provided by these demos.
4.2
I2C™ DEMO
The I2C demo reads the current temperature from the on-board MCP9800 I2C
temperature sensor. The I2C driver is used to extract the data. The resulting value is
converted to a PWM duty cycles and used to control the brightness of the LED D4. LED
D1 toggles at approximately 10 ms.
4.3
LCD DEMO
The LCD demo adds button, potentiometer, Real-Time Clock (RTC) and LCD support
to the I2C demo. The 32.768 kHz crystal is activated to maintain the Real-Time Clock
and to drive the LCD peripheral. An input driver is supplied to manage the button and
potentiometer. A state machine now controls the major features of the demo so that the
time, temperature and potentiometer value can be displayed on the LCD.
4.4
BLDC DEMO
The BLDC demo controls a sensorless, brushless DC motor connected to the PIC16F1
BLDC Expansion board (DM164130-2). Other motors can also be driven by making
appropriate modifications to the motor control parameters in the source code.
4.5
COMBINED DEMO
The combined demo combines all the software from all the previous demos to show the
power of the PIC16LF1937. In this demo, the BLDC motor is seamlessly controlled
while displaying the time, temperature, potentiometer position or motor RPM/10. All
drivers are reused from the previous demos. The RTCC is driven from the LCD
peripheral.
The combined demo is preprogrammed in the F1 Evaluation Platform.
© 2009 Microchip Technology Inc.
DS41401A-page 19
F1 Evaluation Platform User’s Guide
NOTES:
DS41401A-page 20
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 5. Hardware Libraries and Drivers
5.1
INTRODUCTION
All of the demo code uses a common set of libraries to provide I2C, real-time clock,
MCP9800 and LCD services. These libraries may be useful for other applications so
they are documented here. These drivers are located at www.microchip.com/F1Eval.
5.2
I2C™ DRIVER
The I2C driver allows I2C requests to be queued and then handled either by interrupts
or by polling. The driver is configured during compilation to support polling or interrupts.
The I2C and LCD demos configure the driver for interrupt mode. The Combined demo
polls the I2C handler within the MCP9800 driver.
5.3
MCP9800 DRIVER
The MCP9800 driver uses the I2C driver to get the current temperature. The
mcp9800_get_temp function is fully blocking, so once a request is queued, the driver
polls the I2C subsystem until the data is complete. If the I2C driver is operating without
interrupts, the mcp9800_get_temp function repeatedly calls the I2C_handler
function to process all the I2C events. If the I2C driver is operating with interrupts, the
mcp9800_get_temp function simply inserts an I2C_TRANSACTION_T into the I2C
transaction queue and waits for the transaction to complete.
5.4
RTCC DRIVER
A software RTCC is managed by the supplied RTCC driver. This driver implements the
time() function required by the C compiler. Time is internally kept as seconds since
January 1, 1970. Standard C functions can be used to convert the time to the current
date. This driver has two modes. In the first mode, it expects to be called once per
second by the Timer1 interrupt. In the second mode, it expects to be called on every
LCD mode B frame. This allows the RTCC to keep accurate time even if Timer1 is being
used by some other function, such as the BLDC motor driver.
5.5
LCD DRIVER
The LCD driver contains the initialization code required for the LCD peripheral and the
mapping code required to control the 3.5-digit LCD supplied with this demo board. It is
a good starting point for the LCD driver your unique application will require.
© 2009 Microchip Technology Inc.
DS41401A-page 21
F1 Evaluation Platform User’s Guide
5.6
USING THE I2C™ DRIVER
The supplied software includes an I2C Master mode driver with the following features:
1.
2.
3.
4.
5.
6.
Interrupt driven or polled
Queued requests
Minimum memory requirements
Uses Restart to maximize bus bandwidth
Multiple atomic I2C transactions allowed at each queue entry
Completion flag for each queued block of I2C commands.
5.6.1
I2C Data Structures
Two data structures are defined to simplify interactions with the I2C driver.
5.6.1.1 I2C_RESULTS_T
The I2C_RESULTS_T is an enumerated type with the following enumerations:
TABLE 5-1:
I2C_RESULTS_T
I2C_REQUEST_PENDING
Request is in the queue or in process but it is not
done.
I2C_REQUEST_COMPLETE
The request is finished successfully.
I2C_REQUEST_STUCK_START
The request was aborted. The start condition did
not clear correctly.
I2C_REQUEST_ADDRESS_NO_ACK
The request was aborted. No ACK occurred on
the address, so the target device must not exist
or is not functioning.
I2C_REQUEST_DATA_NO_ACK
The request was aborted. Not all of the data
could be sent because the device did not ACK a
byte.
I2C_REQUEST_LOST_STATE
The I2C state machine had a RAM corruption
and the default case caught the failure. This will
infinite loop so you should never see it.
The data completion flag for an I2C request is of type I2C_RESULTS_T. This flag will
be I2C_REQUEST_PENDING until the request is complete. If the request completed
without errors, the value will be I2C_REQUEST_COMPLETE. If there were errors, the
value will reflect one of the other 4 error conditions.
5.6.1.2 I2C_T
The I2C_T is a structure representing one transaction on the I2C bus. A transaction
contains the following elements:
1. A 7- or 10-bit address. Address type is determined automatically by the driver.
R/W mode is implicit in the address and specified by bit 0.
2. An 8-bit baud rate. This is the value placed in SPADD. Predefined constants are
included that compute the SPADD value given an FOSC value. Set FOSC with
a #define before #including the I2C.h file.
3. A buffer_length. This is the number of bytes available for reading or writing
at the supplied data buffer.
4. A Buffer Pointer. Your application will allocate a block of memory for an I2C
transaction. Pass a pointer to this block via the Buffer Pointer. The block must
remain valid until the transaction is complete (i.e. if you allocate the block as a
non-static array within a function, you must not leave the function until the I2C
transaction is complete or the array may be reused by a different function).
DS41401A-page 22
© 2009 Microchip Technology Inc.
Hardware Libraries and Drivers
5.6.2
I2C Function Interface
5.6.2.1
i2c_init
The function i2c_init configures the I2C driver and makes it ready to receive
transaction in the transaction queue.
FIGURE 5-1:
initialize()
{
i2c_init(I2C_400K);
}
5.6.2.2
i2c_insert
The function i2c_insert places one complete set of transaction request block (trb’s).
TRBs can be bundled into an array of multiple TRBs and inserted as one large request.
The driver will ensure that all the TRBs in the list will be processed sequentially with I2C
restarts separating them.
FIGURE 5-2:
Send_data()
{
I2C_TRANSACTION_REQUEST_BLOCK trb_list[5];
I2C_RESULTS flag;
… populate the trb’s …
i2c_insert(5,trb_list, &flag);
}
5.6.2.3
i2c_build_write_trb / i2c_build_read_trb
The i2c_build_write_trb and i2c_build_read_trb functions are helpers to
assemble the I2C_TRANSACTION_REQUEST_BLOCKS from passed parameters.
FIGURE 5-3:
Send_one_byte()
{
I2C_TRANSACTION_REQUEST_BLOCK trb_list;
unsigned char data;
I2C_RESULTS flag;
data_block = .. my data byte ..
i2c_build_write_trb(&trb_list,ADDRESS, 1, &data, i2c_200K);
i2c_insert(1,&trb,&flag);
}
5.6.2.4
i2c_write_block / i2c_read_block
The i2c_write_block and i2c_read_block functions are helpers that assemble
a TRB, insert it into the queue and wait for the transaction to complete.
© 2009 Microchip Technology Inc.
DS41401A-page 23
F1 Evaluation Platform User’s Guide
FIGURE 5-4:
Send_one_byte()
{
unsigned char data;
i2c_write_block(ADDRESS, 1, &data, i2c_200K);
}
5.6.2.5
i2c_handler
The i2c_handler function must be called for each I2C state to be handled. This
function can be placed into the Interrupt Service Routine for your application or, you
can simply poll it often. If the i2c_write_block or i2c_read_block functions are
used when the driver is configured for polling, then this function will repeatedly be
called until the transaction completes.
FIGURE 5-5:
Interrupt_service_routine()
{
i2c_handler();
}
5.7
USING THE LCD DRIVER
The supplied LCD driver configures the LCD module for the I/O pins used by the F1
Evaluation Platform. Icon definitions are provided to simplify the software. A BCD to
7-segment display mapping function is also provided to further simplify control of the
LCD glass. For more information concerning the LCD peripheral, please consult the
LCD chapter in the PIC16LF1937 data sheet (DS41364).
5.7.1
LCD Data Structures
5.7.1.1
BCD_TYPE
To simplify BCD to the 7-segment display mapping, a BCD segment data type has been
provided. This data type is simply four 4-bit fields representing digits 0, 1, 2, and 3.
FIGURE 5-6:
typedef union
{
UINT16
val;
struct
{
unsigned
digit0 : 4;
unsigned
digit1 : 4;
unsigned
digit2 : 4;
unsigned
digit3 : 4;
};
} BCD_TYPE;
Simply place the number you want displayed in each digit position and call
lcd_display_digits. Digit 3 is the most significant ½ digit of the 3.5-digit LCD
glass. Therefore, the largest value displayable is 1FFF assuming hexidecimal digits or
1999 for decimal digits.
DS41401A-page 24
© 2009 Microchip Technology Inc.
Hardware Libraries and Drivers
5.7.2
LCD Function Interface
5.7.2.1
lcd_init
This function configures the LCD peripheral for this board and this glass. Type B
waveforms are used to allow the LCD peripheral to be used for the real time clock
function. The Timer1 oscillator is configured as the LCD clock source.
FIGURE 5-7:
System_initialize()
{
lcd_init();
}
5.7.2.2
lcd_display_digits
This function accepts a BCD_TYPE variable and maps each digit to the correct
segments. Mapping the segments is done in two stages. First, the digit is converted to
the correct 7-segment mapping. Then, the 7-segment mapping is converted to the
actual glass segments with a long series of “if-else” statements. This function will need
extensive work in the “if-else” statements for applications driving different glass.
FIGURE 5-8:
void display_int(int t)
{
BCD_TYPE bcd;
bcd.digit0 = t %10;
t /= 10;
bcd.digit1 = t % 10;
t /= 10;
bcd.digit2 = t % 10;
t /= 10;
bcd.digit3 = t%10;
lcd_display_digits(bcd);
}
5.7.2.3
lcd_display_on / lcd_display_off
These two functions simply turn the LCD peripheral off. The Timer1 oscillator is left
running. One use for these functions is to implement display blinking.
FIGURE 5-9:
void update_blinking()
{
if(time(0) % 2) // if an odd number of seconds
{
lcd_display_on();
}
else
{
lcd_display_off();
}
}
© 2009 Microchip Technology Inc.
DS41401A-page 25
F1 Evaluation Platform User’s Guide
5.7.3
LCD Segment Definitions
FIGURE 5-10:
LCD DISPLAY
There are many segments present on the F1 Evaluation Platform LCD. To access these
segments, simply set the supplied #defines to 1 or 0.
FIGURE 5-11:
void display_volts(int v)
{
display_int(v);
DP3 = 0;
DP2 = 0;
S1 = 0;
S2 = 0;
AMPS = 0;
VOLT = 1;
KILO = 0;
OHMS = 0;
if (v < 0)
MINUS = 1;
else
MINUS = 0;
}
5.8
USING THE RTCC DRIVER
The RTC driver simply keeps track of seconds. The power-up initial value is ‘0’,
however a function (rtcc_set) is provided to change that value. To keep the seconds
up-to-date, the function, rtcc_handler, must be called more frequently than the
defined value of CLOCKS_PER_SECOND. There are two options for the RTCC driver.
The first option is to use the Timer1 counter to provide a 1 Hz interrupt
(CLOCKS_PER_SECOND = 1). The second option is to use the LCD write-allowed
interrupt flag to provide a 128 Hz event (CLOCKS_PER_SECOND = 128). The two
choices are selected by defining use_lcdif or undefining use_lcdif.
5.8.1
RTCC Function Interface
5.8.1.1
rtcc_init
Intialize the RTCC function including Timer1, if required.
DS41401A-page 26
© 2009 Microchip Technology Inc.
Hardware Libraries and Drivers
FIGURE 5-12:
System_initialization()
{
rtcc_init();
}
5.8.1.2
rtcc_handler
The rtcc_handler function must be called frequently to keep the internal seconds
counter accurate.
FIGURE 5-13:
System_interrupt_service_routine()
{
If(TMR1IF & TMR1IE)
{
TMR1IF = 0;
rtcc_handler();
}
}
5.8.1.3
rtcc_set
After system initialization, the seconds counter is cleared to ‘0’. The standard C
libraries equate 0 seconds to Midnight, Jan 1, 1970. That time has expired a long time
ago, so a new time in seconds can be configured with rtcc_set().
FIGURE 5-14:
#include <time.h>
Time_set() // set the time & date to 1 second after midnight, July 4, 2009
{
struct tm time_str;
time_t unix_time;
time_str.tm_year = 2009; // the year
time_str.tm_mon = 7;
// the month
time_str.tm_mday = 4;
// the day of the month
time_str.tm_hour = 0;
// the hour (0-23)
time_str.tm_min = 0;
// the minutes
time_str.tm_sec = 1;
// the seconds
time_str.tm_isdst = -1; // daylight savings time modifier
unix_time = mktime(&time_str);
rtcc_set(unix_time);
}
5.8.1.4
time
The standard C libraries require the application to supply the time function. This
function returns the current time_t value or loads a supplied time_t value. The
interrupts are saved and restored to make this function safe for use with interrupt driven
code.
5.9
USING THE MCP9800 DRIVER
The MCP9800 is an I2C temperature sensor. The MCP9800 driver provides a simple
interface to the features in the sensor.
© 2009 Microchip Technology Inc.
DS41401A-page 27
F1 Evaluation Platform User’s Guide
5.9.1
MCP9800 Function Interface
5.9.1.1
mcp9800_init
This function configures the mcp9800 for 12-bit temperature, Continuous Conversion
mode. In this mode, the temperature is always ready to be read from the I2C interface.
FIGURE 5-15:
System_init()
{
i2c_init();
mcp9800_init();
}
5.9.1.2
mcp9800_get_temp
This function reads the current temperature and scales the result to degrees C * 10.
(24.3C is returned 243)
FIGURE 5-16:
Thermostat()
{
int temperature;
temperature = mcp9800_get_temp();
if(temperature > 260)
{
turn_on_air_conditioner();
}
}
DS41401A-page 28
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 6. Troubleshooting
6.1
INTRODUCTION
There may come a time when you need to determine why your F1 Evaluation Platform
is not performing correctly. This chapter lists a few of the problems that can prevent
proper operation.
6.2
COMMON PROBLEMS
6.2.1
The board will not power up
Make sure there is no shorting jumper at JP3. Then, go back and review Chapter
2. “Getting Started” of this manual.
6.2.2
LCD is blank, but everything else works
The demo code in supplied with your F1 Evaluation Platform uses the Timer1 oscillator
to drive the LCD. If the Timer1 oscillator is not oscillating, the LCD will remain blank.
Here are some steps to assure that your Timer1 oscillator is working properly.
1. Clean and dry the board especially around the components at the top right corner
of the PIC16LF1937.
2. Make sure no foreign material is shorting the crystal leads.
3. If you are using the RC0 and RC1 pins for some other function, you should
modify lcd_init to reconfigure the LCD peripheral for a different clock
source.
The Timer1 oscillator of the PIC16LF1937 is a very low-power design that can be easily
disrupted by stray leakage. In an actual application, Microchip recommends that the
crystal circuit be conformal coated to prevent leakage. Please review Application Note
AN1288, “Design Practices for Low-Power External Oscillators” for more information.
6.2.3
The motor spins, but then stops
The BLDC start-up algorithm could be having trouble finding the BEMF zero-crossing
signal required to synchronize the motor commutation.
If you have attached the BLDC add-on board and you are using the supplied BLDC
motor, then the pot labeled iRef needs to be turned completely counter clockwise to
assure that a good BEMF zero-crossing signal is detected by the PIC16LF1937.
If you are using a different motor, you need to adjust the zero-crossing threshold to
match the requirements of the motor. For more information, consult the documentation
supplied with the BLDC add-on board.
© 2009 Microchip Technology Inc.
DS41401A-page 29
F1 Evaluation Platform User’s Guide
NOTES:
DS41401A-page 30
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Chapter 7. Schematics
7.1
INTRODUCTION
To help understand the features of the F1 Evaluation Platform and the BLDC add-on
board, the schematics are included here.
© 2009 Microchip Technology Inc.
DS41401A-page 31
F1 Evaluation Platform User’s Guide
F1 Evaluation Platform Schematic (1 of 3)
7.1.1
DS41401A-page 32
© 2009 Microchip Technology Inc.
Schematics
7.1.2
F1 Evaluation Platform Schematic (2 of 3)
© 2009 Microchip Technology Inc.
DS41401A-page 33
F1 Evaluation Platform User’s Guide
7.1.3
F1 Evaluation Platform Schematic (3 of 3)
DS41401A-page 34
© 2009 Microchip Technology Inc.
Schematics
7.1.4
BLDC Add-On Schematic (1 of 3)
© 2009 Microchip Technology Inc.
DS41401A-page 35
F1 Evaluation Platform User’s Guide
7.1.5
BLDC Add-On Schematic (2 of 3)
DS41401A-page 36
© 2009 Microchip Technology Inc.
Schematics
7.1.6
BLDC Add-On Schematic (3 of 3)
© 2009 Microchip Technology Inc.
DS41401A-page 37
F1 Evaluation Platform User’s Guide
NOTES:
DS41401A-page 38
© 2009 Microchip Technology Inc.
F1 EVALUATION PLATFORM
USER’S GUIDE
Index
Numerics
I
2C Demo .................................................................. 19
3.5-digit LCD ............................................................ 12
ICSP pins ................................................................. 17
Internet Address......................................................... 8
A
L
AC164110 ................................................................ 17
Ammeter .................................................................. 14
LCD Demo ............................................................... 19
LCD Display ............................................................. 15
LCD Function Interface ............................................ 25
lcd_display_digits.............................................. 25
lcd_display_on / lcd_display_off ....................... 25
lcd_init............................................................... 25
Linear regulator ........................................................ 15
B
BEMF Zero crossing signal ...................................... 29
BLDC Demo ............................................................. 19
BLDC expansion ...................................................... 14
BLDC motor ............................................................. 15
C
C12IN3-.................................................................... 18
CCP1 Output A ........................................................ 18
CCP1 Output B ........................................................ 18
CCP1 Output C ........................................................ 18
Centigrade ............................................................... 15
COM1....................................................................... 18
COM2....................................................................... 18
COM3....................................................................... 18
Combined Demo ...................................................... 19
Common Problems .................................................. 29
Customer Notification Service.................................... 8
Customer Support ...................................................... 9
D
Documentation
Conventions ........................................................ 6
Layout ................................................................. 5
E
Enhanced midrange microcontrollers....................... 11
EUSART RX ............................................................ 18
F
F1 Evaluation Platform............................................. 11
F1 Evaluation Platform Schematic ........................... 32
H
Hardware Features .................................................. 11
16-bit timers ...................................................... 11
32-MHz internal oscillator ................................. 11
ECCP ................................................................ 11
EEPROM .......................................................... 11
EUSART ........................................................... 11
LCD controller ................................................... 11
RAM .................................................................. 11
Hardware Libraries & Drivers ................................... 21
© 2009 Microchip Technology Inc.
M
MCLR ....................................................................... 18
MCP9800 ................................................................. 11
Temperature sensor.......................................... 11
Microchip Internet Web Site ....................................... 8
MSSP SCLK............................................................. 18
MSSP SDA............................................................... 18
P
PGC ......................................................................... 18
PGD ......................................................................... 18
PIC® microcontrollers .............................................. 11
PIC16 series............................................................. 11
PIC16F1 Evaluation Kit ............................................ 11
PIC16F1 family......................................................... 11
PIC16LF1937 ........................................................... 11
PICkit ICSP™ programming capability interface...... 17
PICkit Serial ............................................................. 14
PICkit Serial connector............................................. 14
PICkit Serial power output........................................ 14
PICkit™ 2 ................................................................. 17
PICkit™ 3 ................................................................. 17
Platform Contents .................................................... 11
F1 Evaluation Platform Demo Board ................ 11
Powering with PICkit 3 ............................................. 13
JP1.................................................................... 13
JP2.................................................................... 13
PICkit ICSP connector ...................................... 14
Voltage.............................................................. 14
Programming & debugging ...................................... 12
R
RD1 .......................................................................... 18
RD2 .......................................................................... 18
RE0 .......................................................................... 18
RE1 .......................................................................... 18
RE2 .......................................................................... 18
Reading, Recommended ........................................... 7
Readme...................................................................... 7
DS41401A-page 39
F1 Evaluation Platform User’s Guide
REAL ICE™ in-circuit emulator ................................ 17
S
Segment 17 .............................................................. 18
Sensorless BLCD add-on board............................... 12
Supply voltage.......................................................... 13
T
T1OSCI .................................................................... 18
T1OSCO .................................................................. 18
U
User Interface........................................................... 16
Pot ADC value .................................................. 16
RPM .................................................................. 16
Temperature ..................................................... 16
Time .................................................................. 16
W
Warranty Registration................................................. 7
WWW Address ........................................................... 8
X
XLP low power ......................................................... 11
DS41401A-page 40
© 2009 Microchip Technology Inc.
F1 Evaluation Platform User’s Guide
NOTES:
© 2009 Microchip Technology Inc.
DS41401A-page 41
WORLDWIDE SALES AND SERVICE
AMERICAS
ASIA/PACIFIC
ASIA/PACIFIC
EUROPE
Corporate Office
2355 West Chandler Blvd.
Chandler, AZ 85224-6199
Tel: 480-792-7200
Fax: 480-792-7277
Technical Support:
http://support.microchip.com
Web Address:
www.microchip.com
Asia Pacific Office
Suites 3707-14, 37th Floor
Tower 6, The Gateway
Harbour City, Kowloon
Hong Kong
Tel: 852-2401-1200
Fax: 852-2401-3431
India - Bangalore
Tel: 91-80-3090-4444
Fax: 91-80-3090-4080
India - New Delhi
Tel: 91-11-4160-8631
Fax: 91-11-4160-8632
Austria - Wels
Tel: 43-7242-2244-39
Fax: 43-7242-2244-393
Denmark - Copenhagen
Tel: 45-4450-2828
Fax: 45-4485-2829
India - Pune
Tel: 91-20-2566-1512
Fax: 91-20-2566-1513
France - Paris
Tel: 33-1-69-53-63-20
Fax: 33-1-69-30-90-79
Japan - Yokohama
Tel: 81-45-471- 6166
Fax: 81-45-471-6122
Germany - Munich
Tel: 49-89-627-144-0
Fax: 49-89-627-144-44
Atlanta
Duluth, GA
Tel: 678-957-9614
Fax: 678-957-1455
Boston
Westborough, MA
Tel: 774-760-0087
Fax: 774-760-0088
Chicago
Itasca, IL
Tel: 630-285-0071
Fax: 630-285-0075
Cleveland
Independence, OH
Tel: 216-447-0464
Fax: 216-447-0643
Dallas
Addison, TX
Tel: 972-818-7423
Fax: 972-818-2924
Detroit
Farmington Hills, MI
Tel: 248-538-2250
Fax: 248-538-2260
Kokomo
Kokomo, IN
Tel: 765-864-8360
Fax: 765-864-8387
Los Angeles
Mission Viejo, CA
Tel: 949-462-9523
Fax: 949-462-9608
Santa Clara
Santa Clara, CA
Tel: 408-961-6444
Fax: 408-961-6445
Toronto
Mississauga, Ontario,
Canada
Tel: 905-673-0699
Fax: 905-673-6509
Australia - Sydney
Tel: 61-2-9868-6733
Fax: 61-2-9868-6755
China - Beijing
Tel: 86-10-8528-2100
Fax: 86-10-8528-2104
China - Chengdu
Tel: 86-28-8665-5511
Fax: 86-28-8665-7889
Korea - Daegu
Tel: 82-53-744-4301
Fax: 82-53-744-4302
China - Hong Kong SAR
Tel: 852-2401-1200
Fax: 852-2401-3431
Korea - Seoul
Tel: 82-2-554-7200
Fax: 82-2-558-5932 or
82-2-558-5934
China - Nanjing
Tel: 86-25-8473-2460
Fax: 86-25-8473-2470
Malaysia - Kuala Lumpur
Tel: 60-3-6201-9857
Fax: 60-3-6201-9859
China - Qingdao
Tel: 86-532-8502-7355
Fax: 86-532-8502-7205
Malaysia - Penang
Tel: 60-4-227-8870
Fax: 60-4-227-4068
China - Shanghai
Tel: 86-21-5407-5533
Fax: 86-21-5407-5066
Philippines - Manila
Tel: 63-2-634-9065
Fax: 63-2-634-9069
China - Shenyang
Tel: 86-24-2334-2829
Fax: 86-24-2334-2393
Singapore
Tel: 65-6334-8870
Fax: 65-6334-8850
China - Shenzhen
Tel: 86-755-8203-2660
Fax: 86-755-8203-1760
Taiwan - Hsin Chu
Tel: 886-3-6578-300
Fax: 886-3-6578-370
China - Wuhan
Tel: 86-27-5980-5300
Fax: 86-27-5980-5118
Taiwan - Kaohsiung
Tel: 886-7-536-4818
Fax: 886-7-536-4803
China - Xiamen
Tel: 86-592-2388138
Fax: 86-592-2388130
Taiwan - Taipei
Tel: 886-2-2500-6610
Fax: 886-2-2508-0102
China - Xian
Tel: 86-29-8833-7252
Fax: 86-29-8833-7256
Thailand - Bangkok
Tel: 66-2-694-1351
Fax: 66-2-694-1350
Italy - Milan
Tel: 39-0331-742611
Fax: 39-0331-466781
Netherlands - Drunen
Tel: 31-416-690399
Fax: 31-416-690340
Spain - Madrid
Tel: 34-91-708-08-90
Fax: 34-91-708-08-91
UK - Wokingham
Tel: 44-118-921-5869
Fax: 44-118-921-5820
China - Zhuhai
Tel: 86-756-3210040
Fax: 86-756-3210049
03/26/09
DS41401A-page 42
© 2009 Microchip Technology Inc.