Interconexion HC11
Interconexion HC11
by AN2103/D
AN2103
by Alan Devine
Systems Engineering
East Kilbride, Scotland.
1 Introduction
This application note describes a LIN demo that was designed for the
SAE show in March 2000. The project was intended to demonstrate the
LIN protocol, tools and Freescale products that were available. Although
the demo is purely visual and does not represent any particular
application, it does introduce many features that would be implemented
in actual applications, such as CAN-LIN gateway, sleep mode,
messaging scheme, LIN drivers and LIN tools. The hardware was
designed to be flexible and can easily be configured to drive many real
applications.
An introduction to the LIN protocol and general description of the demo
is presented first, followed by a detailed description of the hardware and
software, including schematics and flow diagrams. All code listings are
included in the Appendix.
hardware
• Enabler for hierarchical networks
Data is transferred across the bus in fixed form messages of selectable
lengths. The master task transmits a header that consists of a break
signal followed by synchronization and identifier fields. The slaves
respond with a data frame that consists of between 2, 4 and 8 data bytes
plus 3 bytes of control information. Figure 1 shows the communication
concept of message transfer and the message format.
master task
MESSAGE FRAME
HEADER RESPONSE
In-Frame
Interbyte
response
Space
space
2
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Local Interconnect Network Bus (LIN)
Header Frame
The master controls all bus traffic on the network. The master initiates
communication by transmitting a header frame with synchronization and
identifier information. Any slave, including the slave task in the master
control unit, can respond with a data frame. Only one slave can respond
to each identifier. However, any number of slaves can be configured to
recognize a particular identifier driven on the bus. The master control
unit can transfer data to any number of slaves through its slave task. i.e.
the master’s slave task responds to a header (sent by the master) and
transmits data on to the bus. All other slaves can simultaneously receive
the data frame.
2.1 Header
Freescale Semiconductor, Inc...
TSYNBRK TSYNDEL
AN2103
The final part of the header is the IDENTIFIER FIELD that denotes the
content and length of a message. The content is represented by 6
identifier bits and 2 parity bits. Identifier bits ID4 and ID5 specify the
number of data fields in a message. Figure 3 shows the identifier field.
IDENTIFIER
Freescale Semiconductor, Inc...
FIELD
START
BIT
2.2 Response The response frame is always transmitted by the slave task (this can be
Frame the slave in the master). It consists between 2, 4 or 8 data fields and a
checksum field. The data fields consist of 8 bits of data transmitted LSB
first. The checksum contains an inverted modulo 256 sum over all data
bytes.
2.3 Sleep Mode A reserved Sleep Mode Frame with a fixed 0x80 identifier was specified
Frame in the original version of the LIN specification. In version 1.2 or later the
Sleep Mode Frame has been removed and replaced by reserved
identifiers, which are described in section 2.4. However, as the demo
software was developed to the original specification it uses the fixed
identifier 0x80 as the Sleep Mode Frame.
NOTE: Any slave node can bring the bus out of sleep mode (by transmitting the
WAKE_UP signal). However, it is only the master that is allowed to put
the network to sleep.
AN2103
4
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Local Interconnect Network Bus (LIN)
Reserved Identifiers
2.4 Reserved Version 2.1 of the LIN specification contains reserved identifiers;
Identifiers Command frame identifiers and Extended frame identifiers.
The download frame is used to send commands and data from master
to the slave nodes. The upload frame is used to trigger one of the slave
nodes (being addressed by a prior download frame) to send data to the
master.
Additionally, command frames with their first byte containing 0x00 to
0x7F are reserved for specific use by the LIN consortium. The remaining
frames are free to be assigned by the user.
2.4.2 Sleep Mode The SLEEP MODE COMMAND is used to broadcast the sleep mode to
Command all bus nodes. The SLEEP MODE COMMAND is a download
COMMAND FRAME with the first data byte set to 0x00
2.4.3 Extended Two EXTENDED FRAME IDENTIFIERS have been reserved to allow
Frame Identifier the embedding of user defined message formats and for future
expansion without violating the specification. The frame structure is
identical to regular 8-byte message frames with the following reserved
IDENTIFIER FIELDS:
0xFE – User defined extended frame
0xBF – Future LIN extension
The identifier can be followed by an arbitrary number of LIN BYTE
FIELDS. The frame length, communication concept and data content are
not specified. Also, the length coding within the ID field does not apply
to the EXTENDED frame identifiers.
AN2103
The LIN Demo consists of a single master node and twelve slave nodes
mounted on a ‘clock face’ (see Figure 4 for details). The master controls
all slave nodes. It schedules messages that flash the slave’s LEDs in a
predetermined sequence. In addition, on a request from the master,
each slave node responds with a status messages. The status returned
is the value of 2 HEX switches mounted on the slave hardware. The
value can be changed, in real time, and monitored on the LIN and CAN
buses.
Freescale Semiconductor, Inc...
The demo has several modes of operation that are described below.
Each mode is selected by a CAN message or by a switch on the master
node, when operated in standalone mode. Finally, the master node can
be removed and the demo can be driven using a VCT LINspector
configured in emulation mode.
AN2103
6
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
SAE Demo Description
Demo Configuration:
NOTE: The LINspector is a cost effective LIN tool that can be used in a variety
of situations, including development, testing and verification. It is driven
from a LIN configuration description file, which contains all details of the
network. It can be used to monitor all traffic, provide detailed timing
information and advanced triggering functions. Additionally, it enables
basic and advanced emulation features that allow the user to ‘replace’
any number of nodes on the network. Refer to VCT’s web page for more
details. The URL is http://www.vct.se
3.1 Demo
Freescale Semiconductor, Inc...
Configuration:
3.1.3 Emulator: VCT LINspector used to control the demo and display all bus activity.
3.2 Modes of
operation:
3.2.1 Default In this mode, the master sequentially transmits messages to the slave
Mode: nodes that control their LEDs. The slaves respond with the settings of
their HEX switches. The switch settings are translated to a CAN
message and transmitted onto the CAN bus. If a slave node is removed
a NO_NODE code (0x00) is transmitted on to the CAN bus
3.2.2 Broadcast In this mode, the master periodically transmits a messages that each
Mode: slave node simultaneously receives. The transmitted messages switch
on the slave’s LEDs. The master node controls the LED pattern.
AN2103
3.2.3 Ident Mode: This mode is primarily used to set-up the demo. The master transmits a
broadcast message that each slave node receives. On reception of this
message, the slaves output their IDs to the LEDs.
3.2.4 Sleep Mode: This is the demo’s low power mode. The master transmits a sleep
command that signals to the slaves to enter sleep mode by disabling
their voltage regulators. The master also enters sleep mode once the
sleep command has been successfully transmitted. Any slave can
wake-up the demo by pressing the red buttons around the perimeter of
the ‘clock face’. The slave node that is woken up wakes up the entire
network by transmitting a wake-up sequence on the LIN bus.
Freescale Semiconductor, Inc...
The LIN physical interface (MC33399) supports wake-up from the bus
and from an external source. On the detection of a valid wake-up signal,
the physical interface drives its inhibit output signal low, enabling an
external voltage regulator (if this feature is used). Alternatively, the
inhibit output can be used to drive the IRQ of the microcontroller. Refer
to MC33399 data sheet for specific application details.
3.3 LIN A simple data driven messaging scheme was used to control the demo.
Messaging Each slave node is statically configured to recognize 3 LIN message
Scheme identifiers. These are a NodeX_Write, a NodeX_Read and a Broadcast
message, where X denotes the node number. This allows the master to
transmit commands and data to individual nodes and for each node to
transmit status responses back to the master. The broadcast message
identifier is common to each slave node. It allows the master to transmit
data to all the nodes simultaneously. Table 1 lists the messages that
were used for the demo.
Table 1 LIN Messages
Message Name Message ID Slave Response Slave Response Description
(LIN ID) Source Destination
Node1_Write LINMsg01 (0xC1) Master Slave_ID 1 Master transmits node1 control
command
Node2_Write LINMsg02 (0x42) Master Slave_ID 2 Master transmits node2 control
command
Node3_Write LINMsg03 (0x03) Master Slave_ID 3 Master transmits node3 control
command
Node4_Write LINMsg04 (0xC4) Master Slave_ID 4 Master transmits node4 control
command
Node5_Write LINMsg05 (0x85) Master Slave_ID 5 Master transmits node5 control
command
Node6_Write LINMsg06 (0x06) Master Slave_ID 6 Master transmits node6 control
command
AN2103
8
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
SAE Demo Description
LIN Messaging Scheme
The messages selected for the demo are all 2 bytes long. The first byte
is a command byte and the second is data. Table 2 details the
NodeX_Write Message Format.
AN2103
Command Code
SLAVE_LEDS_COMMAND 0x01
CLOCK_LEDS_COMMAND 0x03
Freescale Semiconductor, Inc...
Command Code
BROADCAST_COMMAND 0x02
IDENT_COMMAND 0x04
SLEEP_COMMAND 0x80
NOTE: LED pattern sent with command byte. Pattern written to slave node
LEDs. IDENT and SLEEP commands the LED pattern is ignored.
The message format was adopted to allow flexibility within the demo.
Additional commands can be added without too much effort. The slaves
can also easily decode the various commands and act accordingly.
Another benefit is that the master node software has total control over
the LED pattern that the slaves output. In order to change the LED’s
sequence, only the master software has to be changed.
AN2103
10
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
SAE Demo Description
Hardware Description
3.4 Hardware The demo consists of 13 LIN nodes; a single master and 12 slaves. The
Description hardware for each node is identical as shown in the schematic (see
appendix for schematic details). Identical hardware was used to enable
a universal master/slave board to be designed. This makes the slaves
more flexible and reduces demo cost. The main drawback of adopting
this common solution is that the microcontroller required for the master
node, MC68HC908AZ60, is not suitable for slave nodes because of its
Freescale Semiconductor, Inc...
AZ60 MCU
Vdd
Vreg
(LT1121) Gnd
Monitor PTC
Mode
D-Type Connector
CANH/L TX/RX
CAN I/F
CAN
Wake-Up (MC33388) Control
select
LIN
OSC
AN2103
The hardware has several functions that make the design flexible and
suitable for other general CAN and LIN applications.
3.4.1 Monitor The hardware has the additional circuitry included to allow the
Mode microcontroller to communicate with a PC via its monitor mode. This
enables in-circuit Flash programming and simple debugging to be
performed. Hiware’s MON08 target was used in the application
development.
3.4.2 LIN Physical The MC33399 was used in the demo. This interface is a serial link bus
Interface interface designed to provide bi-directional, half-duplex communication
(MC33399) interfacing in automotive applications. It is similar to the ISO9141
interface, but has additional features specific to the LIN protocol. These
features are wake-up from the LIN bus, wakeup from an external source
and slew rate control to reduce EMI emissions. Refer to the MC33399
data sheet for a detailed description and application diagrams.
3.4.3 CAN In addition to the LIN interface, each node has a CAN physical interface
Physical Interface (MC33388). This is required for the master node, as a simple CAN to LIN
gateway is implemented.
3.4.4 LEDs and HEX Each node has 8 LEDs (4 red and 4 green) and 2 HEX switches. The
Switch interface LEDs are driven directly from Port B, configured as output, and used to
demonstrate the LIN protocol and sequencing of messages from the
AN2103
12
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Freescale LIN Drivers and API
master. The switches are input to Port D and allow each node to have a
status and identifier value that can be changed in real time and
transmitted on the LIN bus.
The LEDs and switches are positioned at the edge of the boards and can
easily be removed and the board used to drive an actual application. For
example, the port lines that interface to the LEDs and switches could be
connected to a power drive board and could be used to control motors
of a mirror module. This makes the board very flexible and allows quick
prototyping of LIN applications.
Components used
MC33399 – LIN Physical interface.
MC33388 – Low speed, fault tolerant, CAN physical interface.
4 Software Description
The demo comprises a single master and 12 slave nodes. The master
software is responsible for scheduling LIN messages, providing a CAN
to LIN gateway and general communications. The slave software
interrogates all header frames transmitted on the bus and either receives
a response frame from another slave or transmits a response frame on
to the bus. Each slave waits for a pre-configured message, decodes the
command and either outputs the data to its LED port, if it is a
NodeX_Write or broadcast message, or transmits a status message to
the LIN network, if a NodeX_Read message was detected. The code for
each slave is practically identical, the only difference being the
messages configured are specific to individual nodes. See Table 1 for
details.
The master and slave code implementations both use the Freescale
HC08 LIN low level drivers to manage all the LIN communications. The
drivers and the application code for the demo are described in this
section. All data flow diagrams and flow charts are included. Refer to the
appendix for code listing.
4.1 Freescale The driver provides the full LIN protocol eliminating the application code
LIN Drivers and from implementing the LIN low level kernel. The user interfaces with the
API drivers, statically at compile time and dynamically at run time through an
API. Two versions of the drivers exist: one with a custom Freescale API
and the second with the LIN API. The project used the Freescale API
drivers.
AN2103
AN2103
14
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Freescale LIN Drivers and API
4.1.1 Static The drivers are statically configured through 2 header files, lincfg.h and
Configuration linmsgid.h. The lincfg.h file is used to provide general LIN configuration
information, such as baud rate and timer pre-scalers. The information in
this file is the same for each node on the network, assuming they are all
the same target hardware. The linmsgid.h file is used to define the
node’s messages and whether they are to be received or transmitted.
This file is usually unique to every node on the network. For further
details refer to the LIN drivers manual and the demo configuration files.
4.1.2 Driver API The API is the interface with the drivers. The application code calls the
run time services provided by the driver, during execution. The services
Freescale Semiconductor, Inc...
used in the demo software are described below. Refer to driver manual
for full descriptions of the Freescale and LIN API.
4.1.2.1 LIN_Init: The LIN_Init service performs initialization of the driver. The function
must be called before any other API service call is made. The service
initializes the following functions:
• Sets baud rate (Information entered in lincfg.h file)
• Assigns physical interface pins
• Sets Tx to idle state
• Clears all error flags and counters
• Clears all data buffers
• Change state of drivers to run
• Initializes all variables
AN2103
4.1.2.2 The LIN_GetMsg service retrieves the current content of the specified
LIN_GetMsg: message buffer to an application defined buffer
LIN_MSG_NODATA
AN2103
16
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
4.2 Master code The master software has 2 main tasks that schedule LIN messages
implementation and provide a CAN to LIN gateway. The scheduler operates from a
periodic tick, driven from Timer B overflow, and transmits a header
frame every150ms. The gateway function is driven from the CANRx
interrupt and either changes the demo mode or transmits a LIN
message to a specific slave node. Figure 6 shows the data flow
diagram of the master software.
PortD
CANRxISR
SCITx
RequestMsg
LIN SCI
Drivers Port
CAN GetMsg SCIRx
Message
Handler
Demo
Mode
PutMsg
CAN Global Data
Message Port Buffer
Data Data
PortCAN CANRx
RequestMSG
Read
CANTx
msCAN Demo Data
Buffer Mode
Write
CANTX Data
CAN
Data
Message
Data Schedule
CAN Msg 150ms
Transmit
AN2103
4.2.1 Demo Modes As discussed the demo has several modes of operation that are user
selectable. The mode is controlled by a CAN message or by the HEX
switch on the master PEC, when operated in standalone mode. The
mode can be changed at any time. Table 6 shows the CAN
messages and switch positions that select different modes.
AN2103
18
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
Start
Transmit ALIVE
Message
Y Standalone
Mode
Update
demomode varible N
Freescale Semiconductor, Inc...
Y
DEFAULT
Mode
Call
N DefaultMsgHandler
Y
BROADCAST
Mode
Call
BroadcastMsgHandler
N
Y
IDENT
Mode
Call
N IdentMsgHandler
Y
SLEEP
Mode
Call
N SleepMsgHandler
End
AN2103
4.2.1.1 Default mode In default mode the software executes in a loop that sequentially
transmits 2 messages to each slave node. See Table 7 for sequence.
The first message is a NodeX_Read message that requests a status
response from the slave to indicate that it is present. If the master
does not receive the slave response within a 10mS timeout it is
assumed that the node is not present and a NO_NODE code (0x00)
is transmitted on the CAN bus. The second message transmitted
(assuming a node is present) is a NodeX_Write message that
transmits a command byte and a data byte to a specific slave. The
slave decodes the command and outputs the data to its LED port.
Freescale Semiconductor, Inc...
The scheduler software exits this function then waits in the main loop
before transmitting to the next node in the sequence. The node
number to be transmitted is controlled in the TIMBOVF_ISR. See
main loop for further details.
AN2103
20
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
9 GREEN_LEDS_ON
4 RED_LEDS_ON
8 GREEN_LEDS_ON
5 RED_LEDS_ON
7 GREEN_LEDS_ON
6 ALL_LEDS_ON
7 RED_LEDS_ON
5 GREEN_LEDS_ON
8 RED_LEDS_ON
4 GREEN_LEDS_ON
9 RED_LEDS_ON
3 GREEN_LEDS_ON
10 RED_LEDS_ON
2 GREEN_LEDS_ON
11 RED_LEDS_ON
1 GREEN_LEDS_ON
REPEAT REPEAT
The default message table shows the order that the nodes are written
to and the data that is transmitted.
AN2103
Start
N Index
w ithin range
(1 to 12)
Reset Index to 1
Y
Index N
6 or 12
Freescale Semiconductor, Inc...
C alulate
Y AltScheduleIndex
(AltScheduleIndex = 12 -
ScheduleIndex)
C all Transmit Function
and pass ScheduleIndex,
ALL_LEDS_ON data C all Transmit Function
&MsgReadBuf1 and pass ScheduleIndex,
RED_LEDS_ON data
&MsgReadBuf
Standalone Y
Mode
Update Status
End
AN2103
22
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
Start
Start Timeout
N Timeout or
NewMsg Data
Stop Timeout
N
NewMsg Data
Y
Updata MsgRead Buffer Store new data in MsgRead
with NO_NODE command buffer
Transmit
SLAVES_LED_COMMAND
with data byte passed into
function
End
AN2103
4.2.1.2 Broadcast In this mode, the master software periodically transmits a broadcast
Mode message which is received by every slave node. The first byte of the
message contains the broadcast command, and the second byte
contains the data byte that each slave outputs to its LED port. A
single 1 is shifted through the data byte from bit0 to bit7, the
sequence is then reversed and repeated. The data bytes to be
broadcast are stored in a lookup table. See Table 8 below for details.
0x03
0x07
0x0F
0x1F
0x3F
0x7F
0xFF
NOTE: A lookup table was used to allow the pattern sequence to be changed
with ease
AN2103
24
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
Start
N Index
within range
(0 to 7)
Reset Index to 0 Y
Load Write
Buffer with
Command and
data to be
transmitted
Freescale Semiconductor, Inc...
Transfer
command and
data to LIN
Broadcast
messge
transmit buffer
Request
Transmission of
LIN Broadcast
Message
N Transmission
Complete
Y Index
equal 0
Initialise Up conter N
(UpDownControl =1)
Y
Index
equal 7
Initialise Down
conter N
(UpDownControl =0)
End
AN2103
4.2.1.3 IDENT Mode In this mode, the master software periodically transmits a broadcast
message with an IDENT command. Each slave node receives this
command and outputs its individual identifier to its LED port.
Start
with Ident
Command and
data to be
transmitted
Transfer command
and data to LIN
Broadcast messge
transmit buffer
Request
Transmission of
LIN Broadcast
Message
N Transmission
Complete
End
AN2103
26
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
4.2.1.4 Sleep Mode In this mode, the demo enters its low power state by switching off its
voltage regulator. The master node transmits a SLEEP command
that is received by all slave nodes. Once the SLEEP command has
been successfully transmitted, the master disables its voltage
regulator by driving the LIN interface into its Sleep mode. The
software then waits in an infinite loop until the regulator is disabled.
The master is the only node that can issue a SLEEP command.
The master is woken by a wake-up request initiated by one of the
slave nodes. The LIN I/F device recognizes a specific wake-up
message driven onto the bus. The LIN I/F brings the node out of
sleep mode by turning on the voltage regulator.
Freescale Semiconductor, Inc...
Start
Enable SBC
control ports as
output (PTF pins
as output)
Disable UPL
device
Wait forever
AN2103
4.2.2 CAN The master software also provides CAN communication and
Communication implements a simple CAN to LIN gateway.
The CAN receive and the transmit functions are described below:
4.2.2.1 Receiving The receiver function is interrupt driven. If a message passes the
CAN Messages CAN filters it is written into the CAN receive buffer and a receive
interrupt request is issued. The CANRx ISR sets a msgrxd flag that
indicates that a new message has been received and clears the
Freescale Semiconductor, Inc...
4.2.2.2 CAN Message The basis of the CAN communication and gateway function is
Handlers performed using a series of message handlers. These are described
below:
4.2.2.2.1 Common This handler is used to transmit a LIN message to a particular slave
Message Handler node. The node that the message is transmitted to is determined by an
index (CanMsgIndex). The index is calculated from the CAN message
that was received. The slaves receive the LIN messages and control
the external button LED around the circumference of the ‘clock face’.
Start
Transmit
CLOCK_LED_COMMAND X denotes node number
to slave node X (0 <= x >=12)
End
AN2103
28
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
4.2.2.2.3 ModeSelect This function decodes the CAN mode select message and writes the
Handler appropriate value to the demomode variable.
Start
Freescale Semiconductor, Inc...
DEFAULT Y
MODE
demomode = DEFAULT
N
BROADCAST Y
MODE
demomode =
BROADCAST
N
IDENT MODE Y
N demomode = IDENT
End
4.2.2.2.4 This handler consists of the function prototype. This is included for
DefaultHandler expandability and to ensure that the code does not ‘run away’ even
if an invalid entry in the message handler vector table is accessed,
i.e. all unused entries in the table jump to DefaultMessage handler.
AN2103
4.2.2.3 Transmitting The CAN transmitter function is called from the initialisation and
CAN Messages default mode functions. The identifier and data to be transmitted are
written to TxBuffer0 and transmitted when the bus is idle. The
function that transmits the message, TxCANBuffer(), receives a
pointer to a structure that contains the id and data to be transmitted
and the TxBuffer number as arguments.
Start Start
Freescale Semiconductor, Inc...
Calculate message ID to
be transmitted and copy to
StatusMsg ID field CAN TX0 N
buffer empty
y
Calculate number of data
bytes to be transmitted
and store value in
StatusMsg DLR field Load CANTx buffer with
message ID
End
AN2103
30
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Master code implementation
4.2.2.4 Master Node The main routine is essentially a simple infinite loop that waits for
Main Loop either a msgrxd system flag to be set or a loopcontrol system flag to
be cleared. The msgrxd flag is set in the CANRx_ISR when a CAN
message is received. If the flag is set, the MsgHandlerTable is called
and the appropriate handler routine executed as described in the
Receiving CAN Messages section. The loopcontrol flag is cleared
periodically in the TIMBOVF_ISR, which overflows every 150ms.
When the flag is cleared, the ScheduleMsg function is called and the
selected mode executed. Once the CAN message is received or the
mode executed, the main function resets the appropriate flags and
returns to the infinite loop waiting for a flag to change again.
Freescale Semiconductor, Inc...
AN2103
Start
Initialise MCU
Register
Initialise LIN
Drivers
Transmit Alive
Message
Freescale Semiconductor, Inc...
Initialise Schedule
Table
Initialise loop
control flag
N LoopControl
flag clear or
msgrxd set
Y LoopControl
Flag clear
Schedule
N
Message to be
transmitted
msgrxd Y
Flag set
Call Message
Set LoopControl N Handler Table and
Flag
Execute specific
handler
32
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Slave Code description
4.3 Slave Code The slave code is entirely message driven. The software for each
description node is practically identical, the only difference being the messages
the node is configured to recognize and the nodeID.
The individual slaves are configured to react to 3 preprogrammed
message identifiers: a NodeX_Write, a NodeX_Read and a common
broadcast message (NodeX_Write message that every slave is
programmed to receive). See Table 1 for details. Each slave
monitors every header that the master drives on the bus, but only
reacts to its configured identifiers. If a NodeX_Write message is
detected, it receives the message data, decodes the command, and
either writes to its LED output port or the external output LED or
Freescale Semiconductor, Inc...
Periodic
PortD
Read
Message
Port Data
Status
Msg
Status
Read
C omandData
MsgIndex
PortB
GetMsg
Golbal Data
SCIRx
LIN Buffer
Drivers Write
PutMsg Port Data
SCI
Read
Port
LED
SCITx Data
Write
Message Port Data
Handler
PortE
AN2103
4.3.1 Slave Code The slave code’s main function is very similar to the master’s in that
Main Function it performs some initialization before entering an infinite loop. During
an iteration of the loop, the code updates the status message buffer
by writing the HEX switch settings to the NodeX_Read message
buffer using the LIN_PUTMsg() service and checks to see if a new
received message has been detected. If a new message has been
detected, the MsgHandlerTable is called and the appropriate handler
function is executed. Several housekeeping tasks are also
performed in the main loop, such as control of timeouts etc. Once the
iteration is complete, the code jumps back to the start of the loop and
performs the tasks again.
Freescale Semiconductor, Inc...
AN2103
34
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Slave Code description
Start
Initialise MCU
Register and LIN
Dr ivers
Enable Global
Interrupts
Transfer MsgSent
buffer to LIN
drivers buffer
Freescale Semiconductor, Inc...
(LIN_PutMsg)
N
MsgData
Changed
Y
Reset
WakupTimeOut
N New
NodeX_Write
LIN message
Y
Get message from
LIN buffers and
transfer to
MsgRcvd buffer
Mask command
&Jump to
message handler
table
Reset
WakupTimeOut
N New
NodeX_Write
LIN message
Y
Get message from
LIN buffers and
transfer to
MsgRcvd buffer
Mask command
&Jump to
message handler
table
Reset
WakupTimeOut
AN2103
4.3.2 Receiving LIN Each slave node is configured to receive 2 LIN messages: a
messages broadcast message and a NodeX_Write message. The first byte of
the message is a command. The main function polls the message
status flags of the configured messages and transfers the received
data to the application receive buffer, MsgRcvd, when a valid
message is received. The command byte is decoded and the
appropriate handler function is executed. Each message handler is
described below:
4.3.2.1 Rotating This handler is entered when the demo is configured for default mode
Handler (SLAVE_LEDS command transmitted by the master). The handler
decodes the LED data received, to see if it is to illuminate the RED
Freescale Semiconductor, Inc...
or GREEN LEDs, resets the appropriate time out counter and then
outputs the data to its LED output port.
AN2103
36
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Slave Code description
Start
N Msg Data
equal
RED_LED_ON
Timeout
Msg Data
N equal
GREEN_LED_ON
Reset GREEN
LED Timeout
Enable System
Timeout
End
AN2103
4.3.2.2 Broadcast This handler is entered when the demo is configured for broadcast
Handler mode (BROADCAST command transmitted by the master). The
handler disables the time out and then outputs the data to its LED
output port.
Start
Disable System
Timeout
Freescale Semiconductor, Inc...
End
4.3.2.3 External This handler is entered when the demo is configured for external
Handler mode (CLOCK_LEDS_COMMAND command transmitted by the
master). The handler enables the time out and then outputs the data
to its external output port (PortE, bit4)
Start
Reset external
timeout counter
Enable external
timeout counter
Swiitch on external
LED
End
AN2103
38
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Software Description
Slave Code description
4.3.2.4 Identify This handler is entered when the demo is configured for IDENT mode
Handler (IDENT command transmitted by the master). The handler disables
the time out and then outputs the data to its LED output port
Start
Disable System
timeout
Freescale Semiconductor, Inc...
End
4.3.2.5 Default This handler consists of the function prototype. This is included for
Handler expandability and to ensure that the code does not ‘run away’ even
if an invalid entry in the message handler vector table is accessed.
I.e. All unused entries in the table jump to DefaultMessage handler.
AN2103
4.3.3 Sleep mode is the demo’s low power mode. It is entered when the
Sleep Mode master transmits the SLEEP identifier (0x80). Each slave receives
the command and jumps to the sleep message handler. The handler
disables the voltage regulator by driving the LIN I/F into sleep mode.
Any node can be brought out of sleep mode by an external switch
(switches around the circumference of the clock face) or a wake-up
message (see protocol specification for details) detected on the LIN
bus. The slave that is woken up transmits the wake-up message onto
the bus, which wakes up the master and the other nodes.
Each slave distinguishes between a wake-up (switch on voltage
regulator) and a normal power up sequence, by detecting if the
Freescale Semiconductor, Inc...
AN2103
40
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
5 Code Listings
Engineer : R29414
Location : EKB
*****************************************************************************************
Freescale reserves the right to make changes without further notice to any
Product herein to improve reliability, function or design. Freescale does not
assume any liability arising out of the application or use of any product,
circuit, or software described herein; neither does it convey any license
under its patent rights nor the rights of others. Freescale products are not
designed, intended, or authorized for use as components in systems intended for
surgical implant into the body, or other applications intended to support life,
or for any other application in which the failure of the Freescale product
could create a situation where personal injury or death may occur. Should
Buyer purchase or use Freescale products for any such unintended or
Unauthorized application, Buyer shall idemnify and hold Freescale and its
officers, employees, subsidiaries, affiliates, and distributors harmless
against all claims costs, damages, and expenses, and reasonable attorney fees
arising out of, directly or indirectly, any claim of personal injury or death
associated with such unintended or unauthorized use, even if such claim alleges
that Freescale was negligent regarding the design or manufacture of the part.
Freescale and the Freescale logo* are registered trademarks of Freescale Semiconductor, Inc.
************************************************************************************/
AN2103
0x07,
0x0F,
0x1F,
0x3F,
0x7F,
0xFF
};
/******************************************************************************
Message handler vector table
******************************************************************************/
tU08 MsgWriteBuf [2]; // Temp write buffer used with LIN Drivers
tU08 ScheduleIndex = 0x01; // Slave node index
tU08 AltScheduleIndex = 0x00;
tU08 BroadcastIndex = 0x00; // Broadcast control index
tU08 MsgReadBuf1[2] = {0x00,0x00}; // Temp read buffer used with LIN Drivers
tU08 MsgReadBuf2[2] = {0x00,0x00};
tU08 CanMsgIndex = 0x00;
tU08 TimeoutCount = 0x00; // Timeout counter for slave nodes. Set at 5ms
tU08 LoopControlTime = 0x00;
AN2103
42
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
/******************************************************************************
Function Name : Main
Engineer : R29414
Date : 09/02/2000
Parameters : none
Returns : none
Freescale Semiconductor, Inc...
void main(void)
{
/* Local variables */
tU08 i; // loop control
/***************************************
LIN drivers TOC attached to output ports
Disabled on production software
***************************************/
AN2103
/* Main Loop */
while(1)
{
/* Wait for timer interrupt or CAN receive message */
while ((SystemFlags.bit.loopcontrol==1) && (SystemFlags.bit.msgrxd==0))
;
}
else // CAN message received
{
CanMsgIndex = (AZ60_MSCAN08.rxbuf.dsr[0] & 0x0F);
MsgHandlerTable[CanMsgIndex](); // Jump to message handler table
/******************************************************************************
Function Name : ScheduleTableInit
Engineer : R29414
Date : 09/02/2000
Parameters : none
Returns : none
Notes : Initialise the schedule table. It identifies the slave
on the LIN bus
******************************************************************************/
void ScheduleTableInit (void)
{
/* Local variables */
tU08 i; // Index counter
tU08 msgTempBuffer[] = {0x00, 0x00}; // Initialise temp buffer
AN2103
44
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
if (SystemFlags.bit.linmsgtimeout==0) // No Timeout
{
// Valid message received
LIN_GetMsg (SlaveMsg[i].ReadMsg, msgTempBuffer); // Transfer Node status to Temp buffer */
CurrentSlaveStatus[i-1].Byte1 = msgTempBuffer[1];
} // end of for
/******************************************************************************
Task Name : ScheduleMsg
Engineer : R29414
Date :
Parameters : none
Returns : none
Notes : Determine mode of demo and calls handler
******************************************************************************/
void ScheduleMsg(void)
{
case BROADCAST:
AN2103
case IDENT:
IdentMsgHandler(); // Call IdentMsgHandler
break;
default:
break;
} // End of switch
} // End scheduleMsg
Freescale Semiconductor, Inc...
/******************************************************************************
Task Name : DefaultMsgHandler
Engineer : R29414
Date : 26/07/2000
Parameters : none
Returns : none
Notes :
*******************************************************************************/
void DefaultMsgHandler(void)
{
/* Within range */
if ((ScheduleIndex == 12) || (ScheduleIndex == 6)) // Valid ScheduleIndex
{
/* Node 12 or 6 */
LINTransmit(ScheduleIndex, ALL_LEDS_ON, MsgReadBuf1); // Transmit specified message header frame
}
else
{
AltScheduleIndex = 12 - ScheduleIndex; // Calculate alternate index
AN2103
46
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
} // End DefaultMsgHandler
/******************************************************************************
Task Name : LINTransmit
Engineer : R29414
Date : 26/07/2000
MsgWriteBuf[0] = SLAVE_LEDS_COMMAND;
MsgWriteBuf[1] = ledcommand; //Set up write buffer to transmit command to node
} /* End LINTransmit */
/******************************************************************************
Task Name : BroadcastMsgHandler
Engineer : R29414
Date :
Parameters : none
Returns : none
Notes :
*******************************************************************************/
void
BroadcastMsgHandler(void)
AN2103
{
if (BroadcastIndex < 0 || BroadcastIndex >7) // Dont let Index outwith range
{
BroadcastIndex = 0;
}
MsgWriteBuf[0] = BROADCAST_COMMAND;
MsgWriteBuf[1] = BroadcastTable[BroadcastIndex];
LIN_PutMsg(SlaveMsg[0].WriteMsg, MsgWriteBuf);
LIN_RequestMsg(SlaveMsg[0].WriteMsg);
while (LIN_MsgStatus(SlaveMsg[0].WriteMsg) !=LIN_OK) // Wait for message complete
;
if (BroadcastIndex == 0)
{
SystemFlags.bit.updowncontrol = 0; // Up Counter
Freescale Semiconductor, Inc...
}
if (BroadcastIndex == 7)
{
SystemFlags.bit.updowncontrol = 1; // Down Counter
}
} // End of BroadcastMsgHandler
/******************************************************************************
Task Name : IdentMsgHandler
Engineer : R29414
Date :
Parameters : none
Returns : none
Notes :
*******************************************************************************/
void
IdentMsgHandler(void)
{
MsgWriteBuf[0] = IDENT_COMMAND;
MsgWriteBuf[1] = AZ60_PORT.ptd.byte; // Hex switch input
LIN_PutMsg(SlaveMsg[0].WriteMsg, MsgWriteBuf);
LIN_RequestMsg(SlaveMsg[0].WriteMsg);
while (LIN_MsgStatus(SlaveMsg[0].WriteMsg) !=LIN_OK); // Wait for message complete
} // End of BroadcastMsgHandler
/******************************************************************************
Task Name : MCUInitialisation
Engineer : R29414
Date :
Parameters : none
Returns : none
Notes : Initialise the mcu hardware
*******************************************************************************/
void MCUInitialisation(void)
{
/* Device configuration */
AZ60_KBD.config1.bit.copd = 1; // Disable Watchdog
AZ60_SIM.config2.byte = 1; // AZ Mode and CAN enabled
/* Ports Initialisation */
AZ60_PORT.ddrd.byte = 0x00; // PortD i/p for HEX switches
AN2103
48
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
AZ60_PORT.ptb.byte = 0xFF;
AZ60_PORT.ddrb.byte = 0xFF; // Port B o/p for LEDs
AZ60_PORT.ptc.bit.ptc0 = 0;
AZ60_PORT.ddrc.bit.ddrc0 = 1;
/******************************************************************************
Function Name : TxCANMsg
Engineer : R29414
Date : 22/02/00
for (i=0 ; i < StatusMsg.dlr ; i++ ) // Transfer data bytes to CAN message buffer
{
StatusMsg.dsr[i] = MsgBuffer[i];
}
TxCANBuffer(&StatusMsg,MSCAN_TX0);
}
/******************************************************************************
Function Name : TxCANBuffer
Engineer : R38917
Date : 11/02/00
AN2103
AZ60_MSCAN08.ctflg.byte = TxBufferID;
Freescale Semiconductor, Inc...
/******************************************************************************
Function Name : SetMC33388Mode
Engineer : R38917
Date : 11/02/00
Parameters : Mode
Returns : None
Notes :
******************************************************************************/
case SLEEP_RQ:
AZ60_PORT.ptf.byte = PTF3; //STB=0,EN=1
break;
case RX_ONLY:
AZ60_PORT.ptf.byte = PTF4; //STB=1,EN=0
break;
case NORMAL:
AZ60_PORT.ptf.byte = PTF4|PTF3; //STB=EN=1
break;
default:
;
}
}
/******************************************************************************
Function Name : CommonMsgHandler
Engineer : R38917
Date : 20/07/00
Parameters : None
Returns : None
Notes : This handler is common to the 12 messages as only the index is different.
******************************************************************************/
AN2103
50
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
/******************************************************************************
Function Name : SleepHandler
Engineer : R38917
Date : 11/02/00
Freescale Semiconductor, Inc...
Parameters : None
Returns : None
Notes :
******************************************************************************/
void SleepHandler(void)
{
/* Send out LIN Sleep command */
MsgWriteBuf[0] = SLEEP_COMMAND;
MsgWriteBuf[1] = 0x00;
LIN_PutMsg(SlaveMsg[0].WriteMsg, MsgWriteBuf);
LIN_RequestMsg(SlaveMsg[0].WriteMsg);
SetMC33388Mode(SLEEP_RQ);
SetMC33388Mode(SLEEP);
while(1)
; //placing MC33388 into SLEEP mode switches off the Vreg
}
/******************************************************************************
Function Name : ModeSelect
Engineer : R38917
Date : 10/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void ModeSelect(void)
{
switch(AZ60_MSCAN08.rxbuf.dsr[1]) // Demo mode in byte1
{
case DEFAULT:
DemoMode = DEFAULT; // Put demo in default mode
break;
case BROADCAST:
AN2103
case IDENT:
DemoMode = IDENT; // Put demo in IDENT mode
break;
default:
;
}
}
/******************************************************************************
Function Name : DefaultHandler
Engineer : R38917
Freescale Semiconductor, Inc...
Date : 11/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void DefaultHandler(void)
{
}
/******************************************************************************
Function Name : InitialiseMSCAN08
Engineer : R38917
Date : 10/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void InitialiseMSCAN08(void)
{
AZ60_MSCAN08.cmcr0.bit.sftres = 1; //put CAN module in soft reset
AZ60_MSCAN08.cbtr0.byte = CBT0_125K;
AZ60_MSCAN08.cbtr1.byte = CBT1_125K;
while(!AZ60_MSCAN08.cmcr0.bit.synch)
; //wait for CAN bus to synchronize
}
/******************************************************************************
Task Name : TimerB Overflow
Engineer : R29414
Date :
Parameters : none
Returns : none
Notes : Overflow period set at 1ms.
******************************************************************************/
AN2103
52
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – Master08.C
/* Hiware compiler */
#pragma TRAP_PROC
if (ScheduleIndex >=13)
{
if (DemoMode == BROADCAST)
{
if (SystemFlags.bit.updowncontrol == 0)
{
BroadcastIndex++;
}
else
{
BroadcastIndex--;
}
}
}
if (SystemFlags.bit.starttimeout == 1)
{
if (TimeoutCount<TIMEOUT_PERIOD) // Timeoutperiod set in header file
{
TimeoutCount++;
}
else
{
} // End of ISR
/******************************************************************************
Function Name : CANRxISR
Engineer : R38917
Date : 10/02/00
Parameters : None
AN2103
Returns : None
Notes : CAN message received interrupt service routine
******************************************************************************/
#pragma TRAP_PROC
void CANRx_ISR(void)
{
SystemFlags.bit.msgrxd = 1;
Copyright (c)
File Name : MASTER08.C
Engineer : R29414
Location : EKB
*******************************************************************************
Freescale reserves the right to make changes without further notice to any
Product herein to improve reliability, function or design. Freescale does not
assume any liability arising out of the application or use of any product,
circuit, or software described herein; neither does it convey any license
under its patent rights nor the rights of others. Freescale products are not
designed, intended, or authorized for use as components in systems intended for
surgical implant into the body, or other applications intended to support life,
or for any other application in which the failure of the Freescale product
could create a situation where personal injury or death may occur. Should
Buyer purchase or use Freescale products for any such unintended or
unauthorized application, Buyer shall idemnify and hold Freescale and its
officers, employees, subsidiaries, affiliates, and distributors harmless
against all claims costs, damages, and expenses, and reasonable attorney fees
arising out of, directly or indirectly, any claim of personal injury or death
associated with such unintended or unauthorized use, even if such claim alleges
that Freescale was negligent regarding the design or manufacture of the part.
Freescale and the Freescale logo* are registered trademarks of Freescale, Inc.
************************************************************************************/
#ifndef MASTER08CODEREVIEW_H
#define MASTER08CODEREVIEW_H
AN2103
54
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Master Code – MASTER08.H
} SlaveNodeMsgType;
} SlaveMsgBufferType;
Freescale Semiconductor, Inc...
typedef union
{
tU08 byte;
struct
{
tU08 msgrxd:1; //target connection established
tU08 loopcontrol :1; //Loop control flag
tU08 updowncontrol :1; //Broadcast message up down flag 0=Up, 1=Down
tU08 canmode :1; //Flag indicates mode. Standalone = 1 CAN = 0
tU08 linmsgtimeout :1; //LIN timeout. Timeout = 1, OK = 0
tU08 starttimeout :1; //LIN timeout. Timeout = 1, OK = 0
tU08 :2; // not used
}bit;
}tFLAG;
typedef enum
{
DEFAULT,
BROADCAST,
IDENT,
SLEEPMODE
} DemoModeType_t;
enumtMC33388
{
SLEEP,
SLEEP_RQ,
RX_ONLY,
NORMAL
};
AN2103
/* command bytes */
#define SLAVE_LEDS_COMMAND 0x01
#define BROADCAST_COMMAND 0x02
#define CLOCK_LEDS_COMMAND 0x03
#define IDENT_COMMAND 0x04
#define SLEEP_COMMAND 0x08
#define ALIVE_COMMAND 0x0F
#define ALIVE_BYTE 0xAD
void CommonMsgHandler(void);
void TxCANBuffer(tTXBUF * ,tU08);
void SetMC33388Mode(enum tMC33388);
void SleepHandler(void);
void StatusRequestHandler(void);
void ModeSelect(void);
void DefaultHandler(void);
void InitialiseMSCAN08(void);
void LINTransmit(tU08, tU08, tU08 *);
Engineer : TTZ740
Project : SAE Demo Project
Location : EKB
AN2103
56
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Slave Code – SLAVE08.C
Functions :
Tasks :
*******************************************************************************
Freescale reserves the right to make changes without further notice to any
Product herein to improve reliability, function or design. Freescale does not
assume any liability arising out of the application or use of any product,
circuit, or software described herein; neither does it convey any license
under its patent rights nor the rights of others. Freescale products are not
designed, intended, or authorized for use as components in systems intended for
Freescale Semiconductor, Inc...
surgical implant into the body, or other applications intended to support life,
or for any other application in which the failure of the Freescale product
could create a situation where personal injury or death may occur. Should
Buyer purchase or use Freescale products for any such unintended or
unauthorized application, Buyer shall idemnify and hold Freescale and its
officers, employees, subsidiaries, affiliates, and distributors harmless
against all claims costs, damages, and expenses, and reasonable attorney fees
arising out of, directly or indirectly, any claim of personal injury ordeath
associated with such unintended or unauthorized use, even if such claim alleges
that Freescale was negligent regarding the design or manufacture of the part.
Freescale and the Freescale logo* are registered trademarks of Freescale Inc..
************************************************************************************/
typedef union
{
tU08 byte;
struct
{
tU08 enableTimeout :1; //enable defautl mode timeout
tU08 enableExternal :1; //enable external timeout
tU08 disableWaketime :1;
tU08 :5; //not used
}bit;
}tFLAG;
AN2103
enum tMC33388
{
SLEEP,
SLEEP_RQ,
RX_ONLY,
NORMAL
};
tFLAG SystemFlags;
tU08 REDTIMticks = 0;
tU08 GREENTIMticks = 0;
tU08 EXTERNTIMticks = 0;
Freescale Semiconductor, Inc...
tU08 TIMticks = 0;
tU08 MsgSent[2];
tU08 MsgRcvd[2];
tU16 WakeupTimeout = 0;
/******************************************************************************
Function Name : SetMC33388Mode
Engineer : r38917
Date : 11/02/00
Parameters : Mode
Returns : None
Notes :
******************************************************************************/
case SLEEP_RQ:
AZ60.ptf.byte = PTF3; //STB=0,EN=1
break;
case RX_ONLY:
AZ60.ptf.byte = PTF4; //STB=1,EN=0
break;
case NORMAL:
AZ60.ptf.byte = PTF4|PTF3; //STB=EN=1
break;
default:
;
}
}
/******************************************************************************
Function Name : Rotating LEDs message
Engineer : TTZ740
AN2103
58
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Slave Code – SLAVE08.C
Date : 10/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void RotatingHandler(void)
{
if((MsgRcvd[1] & RED_LED_MASK) != RED_LED_MASK)
REDTIMticks = 0; //reset red timeout period
SystemFlags.bit.enableTimeout = 1;
Freescale Semiconductor, Inc...
/******************************************************************************
Function Name : Broadcast message
Engineer : TTZ740
Date : 10/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void BroadcastHandler(void)
{
SystemFlags.bit.enableTimeout = 0;
AZ60.ptb.byte = ~MsgRcvd[1]; //output data byte to port
}
/******************************************************************************
Function Name : External LED message
Engineer : TTZ740
Date : 10/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void ExternalHandler(void)
{
EXTERNTIMticks = 0; //reset external timeout period
SystemFlags.bit.enableExternal = 1;
AZ60.pte.bit.pte4 = 1; //switch on external LED
}
/******************************************************************************
Function Name : MsgHandler4
Engineer : TTZ740
Date : 10/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void IdentifyHandler(void)
AN2103
{
SystemFlags.bit.enableTimeout = 0;
AZ60.ptb.byte = ~nodeID; //display node ID on LEDs
}
/******************************************************************************
Function Name : SleepHandler
Engineer : r38917
Date : 11/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void SleepHandler(void)
Freescale Semiconductor, Inc...
{
AZ60.ddrf.byte = DDRF3|DDRF4; //enable PTF pins as output
AZ60.pte.bit.pte3 = 0; //disable UPL interface
SetMC33388Mode(SLEEP);
while(1)
; //placing MC33388 into SLEEP mode switches off the Vreg
}
/******************************************************************************
Function Name : DefaultHandler
Engineer : r38917
Date : 11/02/00
Parameters : None
Returns : None
Notes :
******************************************************************************/
void DefaultHandler(void)
{
}
/******************************************************************************
Message handler vector table
******************************************************************************/
AN2103
60
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Slave Code – SLAVE08.C
DefaultHandler,
DefaultHandler
};
/******************************************************************************
Task Name : LINInitialise
Engineer : TTZ740
Date :
Parameters : none
Returns : none
Notes : LIN driver timer setup causes output compare pins to toggle
: which creates a conflict with the hardware design
******************************************************************************/
void LINInitialise(void)
Freescale Semiconductor, Inc...
{
LIN_Init(); //initialise LIN driver
/******************************************************************************
Task Name : LINWakeup
Engineer : TTZ740
Date :
Parameters: none
Returns : none
Notes : Initial hardware design used the UPL interface, which is
: not compatible with the LIN protocol for bus wakeup, hence
: a custom wakeup routine is required for the UPL interface
******************************************************************************/
void LINWakeup(void)
{
SI.sci.scc1.bit.ensci = 0; // disable SCI
SI.sci.scbr.bit.scr = 1; // 10400 baud
SI.sci.scbr.bit.scp = 1; // 10400 baud
SI.sci.scc1.bit.ensci = 1; // enable SCI
SI.sci.scc2.bit.te = 1; // enable transmit
while (SI.sci.scs1.bit.scte == 0)
;
while (SI.sci.scs1.bit.tc == 0)
;
/******************************************************************************
Task Name : initialise
Engineer : TTZ740
Date :
Parameters : none
Returns : none
AN2103
Notes :
******************************************************************************/
LINInitialise();
Freescale Semiconductor, Inc...
TIMER.tsc.byte = 0x54; //enable ovf interrupt, rst counter and /16 prescaler
TIMER.tmod.word = 0x003E; //1mS overflow based on 4MHz xtal
/******************************************************************************
Task Name : main
Engineer : TTZ740
Date :
Parameters : none
Returns : none
Notes :
******************************************************************************/
while( 1 )
{
MsgSent[0] = nodeID; //data byte1 to be sent is node ID
MsgSent[1] = AZ60.ptd.byte; //Data byte1 to be sent is switch status
LIN_PutMsg(MESSAGESEND, MsgSent); //send data to data buffer
if (LIN_MsgStatus(MESSAGESEND) != LIN_MSG_NOCHANGE)
{
WakeupTimeout = 0; //reset wakeup timeout
}
AN2103
62
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Code Listings
Slave Code – SLAVE08.C
/******************************************************************************
Task Name : PIT_ISR
Engineer : TTZ740
Date :
Parameters : none
Returns : none
Notes :
******************************************************************************/
Freescale Semiconductor, Inc...
#pragma TRAP_PROC
void PIT_ISR(void)
{
if(SystemFlags.bit.enableTimeout)
{
if(REDTIMticks < REDTIMPeriod) //check if timeout period for red LEDs has expired
{
REDTIMticks++; //increment ticks
}
else
{
AZ60.ptb.byte |= RED_LED_MASK; //switch off red LEDs
}
if(GREENTIMticks < GREENTIMPeriod) //check if timeout period for green LEDs has expired
{
GREENTIMticks++; //increment ticks
}
else
{
AZ60.ptb.byte |= GREEN_LED_MASK; //switch off green LEDs
}
if(AZ60.ptb.byte == ALL_LEDS_OFF)
SystemFlags.bit.enableTimeout = 0;
}
if(SystemFlags.bit.enableExternal)
{
if(EXTERNTIMticks < EXTERNTIMPeriod) //check if timeout period for external LEDs has expired
{
EXTERNTIMticks++; //increment ticks
}
else
{
AZ60.pte.bit.pte4 = 0; //switch off external LED
}
if(!AZ60.pte.bit.pte4)
SystemFlags.bit.enableExternal = 0;
}
if (!SystemFlags.bit.disableWaketime)
{
AN2103
{
static tU08retry = 0;
if (retry < 3)
{
WakeupTimeout = 0;//reset wakeup timeout
LINWakeup(); //attempt to wake up network
retry++;
}
else
SystemFlags.bit.disableWaketime = 1;
}
}
Freescale Semiconductor, Inc...
Engineer : TTZ740
Location : EKB
*******************************************************************************
Freescale reserves the right to make changes without further notice to any
Product herein to improve reliability, function or design. Freescale does not
assume any liability arising out of the application or use of any product,
circuit, or software described herein; neither does it convey any license
under its patent rights nor the rights of others. Freescale products are not
designed, intended, or authorized for use as components in systems intended for
surgical implant into the body, or other applications intended to support life,
or for any other application in which the failure of the Freescale product
could create a situation where personal injury or death may occur. Should
Buyer purchase or use Freescale products for any such unintended or
unauthorized application, Buyer shall idemnify and hold Freescale and its
officers, employees, subsidiaries, affiliates, and distributors harmless
against all claims costs, damages, and expenses, and reasonable attorney fees
arising out of, directly or indirectly, any claim of personal injury ordeath
associated with such unintended or unauthorized use, even if such claim alleges
that Freescale was negligent regarding the design or manufacture of the part.
Freescale and the Freescale logo* are registered trademarks of Freescale Inc.
************************************************************************************/
#ifndef SLAVE08_H
#define SLAVE08_H
AN2103
64
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Schematic
Slave Code – SLAVE08.H
#if !defined(TRUE)
#define TRUE 0x01
#define FALSE 0x00
#endif
#define ON TRUE
#define OFF FALSE
#define YES TRUE
#define NO FALSE
6 Schematic
AN2103
AN2103
66
For More Information On This Product,
Go to: www.freescale.com
Freescale Semiconductor, Inc.
Schematic
Slave Code – SLAVE08.H
Freescale Semiconductor, Inc...
AN2103
E-mail:
[email protected]
Schatzbogen 7
81829 Muenchen, Germany
+44 1296 380 456 (English)
+46 8 52200080 (English)
+49 89 92103 559 (German)
+33 1 69 35 48 48 (French)
[email protected]
Japan:
Freescale Semiconductor Japan Ltd.
Headquarters
ARCO Tower 15F Information in this document is provided solely to enable system and software
1-8-1, Shimo-Meguro, Meguro-ku, implementers to use Freescale Semiconductor products. There are no express or
Tokyo 153-0064 implied copyright licenses granted hereunder to design or fabricate any integrated
Japan circuits or integrated circuits based on the information in this document.
Freescale Semiconductor reserves the right to make changes without further notice to
0120 191014 or +81 3 5437 9125 any products herein. Freescale Semiconductor makes no warranty, representation or
[email protected] guarantee regarding the suitability of its products for any particular purpose, nor does
Freescale Semiconductor assume any liability arising out of the application or use of
Asia/Pacific: any product or circuit, and specifically disclaims any and all liability, including without
Freescale Semiconductor Hong Kong Ltd. limitation consequential or incidental damages. “Typical” parameters which may be
Technical Information Center provided in Freescale Semiconductor data sheets and/or specifications can and do
2 Dai King Street vary in different applications and actual performance may vary over time. All operating
parameters, including “Typicals” must be validated for each customer application by
Tai Po Industrial Estate customer’s technical experts. Freescale Semiconductor does not convey any license
Tai Po, N.T., Hong Kong under its patent rights nor the rights of others. Freescale Semiconductor products are
+800 2666 8080 not designed, intended, or authorized for use as components in systems intended for
[email protected] surgical implant into the body, or other applications intended to support or sustain life,
or for any other application in which the failure of the Freescale Semiconductor product
For Literature Requests Only: could create a situation where personal injury or death may occur. Should Buyer
Freescale Semiconductor Literature Distribution Center purchase or use Freescale Semiconductor products for any such unintended or
unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor
P.O. Box 5405 and its officers, employees, subsidiaries, affiliates, and distributors harmless against all
Denver, Colorado 80217 claims, costs, damages, and expenses, and reasonable attorney fees arising out of,
1-800-441-2447 or 303-675-2140 directly or indirectly, any claim of personal injury or death associated with such
Fax: 303-675-2150 unintended or unauthorized use, even if such claim alleges that Freescale
[email protected] Semiconductor was negligent regarding the design or manufacture of the part.