Adapter definition file
If your (simple) programmer for the parallel or serial port is not listed
on the 'interface' tab, here's what to do:
- Copy and rename one of the SampleInterfaceXXX.xml in the WxPic install directory into another file, for example
MyInterface.xml
- With your favorite text editor, load 'your' file and modify it for your needs with the following entries ... some of them optional, only a few are mandatory,
marked with "m"=mandatory:
- DataIn (m)
- serial data line from PIC to PC. Example for a simple interface on the serial
port:
DataIn="cts"
- OkButton
- signal from programming adapter to PC for an optional "OK"-button.
- VppOnOff (m)
- control line to turn the programming voltage on(H) and off(L). From PC to
PIC. Example for a simple interface:
VppOnOff="txd"
- VddOnOff
- control line to turn the supply voltage on(H) and off(L). From PC to PIC.
- PullMclrDown
- control line to pull the MCLR pin down to ground. As far as I know, only
Microchip's "AN589"-programmer uses this (with PullMclrDown=D4)
- Connect
- control line to connect(H) or disconnect(L) the target. From PC to programming
interface. Usually
"!D7"
.
- ClockOut (m)
- serial clock output from PC to PIC. Example for a simple interface on the
serial port:
ClockOut="rts"
- DataOut (m)
- Definies the interface signal which is used to send serial data
output from PC to PIC. Example for a simple interface on the serial port:
DataOut=dtr
- DataOutWhileReading
- Defines the logic state (not a control signal) of the data output
line while reading. For most interfaces, the data output must be set to a
logic "1" by the programmer, so the PIC can pull the serial output low (because
most interfaces use an NPN-transistor or open collector output stage, and
a pullup resistor connected to Vdd). For interfaces with a tristate output,
the level of the serial ouput line while reading doesn't matter (use "OutEnable"
to define the control line for the tristate driver in that case). Example
for a simple interface on the serial port:
DataOutWhileReading="1"
- ClkEnable
- Tristate buffer control for the serial clock output. As far as I know, the
only interface which uses this is the original Microchip "AN589" programmer.
"H" level means output enabled (from PC to PIC), "L" means output disabled
(high impedance). Example for a simple interface:
ClkEnable="nc"
- OutEnable
- Tristate buffer control for the data output. As far as I know, the only interface
which uses this is the original Microchip "AN589" programmer. "H" level means
output enabled (from PC to PIC), "L" means output disabled (high
impedance).
- RedLed
- Optional output from the PC to a red LED on the programmer, signalling "error
state" after programming.
- GreenLed
- Optional output from the PC to a green LED on the programmer, signalling
"success" after programming.
The function token in the definition file is followed by a "="
character, and a symbolic definition for the control signal which
is used. This can be any of the centronics data lines, inverted (LOW-active)
or not inverted (HIGH-active). "Active" must be seen from the target's point
of view. If -for example- there is an inverter between the serial data output
on centronics D0 and the PIC's "RB7" pin, the definition line must be
DataOut="!D0"
- which means
- "The serial data output is connected to D0, inverted" (the '!' character
to invert something is "C"-style)
These names can be used for control lines on the centronics port ("LPT1"
or "LPT2"). Non-inverted always means active-HIGH level on the PC's output,
no matter what the centronics printer specification says (signals which are
inverted by the PC hardware are automatically inverted by software !).
- D0, D1, ... D7
- centronics data, not inverted. Can be used as OUTPUTS from PC to target.
- !D0, !D1, ... !D7
- centronics data, inverted. Can be used as OUTPUTS from PC to target.
- pap, !pap
- centronics "paper out", normal (H=active) or inverted (L=active). Can be
used as INPUT from target to PC.
- ack, !ack
- centronics "acknowledge", normal (H=active) or inverted (L=active). Can be
used as INPUT from target to PC.
- str, alf, psl, ini
- Other control signals OUTPUTS from PC to target: strobe, automatic line feed,
select printer, initialize printer(reset).
- bsy, sld, err
- Other INPUTS from target to PC: busy, selected, error
- nc
- not connected. Use this token for all unused/unsupported functions, like
"RedLed=nc" . All unused functions appear disabled on the "Interface
Test" tab.
For an interface on the serial port, these control lines are available (may
be used if you have an interface with an inverting RS-232 level converter
like the MAX232). If you use the original "COM84" programmer, you don't have
to write your own interface definition !
- txd, !txd
- Transmit Data (here: abused as simple control line). For COM84, "txd" is
used as programming voltage (non-inverted)
- dtr, !dtr
- Data Terminal Ready. For COM84, "dtr" is used as serial data output from
PC to PIC (non-inverted)
- rts, !rts
- Ready To Send. For COM84, "rts" is the serial clock output from PC to PIC.
- cts, !cts
- Clear To Send. For COM84, "cts" is the serial data input (from PIC to PC).
Other "control signal tokens" are listed in the LPT
connector table, or in the SampleInterfaceXXX.xml files. Every
macro definition can control up to 4 output lines, like:
SelVddHigh=D0+D1+!D2+!D3
which will set both D0+D1 high and D2+D3 low when the supply voltage shall
generator shall be configured for "high supply voltage (see notes on simple production-grade programmers).
If you have the source code of WxPic, look for "PicHw_TokenToInOutFunc()"
to find out which tokens are implemented so far ;-)
To continue the installation of a customized programming interface...
- Save your modified interface definition file now, and close the text editor.
- Open WinPic's "Interface" tab and select "Custom , on XXX port, defined by
file" (XXX = COM or LPT; scroll to the end of the list !).
Notice that the edit field under "Custom interface definition file" will
be enabled now.
- Enter the name of your interface definition file in the edit field, or click
"Select" to open a file selector.
- If an error message like "invalid signal definition" appears, check your
interface definition file again (with a text editor) and try again.
If everything is ok, check the proper function of the control lines with
the interface test option. Keep your interface
definition file at its place, because this file will be loaded whenever
you start the program again (the definitions are NOT copied
into the SETTINGS.INI file. Only the name of your interface
definition file is saved in the settings !)
Signals on the PC's 25-pin
"LPT" connector (SUB-D)
Pin Nr |
Signal |
token name
in interface
definition file |
Direction
|
Description
(usual function) |
1 |
/STROBE |
str |
PC->printer |
'Byte clock' |
2 |
D0 |
D0 |
PC->printer |
Centronics Data |
3 |
D1 |
D1 |
PC->printer |
Centronics Data |
4...8 |
... |
... |
PC->printer |
Centronics Data |
9 |
D7 |
D7 |
PC->printer |
Centronics Data |
10 |
/ACK |
ack |
printer->PC |
Acknowledge |
11 |
BUSY |
bsy |
printer->PC |
Busy or Error |
12 |
PAPER |
pap |
printer->PC |
high=printer ran out of paper |
13 |
SELECTED |
sld |
printer->PC |
high=printer is on-line |
14 |
/ALF |
alf |
PC->printer |
automatic line feed |
15 |
/ERROR |
err |
printer->PC |
out of paper, error, offline |
16 |
/INIT |
ini |
PC->printer |
resets the printer |
17 |
/PRINTER SEL |
psl |
PC->printer |
low = select printer |
18..25 |
GROUND |
|
- |
connect ALL LINES to ground |
Original Author for WinPic: Wolfgang Buescher (DL4YHF)
Adapted to WxPic by Philippe Chevrier