Controller Area Network to Modbus network bridge to

interface gas detection units with Building Management

Systems by Quinton, Matthew
University of Southern Queensland
Faculty of Health, Engineering & Sciences
Controller Area Network to Modbus Network Bridge to
interface gas detection units with Building Management
Systems
A dissertation submitted by
Matthew Quinton
in fulfilment of the requirements of
ENG4112 Research Project
towards the degree of
Bachelor of Electrical & Electronic Engineering
Submitted: October, 2015
Abstract
Building Management Systems (BMS') are computer systems designed to control systems
inside buildings or other facilities. While BMS' are common, there is no one size fits all
approach. Controller Area Network (CAN) is a communication protocol sometimes used
within BMS'. Modbus is a very common industrial communications protocol. The two
protocols are not directly compatible and need to be ’bridged’ to communicate with each
other.
Gas Detection Australia (GDA) design and manufacture gas detection equipment. They
have a current and ongoing need to interface Modbus enabled equipment with CAN
enabled equipment in client BMS'. This project is sponsored with the aim of producing
a network bridge to translate between the two protocols. The specific Modbus variation
implemented is Modbus ASCII master.
The design was based around the PIC 18F87K22 microprocessor. This was chosen to
remain consistent with other GDA products. The communication interfaces were designed
using integrated circuits that closely mimic the software development tools. This was a
deliberate choice made to make software development simpler and to make it easier to
translate source code to the finished product. A testing method was also created to allow
the assessment of bridge performance.
Testing demonstrated proof of concept using the development board. Separate testing
of RS-485 hardware suggests that the full hardware specification is valid. Stress tests
were carried out and determined that the bridge could be expected to be capable of
responding to four CAN messages per second. The testing was limited by issues relating
to the inconsistent operation of the CAN interface.
University of Southern Queensland
Faculty of Health, Engineering & Sciences
ENG4111/2 Research Project
Limitations of Use
The Council of the University of Southern Queensland, its Faculty of Health, Engineering
& Sciences, and the staff of the University of Southern Queensland, do not accept any
responsibility for the truth, accuracy or completeness of material contained within or
associated with this dissertation.
Persons using all or any part of this material do so at their own risk, and not at the risk of
the Council of the University of Southern Queensland, its Faculty of Health, Engineering
& Sciences or the staff of the University of Southern Queensland.
This dissertation reports an educational exercise and has no purpose or validity beyond
this exercise. The sole purpose of the course pair entitled “Research Project” is to con-
tribute to the overall education within the student’s chosen degree program. This doc-
ument, the associated hardware, software, drawings, and other material set out in the
associated appendices should not be used for any other purpose: if they are so used, it is
entirely at the risk of the user.
Dean
Faculty of Health, Engineering & Sciences
Certification of Dissertation
I certify that the ideas, designs and experimental work, results, analyses and conclusions
set out in this dissertation are entirely my own effort, except where otherwise indicated
and acknowledged.
I further certify that the work is original and has not been previously submitted for
assessment in any other course or institution, except where specifically stated.
Matthew Quinton
0061024766
Acknowledgments
I would like to thank my academic supervisor, Mr Mark Phythian for his guidance and
support. He often went above and beyond to help me achieve my project aims.
I would also like to thank my two professional supervisors from Gas Detection Australia,
Mr James Boucher and Mr Chris Kelly. Without any of these people this project could
not have taken place. I would especially like to recognise Mr Kelly, who was a continuous
source of knowledge throughout the project. I would also like to thank Mr Trent Rutten
from GDA for his assistance with hands on technical matters.
Finally I would like to thank my wife, Sam who was always there to listen and to help
me through this project. Her patience and understanding were vital.
Matthew Quinton
Contents
Abstract i
Acknowledgments iv
List of Figures xii
List of Tables xiv
Chapter 1 Introduction 1
1.1 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.2 Aim . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3 Project Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.4 Overview of the Dissertation . . . . . . . . . . . . . . . . . . . . . . . . . 4
Chapter 2 Relevant Literature and Design Constraints 5
2.1 Chapter Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
2.2 Building Management Systems . . . . . . . . . . . . . . . . . . . . . . . . 7
2.3 Controller Area Network . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
2.3.1 General CAN Features . . . . . . . . . . . . . . . . . . . . . . . . . 8
CONTENTS vi
2.3.2 Standards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
2.3.3 Frame Format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
2.4 Modbus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.4.1 General Modbus Features . . . . . . . . . . . . . . . . . . . . . . . 11
2.4.2 Frame Format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.4.3 RTU, ASCII and TCP . . . . . . . . . . . . . . . . . . . . . . . . . 14
2.5 Bridging the Protocols . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.5.1 Previous Works . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.5.2 Lessons from Previous Works . . . . . . . . . . . . . . . . . . . . . 16
2.5.3 Existing Bridges and Available Products . . . . . . . . . . . . . . . 17
2.6 Constraints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.7 Chapter Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
Chapter 3 Design Methodology 21
3.1 Chapter Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
3.2 Equipment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
3.3 Hardware Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
3.3.1 Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
3.3.2 CAN Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
3.3.3 Serial Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
3.3.4 Power Supply . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
3.3.5 Isolation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
CONTENTS vii
3.3.6 Ancillary Circuitry . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
3.3.7 Printed Circtuit Board . . . . . . . . . . . . . . . . . . . . . . . . . 29
3.4 Software Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.4.1 CAN Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.4.2 Modbus Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.4.3 Ancillary Functions . . . . . . . . . . . . . . . . . . . . . . . . . . 31
3.4.4 Main . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
3.5 Proposed Testing Methodology . . . . . . . . . . . . . . . . . . . . . . . . 33
3.5.1 RS485 Confirmation . . . . . . . . . . . . . . . . . . . . . . . . . . 34
3.5.2 Physical Cable Testing . . . . . . . . . . . . . . . . . . . . . . . . . 34
3.6 Chapter Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Chapter 4 Design of the Network Bridge 36
4.1 Chapter Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
4.2 Hardware Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
4.2.1 Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
4.2.2 CAN Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
4.2.3 Serial Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
4.2.4 Power Supply . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
4.2.5 Isolation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
4.2.6 Ancillary Circuitry . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
4.2.7 Printed Circuit Board . . . . . . . . . . . . . . . . . . . . . . . . . 42
CONTENTS viii
4.3 Software Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
4.4 Chapter Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
Chapter 5 Results and Discussion 48
5.1 Results . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
5.1.1 Proof of bridge concept . . . . . . . . . . . . . . . . . . . . . . . . 49
5.1.2 Bridge stress testing . . . . . . . . . . . . . . . . . . . . . . . . . . 51
5.1.3 Proof of RS-485 concept . . . . . . . . . . . . . . . . . . . . . . . . 53
5.1.4 Physical Cable Testing . . . . . . . . . . . . . . . . . . . . . . . . . 54
5.2 Discussion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
5.2.1 Proof of Concept . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
5.2.2 Stress Tests . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
5.2.3 Proof RS-485 Concept . . . . . . . . . . . . . . . . . . . . . . . . . 58
5.2.4 Physical Cable Testing . . . . . . . . . . . . . . . . . . . . . . . . . 58
5.2.5 Discussion of issues and limitations - CAN Interface . . . . . . . . 59
5.2.6 Discussion of issues and limitations - Modbusslave simulator . . . 62
5.3 Chapter Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
Chapter 6 Conclusion and Future Work 64
6.1 Conclusions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
6.2 Recommendations and Future Work . . . . . . . . . . . . . . . . . . . . . 66
References 67
CONTENTS ix
Appendix A Project Specification 71
Appendix B Controller Area Network 74
B.1 List of frame field descriptions . . . . . . . . . . . . . . . . . . . . . . . . 75
B.2 Physical Connection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
B.2.1 Topology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
B.2.2 Transmission and Signals . . . . . . . . . . . . . . . . . . . . . . . 76
B.2.3 Encoding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
B.2.4 Synchronisation and Bit Stuffing . . . . . . . . . . . . . . . . . . . 79
B.2.5 Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
B.3 Masks and Filters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
Appendix C Modbus 82
C.1 Protocol Data Unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
C.2 Error Checking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
C.3 Physical Media . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
C.4 RS 485 Data Rates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
C.5 Encoding and Synchronisation . . . . . . . . . . . . . . . . . . . . . . . . 84
Appendix D Network Bridge Source Code - C 85
D.1 C Header . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
D.2 Modbus Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
D.3 Ancillary Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
CONTENTS x
D.4 Main Function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94
Appendix E Hardware Design Images 97
E.1 Schematic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
E.2 PCB Top Layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
E.3 PCB Bottom Layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100
E.4 PCB 3D Top Layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
E.5 PCB 3D Bottom Layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102
Appendix F Results and Discussion Supporting Information 103
F.1 Click Board Schematics . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
F.2 Photos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106
F.3 Code Listings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107
Appendix G Datasheets 108
G.1 PIC18F87K22 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109
G.2 DF04S . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
G.3 HCPL-2601.S . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115
G.4 LM2671 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
G.5 MCP2515 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120
G.6 MCP2551 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
G.7 ROE0505S . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
Appendix H Documentation and Manuals 128
CONTENTS xi
H.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129
H.2 Technical Manual . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129
H.3 Operators Manual . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130
H.4 Software Manual . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130
Appendix I Preliminary Report Documentation 131
I.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132
List of Figures
2.1 CAN Frame - 11bit Identifier (adapted from (Corrigan 2008a)). . . . . . . 10
2.2 CAN Frame - 11bit Identifier (adapted from (Corrigan 2008a)). . . . . . . 10
2.3 Modbus RTU Frame (adapted from (Thomas 2008)). . . . . . . . . . . . . 13
2.4 Modbus ASCII Frame (adapted from (Thomas 2008)). . . . . . . . . . . . 13
4.1 Network Bridge Logical Overview . . . . . . . . . . . . . . . . . . . . . . . 37
4.2 CAN Communications Hardware Interface . . . . . . . . . . . . . . . . . . 39
4.3 Serial Communications Hardware Interface . . . . . . . . . . . . . . . . . 39
4.4 Power Supply Hardware . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
4.5 Indication LEDs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
4.6 Bridge Data Flow Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . 44
5.1 Proof of bridge concept - complete transmission . . . . . . . . . . . . . . . 50
5.2 Percentage of frames received . . . . . . . . . . . . . . . . . . . . . . . . . 52
5.3 RS-485 master packet using 3.3V click board . . . . . . . . . . . . . . . . 53
5.4 Short transmission line CAN traffic . . . . . . . . . . . . . . . . . . . . . . 54
5.5 1 meter twisted pair CAN traffic . . . . . . . . . . . . . . . . . . . . . . . 55
LIST OF FIGURES xiii
5.6 10 meter twisted pair CAN traffic . . . . . . . . . . . . . . . . . . . . . . . 55
5.7 10 meter twisted pair CAN traffic on working bus . . . . . . . . . . . . . . 56
5.8 10 meter twisted pair CAN response . . . . . . . . . . . . . . . . . . . . . 56
5.9 Code exert of serial data sent . . . . . . . . . . . . . . . . . . . . . . . . . 62
5.10 Serial synchronisation errors with 16MHz crystal . . . . . . . . . . . . . . 62
B.1 CAN bit levels (adapted from (ISO 2003a)). . . . . . . . . . . . . . . . . . 77
B.2 NRZ and Manchester Encoding (adapted from (CAN in Automation 2015a)). 78
B.3 CAN bit stuffing (adapted from (CAN in Automation 2015a)). . . . . . . 79
F.1 RS-485 Click board schematic . . . . . . . . . . . . . . . . . . . . . . . . . 104
F.2 CANSpi Click board schematic . . . . . . . . . . . . . . . . . . . . . . . . 105
F.3 RS-485 testing set-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106
List of Tables
2.1 Modbus memory organisation . . . . . . . . . . . . . . . . . . . . . . . . . 12
5.1 Results for frame bridge frame loss - CAN baud 125kbps and Modbus baud
9.6kbps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
Glossary of Terms
A - Ampere
AC - Alternating Current
ASCII - American Standard Code for Information Exchange
CAN - Controller Area Network
CR - Carriage Return (ASCII character)
DC - Direct Current
DFD - Data Flow Diagram
GDA - Gas Detection Australia Pty Ltd
GLCD - Graphical Liquid Crystal Display
IC - Integrated Circuit
IP - Ingress Protection Rating
LED - Light Emitting Diode
LF - Line Feed (ASCII Character)
OSI - Open Systems Interconnection
PCB - Printed Circuit Board
RMS - Root Mean Squared
SPI - Serial Peripheral Interface
UART - Universal Asynchronous Receiver/Transmitter
USB - Universal Serial Bus
V - Voltage/Volts
Messaging Rate - The time delay between CAN frames sent by the USB-CAN converter.
Chapter 1
Introduction
1.1 Motivation 2
1.1 Motivation
GDA designs and manufactures electronic gas sensors and control units. Most of the
sensors are industry standard 4-20 mA output and are hard wired back to control units.
These control units are restricted by only having Modbus, relay switched Volt Free Con-
tacts (VFC) and analogue current outputs to communicate with the customers' existing
equipment. There are a growing number of customers requesting or already using Con-
trolled Area Network (CAN) bus as part of their Building Management System (BMS),
which GDA doesn't currently or plan to support as a direct hardware feature in their
pre-existing products.
GDA wants to explore the development of a CAN bus to Modbus network bridge to
allow customers to directly interface their BMS with GDA control units to simplify the
installation and increase customer satisfaction. The current methods are to add a 4-20
mA current receiver and a CAN bus node with analogue inputs or a CAN bus node with
digital inputs to receive the digital signals generated by the output relays on the control
units. Depending upon the complexity of the customers' system and requirements this
results in significant wiring, which could be replaced by a few wires used by the CAN bus
and Modbus (Gas Detection Australia 2015).
1.2 Aim
GDA requires the development of a network bridge to interface their existing products
with CAN enabled BMS'. The aim is to create a solution to this problem by developing a
network bridge that is capable of interfacing with both CAN enabled BMS' and Modbus
enabled gas detection controllers. The key goal is facilitating the delivery of information
in a bidirectional manner between the two separate systems.
All variations of Modbus will be explored, however the chosen protocol for this bridge is
Modbus ASCII.
1.3 Project Objectives 3
1.3 Project Objectives
The objectives of this project are to design and develop a CAN bus to Modbus network
bridge. The design should be of sufficient quality that it can be used as the base of a
commercial product. It is intended that any prior research or products conducted or
developed for this task will be considered but the final design will be original where
appropriate. The network bridge must be able to reconcile messages sent from Building
Management Systems that operate a CAN bus architecture with that of the Modbus
architecture based gas detection control units.
The Modbus interface must be implemented upon the RS-485 serial standard to be con-
sistent with existing products. Ideally, the network bridge will be configurable between
Modbus RTU and Modbus ASCII. Due to the lack of a RS-485 enabled Modbus ASCII
slave device to test on, testing will be performed using the Universal Asynchronous Re-
ceiver Transmitter (UART) as the physical layer.
The network bridge is intended to be a standalone product; however, it may be expanded
to become a module that may be added to other GDA products. The network bridge
should be developed in line with GDA procedures and methods. Final hardware compo-
nents are to be based upon Printed Circuit Board technology but can be developed and
tested using other methods. Software development is to take place using existing tools
and methods available at GDA.
As well as developing the network bridge, testing procedures and documentation are also
required to ensure correct functionality of the network bridge. Secondary objectives are
to create testing procedures for the network bridge and also to develop documentation on
the operation and maintenance of the network bridge.
1.4 Overview of the Dissertation 4
1.4 Overview of the Dissertation
This dissertation is organized as follows:
Chapter 2 explores the literature and considers existing products as well as requirements
of the sponsoring organisation, Gas Detection Australia.
Chapter 3 details the design methodology as well as the design of the testing parameters
for the bridge.
Chapter 4 includes the final design of the hardware and software for the network bridge.
Chapter 5 examines and discusses the results obtained and the challenges faced in the
design.
Chapter 6 concludes the dissertation and suggests further work in the area of CAN bus
to Modbus network bridges.
Chapter 2
Relevant Literature and Design
Constraints
2.1 Chapter Overview 6
2.1 Chapter Overview
The bridge is to be designed for use with Building Management Systems. This will require
background information on these systems. This is to give an understanding on how the
expected use affects the requirements of the bridge.
To be able to develop a device that translates two separate protocols requires an un-
derstanding of those protocols. This chapter covers some of the basic principles of each
protocol and this gives enough understanding of what is required to reconcile them. The
key differences will be highlighted so that the potential solutions can be developed in later
chapters.
This is further supported by undertaking a review of the literature on this topic as well
as a review of existing commercial products in this space.
2.2 Building Management Systems 7
2.2 Building Management Systems
Building Management Systems (BMS'), sometimes referred to as Building Automation
Systems (BAS) are computer systems that control and monitor various systems within
buildings or facilities. Typical systems that are controlled include heating, ventilation and
air-conditioning (HVAC) electrical distribution, lighting, safety equipment, security sys-
tems, and many more (So 2001). The functionality and capabilities of BMS' are beyond
the scope of this project. An understanding of where the network bridge might fit into
a BMS is the primary concern. As part of the monitoring aspects of BMS', digital and
analogue equipment feeds signals to the BMS. This might include thermostats, sensors,
pressure transducers or numerous other devices (So 2001). The proposed network bridge
is a 'device' that relays gas levels from the field to the BMS. The term device is loose
because in this case it is not a simple sensor but will involve the sensor, controller and
the network bridge. Logically, the network bridge is a gas sensor CAN node within the
BMS.
There are many different communication interfaces used within BMS'. CAN is just one
of the options available when choosing BMS architectures. There is no guarantee that
equipment from one vendor will be compatible with equipment from another, even if they
implement comparable technology (Butzin, Golatowski, Niedermeier, Vicari & Wuchner
2014). As a result, there are no standard requirements or acquisition techniques for BMS'.
The network layout of the BMS, the protocol or protocols used, the individual pieces of
equipment used, and the configuration of the network all contribute to the way a BMS
requests and acquires information. Since all BMS differ it is not possible to satisfy all
requirements with one rigid solution. The aim is to follow the CAN standard as closely
as possible and to give as much flexibility for implementation in different CAN enabled
BMS'. Flexibility would come from configurable parameters for the CAN interface such
as data rates and message types. It may also have flow on affects to the implementation
of the Modbus interface. If possible, examination of a real world BMS would be ideal for
testing of the network bridge to confirm that it operates correctly.
2.3 Controller Area Network 8
2.3 Controller Area Network
Controller Area Network (CAN) was introduced in the mid-1980s by Robert Bosch. The
protocol was designed for distributed automotive control systems. In 1991 Bosch pub-
lished the 2.0 standard containing two parts; part A as the standard for the 11-bit iden-
tifier version and part B as the standard for the 29-bit identifier version. In 1993 CAN
was standardised internationally by the International Organisation for Standards (ISO)
as ISO 11898 (Ferreira & Fonseca 2011). There are two ISO components to a CAN
implementation. ISO 11898-1 defines the data link layer and physical signalling and one
of the parts labelled 11898-X, where X is 2-6 and defines the physical layer for different
applications (ISO 2003a). ISO 11898-2 is the most popular of these physical layer ex-
tensions in use today. Even with the ISO standardisation in place for over twenty years,
CAN is often referred to as CAN 2.0A or 2.0B in reference to the 1991 Bosch standards.
2.3.1 General CAN Features
As mentioned, CAN is a two layer OSI model. ISO 11898-1 is required for CAN implemen-
tations but the system developer has the choice from the 11898-X parts. ISO 11898-2 is
the most common selection and is the assumed standard for this project. It is outside the
scope of the project to implement more than one of the 11898-X parts. Most of the infor-
mation found about CAN is derived direct from these standards (ISO 2003a, ISO 2003b).
CAN is a multi-master system with carrier sense multiple access (CSMA). Each CAN node
on the bus can transmit and receive messages. Collisions are handled using arbitration
of the identifier in the message. CAN is a message orientated system. Message contents
are defined rather than nodes or their addresses. A node will examine the contents of
a frame to determine if it is the desired destination for the frame - if it is not it will
discard the message. Every message has an identifier that is unique on the network and
this defines the content and priority of the message. CAN has numerous in-built fault
handling features including a cyclic redundancy check (CRC).
The physical wiring is a differential pair and CAN defines transmission rates up to 1Mbit
per second over a transmission length of 30 meters (ISO 2003a). Bus lengths of up to
5000 meters are possible at a baud of 10kbits per second. The trade-off for greater speed
is bus run length. CAN has grown to be more than a control system bus for vehicles and
2.3 Controller Area Network 9
is now used in multiple industries including industrial communications, medicine, robotics
and general embedded applications. CAN has benefited from large production volumes
and sound performance to emerge in other industries (Ferreira & Fonseca 2011).
2.3.2 Standards
Exhaustive exploration of the standards is not required. CAN controller chips and com-
piler library functions handle the intricacies of the protocol and their application will be
the focus of this project. An understanding of some aspects is important in order to
properly link CAN to Modbus. ISO 11898-1 defines the data link layer and the physical
signalling aspects of CAN. It forms the base upon which other standards are built. The ba-
sic concepts of CAN, the architecture, Logical Link Control (LLC) sub-layer and Medium
Access Control (MAC) sub-layer are specified. ISO 11898-2 is one of the three extensions
to ISO 11898-1 (ISO 2003a). It defines the high-speed (1Mbit/s) medium access unit and
outlines the medium dependant interface (MDI) features. Electrical characteristics of the
CAN nodes and bus are defined.
ISO 11898-1 is fundamental to any CAN implementation as it specifies the underlying
principles of CAN. From their implementations can vary with requirements. The Inter-
national Organisation for Standards (ISO) defines four other standards to complement
11898-1. They are labelled Part 3 through Part 6. It would be possible to use another
standard for this project; however ISO11898-2 is recognised as the most popular stan-
dard by Ferreira & Fonseca (2011) and will be used for this project. This should allow
maximum compatibility. Higher level protocols have been developed over the years to fill
in the gap where more sophisticated messaging is required. There are several industry
common protocols as well as academic based protocols in existence today. CANopen,
DeviceNet, J1939, FTT-CAN and TT-CAN are some of the more common CAN based
higher level protocols (Ferreira & Fonseca 2011, Corrigan 2008b).
2.3.3 Frame Format
There are two standard frame formats for CAN; one for each of the two addressing modes.
Figure 2.1 is the 11-bit identifier frame and Figure 2.2 is the extended 29-bit identifier
frame. The fields in each frame are considered below.
2.3 Controller Area Network 10
Figure 2.1: CAN Frame - 11bit Identifier (adapted from (Corrigan 2008a)).
The key difference between the two addressing modes is the increased identifier size.
Figure 2.2: CAN Frame - 11bit Identifier (adapted from (Corrigan 2008a)).
Data Frames are the most common frame format and is of the form shown in Figure 2.1
and Figure 2.2.Remote frames are used when a node wants to request information from
another node. The composition is similar to the data frame with two exceptions. The
RTR bit in the arbitration field is marked as recessive to indicate a remote frame and
there will be no data. An error frame is transmitted when a node detects an error in
a message. The other nodes on the bus will respond by sending error frames of their
own. There are safeguards in place to ensure that repeated transmissions of errors do
not completely congest the bus. The overload frame is primarily used to provide a delay
between messages in the event that a node is too busy. It has a similar format to the
error frame.
An in depth discussion of the CAN protocol is beyond the scope of this project. Much
of the implementation of CAN is handled by dedicated integrated circuits and software
libraries. Appendix B contains further specifics about the CAN protocol.
2.4 Modbus 11
2.4 Modbus
Modbus was created in 1979 by Modicon and was a propriety protocol designed for
communication between Modicon Programmable Logic Controllers (PLCs) (de Sousa
& Portugal 2011). Modbus was effectively the first ever industrial field bus protocol
(Hui, Hao & Daogang 2013). Modicon openly published the protocol and it remains free
to use, resulting in Modbus becoming the first de facto standard for industrial commu-
nications. Today it is maintained by Modbus-IDA, is still used widely in industry and
continues to evolve (de Sousa & Portugal 2011).
2.4.1 General Modbus Features
Modbus is free and as such is one of the most widely used protocols across many industries.
It is used with sensors and actuators that are network enabled. It is also used with more
complex automation equipment such as RTUs, PLCs, human machine interfaces (HMIs)
and supervisory control and data acquisition (SCADA) systems (de Sousa & Portugal
2011). Most of these implementations would be either on RS-485 or TCP networks. RS-
232 Modbus implementations are limited to point-to-point connections, such as HMI to
PLC (Thomas 2008).
Modbus is simple to implement and due to its wide use there is a lot of information
freely available. There are also several different implementations, meaning you can pick
the exact flavour that meets your needs. For example, Modbus RTU has smaller frames
than Modbus ASCII so at the same baud is slightly faster (de Sousa & Portugal 2011).
Modbus ASCII has deliberate delimiter, (colon character :) making frame reception an
easier process than RTU.
2.4 Modbus 12
Table 2.1: Modbus memory organisation
Name Memory range Number of bits Functionality
Input registers 1(0)-65,536 (65,535) 16 Read
Holding registers 1(0)-65,536 (65,535) 16 Read and Write
Discrete inputs 1(0)-65,536 (65,535) 1 Read
Coils 1(0)-65,536 (65,535) 1 Read and Write
Modbus allows devices to read and write data to memory locations on another device.
The device performing the reading and writing will have some processing ability (such as
a PLC) but the device being written to and read does not need processing ability (such as
a sensor), although it may have some. Modbus uses the client-server model. The device
processing is the client and it makes requests to the server. The server never initiates an
exchange. Clients can make multiple requests to multiple distinct servers one at a time.
The specification does not allow for servers to have more than one client, but it is possible.
Some devices acting as servers may have the ability to process simultaneous requests but
it is generally done sequentially (de Sousa & Portugal 2011, Modbus Org 2006c).
The reading and writing functions are carried out in the memory of the server. The
protocol defines the organisation of this memory but customisation is allowable (Modbus
Org 2006c). Table 2.1 gives an overview of the specified organisation scheme. Note that
the figures in the table are theoretical only. Many devices will have a memory range
lower than specified here. Typically analogue inputs and outputs are handled through
the registers and the digital inputs and outputs through the discrete inputs and coils.
To access the memory locations of table 2.1 requires specific querying from the Master
to the Slave. This section gives an outline in brief according to the reference guide by
Modicon, Inc. (1996). The are 24 separate function codes within the Modbus specification.
Each function has a unique code that forms part of the Modbus data. For example,
function ’01’ is ’Read Coil Status’. The function code used determines the format of the
frame data. Reading is the key focus of the network bridge so that will be the focus
here. The read functions (01 - 04) have very similar formats. The data component of
the message begins with a slave address. The selected function code appears next. This
is followed by the high and then low bytes of the address to be read. If the address fits
in the low byte, the high will be zero. Likewise with the number of points to be read,
which also has a high and low byte. They are the final two components respectively. An
2.4 Modbus 13
example follows:
To read coils 5-10 (hexadecimal and begins at zero) from slave 11 the query is as follows:
Slave address: 0A
Function: 01
Address high: 00
Address low: 04
Number of points high: 00
Number of points low: 06
The response from the slave follows a similar format but is not the focus given the bridge
is a master only. The query forms the data portion of the Modbus frames discussed next.
2.4.2 Frame Format
The implementations have similarities in their frame composition. They both include the
function code and data fields.
Figure 2.3: Modbus RTU Frame (adapted from (Thomas 2008)).
Each implementation has an address and error checking field. The ASCII frame also has
the explicit start bit (:) and end bits (carriage return and line feed). Figure 3 shows the
format for an RTU frame and Figure 4 shows the format for an ASCII frame.
Figure 2.4: Modbus ASCII Frame (adapted from (Thomas 2008)).
As with CAN, there is a lot of detail involved with a Modbus protocol implementation.
Integrated circuits, microprocessors and software libraries handle a lot of the details. As
a result, exploration of the finer details is left to Appendix C.
2.4 Modbus 14
2.4.3 RTU, ASCII and TCP
RTU and ASCII are asynchronous protocols that are implemented on serial channels,
generally either EIA/TIA-232 (RS-232) or EIA/TIA-485 (RS-485). They are designed
to be used on a physical bus with the slaves and master connected to the trunk. Both
transfer a start bit as part of the frame. They differ in the way the frames are constructed
and the way data is represented. RTU mode uses binary encoding and does not use
delimiters (headers and trailers). ASCII encodes the data as ASCII characters and does
use delimiters (Modbus Org 2006b). To compensate for the lack of delimiters while in
RTU mode, timing limits between characters and frames are used. A no signal period
of at least 3.5 character times between frames acts like the delimiter in RTU mode. In
ASCII mode frames have a header and trailer. The : character is the delimiter in ASCII
mode (de Sousa & Portugal 2011). Frame composition is considered later.
There are limitations on both serial variants of the protocol. Since the protocol was
conceived in 1979 data types officially supported are limited to those available at the
time (Modbus Org 2006c). It is possible to work around solutions to cater for modern
formats such as using two 16 bit registers to store 32 bit values. There are also no security
features inherent to the protocol.
Modbus TCP is also a direct byte representation protocol (de Sousa & Portugal 2011).
It is not a serial protocol. The Modbus frames are sent through an existing TCP network
and the connections are managed by the TCP protocol. There is a reserved port 502
for requests to establish Modbus TCP connections. Devices can be clients and servers
simultaneously, send multiple requests simultaneously and do not have to wait for replies
(Modbus Org 2006a). Modbus TCP frames only share the function code and data fields
with the other two protocols, with the rest of the frame made up using the Modbus
Application Protocol Header (MBAP) (de Sousa & Portugal 2011, Modbus Org 2006a).
Theoretically the physical layer for Modbus TCP could be anything but is commonly
Ethernet (Rinaldi 2010). From this point onwards, there is no reference to Modbus TCP.
This section was added for completeness only.
2.5 Bridging the Protocols 15
2.5 Bridging the Protocols
Creating bridges or similar devices to link dissimilar protocols is not a new principle.
Several papers have been written that explore the merging of CAN bus and Modbus
(REF). There are also four companies that the writer is aware of that produce existing
devices for this purpose.
2.5.1 Previous Works
A very brief paper by Guohuan, Hao & Wei (2009) identified the spread of fieldbus tech-
nology in many industries and applications as well as the incompatibility of the many
existing standards and protocols. They briefly discuss the two protocols and then de-
velop a design for the protocol conversion interface. The hardware design identifies five
components inside a block diagram; MAX232 as the serial interface, a PIC18F458 as the
microprocessor, two 6N137 optocouplers chips to isolate each bus driver from the proces-
sor, and an MCP2551 for the differential bus driving capabilities for CAN. The software
design is only developed for the case of CAN as a master and Modbus as a slave. The
brief description and a flowchart demonstrate the process at a high level of abstraction.
Wang, Zhang, Li & Ren (2013) studied the design of an adapter for Low-voltage distri-
bution systems in Intelligent Electric Grids. Modbus is identified as the low level control
network protocol of choice in this application. The major issue identified with the adapter
is the dissimilar data sizes between the two protocols. Wang also refers to other studies
that state issues with existing products. They claim that these devices do not properly
take into account the data size problem. They may be able to transmit more than the 8
byte limit imposed by CAN but have issues with frame loss during communication. The
articles referenced were not locatable to confirm the information, however, the frame size
incompatibility is well known to the author. The rest of the paper outlines the selected
hardware as well as the process required for developing the software.
The issue of conversion is addressed by using transparent transmission. When a Modbus
frame is received and needs to be sent over CAN the adapter firsts completes the CRC
check on the Modbus frame and then sends the whole remaining frame as the CAN data.
The receiving CAN node must then parse the non-data fields of the Modbus frame. Wang
claims this method reduces mapping errors when compared to stripping Modbus frames
2.5 Bridging the Protocols 16
down to just the data before being transmitted on the CAN bus.
The second major challenge addressed by software design is the issue of CAN data sizes.
Wang applies techniques from the sub-packaging rule defined in Ethernet to deconstruct
frames at the CAN transmitter and reconstruct at the CAN receiver. The final consid-
eration is the delay in frame sending from the CAN interface. Wang noted that frames
would sometimes be lost when transmitting at high speed. To address the issue a delay
time between sending frames was calculated. This was based on the bit timing of the
CAN bus based upon the selected baud rate along with the bus state, the priority of the
sending node and the delay time of transmission. The authors claimed that the device
was built, tested and met the requirements of the low-voltage distribution system.
The most recent study known to the author focused upon an adaptation layer for Mod-
bus to CAN (Cena, Bertolotti, Hu & Valenzano 2014). The paper discussed how the
traditional Modbus implementations’ speed limitations are potential issues, the introduc-
tion of Modbus-TCP as a potential solution and the idea of layering Modbus on top of
other protocols as another solution. The theme of this paper is different to the others
in that it is not a converter but a variation of Modbus similar to that of Modbus-TCP.
CAN was chosen as it is simple, fast and many microcontrollers have CAN controllers
built in. The adaptation layer has significant differences to the proposed bridge in this
project, however, the issue of large (greater than 8 bytes) Modbus data PDUs requiring
fragmentation and reassembly for transmission on CAN is evident. The solution engaged
to solve the fragmentation-reassembly issue was to change the composition of the CAN
data frames. In the first transmission of a Modbus frame over CAN, 2 bits at the start
of the data field are reserved for identifying the protocol and the length of the Modbus
frame. Subsequent frames in the sequence gain back the two header bits for data since
these fields are constant for any one Modbus message. The CAN CRC field is used in
place of the Modbus CRC field which is parsed from the Modbus frame. While similarities
are identifiable in this paper, the differences between a bridge or protocol converter and
an adaptation layer are significant and much of the rest of Cena is largely inapplicable.
2.5.2 Lessons from Previous Works
There are common identifiable issues and themes within the above works. De-fragmenting
and reconstitution of the Modbus PDUs for transmission over CAN is the major challenge.
2.5 Bridging the Protocols 17
There needs to be a method of reducing Modbus PDUs of up to 252 bytes into 8 bytes
or less size for transmission. The solution posed in (Guohuan et al. 2009) offers no detail
beyond that of a flowchart. Wang et al. (2013) propose sending the whole Modbus without
the CRC field (as CAN has its own comparable field) and then parsing the unrequired
fields at the CAN receiving end. This method is not suitable to this project as there is no
guarantee of control over the other CAN nodes on the network. Similarly, the adaptation
layer proposed by (Cena et al. 2014) require configuration of the receiving CAN nodes
and given the different nature of the protocol bridge and protocol adaptation layers is not
optimal for this project.
Wang’s lesson regarding the mapping errors when simply stripping the data out of the
Modbus frames is noted. The issue may be less pronounced on the buses the bridge will
operate on. Testing may reveal if this is an issue.
There are two basic ways of achieving CAN transmissions using microcontrollers; using a
microcontroller with embedded CAN controller and external CAN transceiver, or using a
microcontroller with external CAN controller and external CAN transceiver. All papers
reviewed suggest the former as the ideal path to take due to ease with implementations and
hardware design. Using optocouplers to isolate the microcontroller from the transmission
devices is also identified as desirable.
2.5.3 Existing Bridges and Available Products
Considering existing products is important. It allows appreciation for what has been
achieved and may also help identify areas for improvement. It is highly unlikely that any
of the products identified in this section would be suitable for the exact use intended for
the network bridge. Ultimately, GDA would like a product developed internally. This
allows for consistency in products and gives the opportunity to expand aspects of the
network bridge into other products or applications if desirable.
Anybus Communicator from HMS
The Anybus Communicator is capable of interfacing CAN and Modbus RTU through
a protocol conversion interface. This device has a configurable setup option for CAN
2.5 Bridging the Protocols 18
messaging that is configured through a graphical user interface (GUI). It supports both
CAN standards 2.0A and 2.0B as well as serial communication standards RS-485 and
RS-232. This product was designed to be used in fieldbus setups involving PLCs. It may
require significant adaptation for it to function correctly in the BMS environment. It can
only function as a Modbus slave. The obvious major drawback is the intended market for
this device. It was designed for fieldbus use it may not interface as desired with BMSs
expected for the network bridge (HMS 2015). In terms of general functionality the only
significant improvement would be to add Modbus master capabilities.
CAN/Modbus Converters from ADF Web
ADF web offers several products in this category. There are Modbus TCP solutions
that will not be considered and four different Modbus serial offerings. Electronically
there are two variants; one is a Modbus master and the other is Modbus slave. The
other two products are the same devices with extra galvanic isolation and a different
enclosure. Each device has RS-232 and RS-485 connection and one CAN port. They
support data rates on the CAN side up to the limit (1Mbps) and on the Modbus side up
to the limit (115kbps) from the official standard. The devices are fully two directional
messaging capable. Each device is only capable of being either a Modbus master or slave
and not both (ADF web 2015). This may not be suitable for this task. Further, to use
these devices requires the use of Windows based propriety software from ADF web called
Compositor SW67011. The biggest improvement would be to have the configuration built
into the device to remove the need for external software. Providing an interface to the
device that allows on the fly configuration is consistent with practices at GDA. More
flexibility with regards to Modbus configuration would also be desirable.
Modbus RTU to CAN converter from ICP DAS
This device is another protocol converter that supports CAN to Modbus RTU data trans-
fer in both directions. It supports RS-485, RS-232 and RS-422 serial communication stan-
dards. One of its applications listed is building automation so it is likely useful in this
task. It is configurable using proprietary software for the device. The device only sup-
ports Modbus RTU as a master and not as a slave. It does not support Modbus ASCII.
The configuration requires software and cannot be done by interfacing with the device
2.5 Bridging the Protocols 19
directly (ICP DAS USA 2015). To be useful in this task, this device would ideally need
support for Modbus ASCII and the ability to configure as a Modbus slave. Configuration
would be better achieved with an interface on the device itself.
There are several products all of which have their own strengths and weaknesses. None
of these products are suitable for this exact project, but they do provide some proof of
concept for the objectives outlined. Further, each device has limitations and this provides
opportunities for the network bridge.
2.6 Constraints 20
2.6 Constraints
As a sponsored project the network bridge design must be carried out within the con-
straints of the host organisation and within their requirements. Below is a description of
those constraints and requirements.
As a potential commercial product, the bridge must be financially viable. When selecting
components for use in the bridge they must be approved by GDA from a cost perspec-
tive. All components in this project have successfully passed through this process. If a
component to be specified is similar to one used on another existing GDA product, it
may be used on the network bridge to help reduce stocking costs and make use of existing
expertise within the organisation.
The development environment used in this project was chosen as it is the current envi-
ronment employed by GDA. This includes the development board, microprocessor, pro-
gramming language and compiler. Finally, GDA’s general design guidelines were followed
regarding component choice and software design methodology where possible.
There is also a design considerations to be stated. Modbus frames can theoretically
contain data up to 508 bytes in length. In the specific application of the bridge within
GDA, this is unlikely to be the case. Discussions with GDA engineers suggest it is
reasonable to assume that data requirements will not exceed 16 bytes.
2.7 Chapter Summary
This chapter was about the fundamental concepts and considerations for the design of the
network bridge. It contains some fundamental information about the CAN and Modbus
protocols. It also explored previous work that had been carried out in this area including
the investigation of several existing commercial products. Finally, constraint set out as a
consequence of undertaking a sponsored project were considered.
Chapter 3
Design Methodology
3.1 Chapter Overview 22
3.1 Chapter Overview
The basic principle is to keep it as simple as possible whilst meeting the requirements
previously outlined. Hardware design is more restrictive as it is not as simple to create
basic design to build on. The final hardware design must be of commercial quality.
Therefore the design of the hardware will be conducted with the aim of producing one
finished product which can then be produced as a printed circuit board (PCB).
The hardware design methodology involves smaller increments leading to a complete
design. Each logical section, such as the Modbus interface, is broken down and designed
separately. Existing library functions will be used from the chosen compiler to prove
concepts where possible. Only once all concepts are proven will more advanced techniques
be use to refine the design.
Software design will be performed logically first, and then in code.
3.2 Equipment 23
3.2 Equipment
The following is a run-down of the equipment used during this project. This list is not
exhaustive but highlights the key tools used.
As previously mentioned the development environment used was consistent with GDA
practices. The development board used was an EasyPIC Pro v7 from MikroElektron-
ika. A PIC 18F87K22 microprocessor was used in development and in final design as
discussed later. The EasyPIC Pro board supports UART over universal serial bus (USB)
natively and this was used for serial communications. A 3.3V CANSpi click board was
used in conjunction with the development board to provide the CAN interface. During
testing, two 5V CANSpi modules were also used. To view activity on the buses, a UNIT
UTD2102CEL 100MHz digital storage oscilloscope was used.
Windows 7 based personal computers (PC) were used to run the development environment
and simulation software for Modbus and CAN. USB cables were used to connect the USB
UART module of the development board to the PC. During initial testing, the two 5V
CANSpi modules were used. Later on a USB-CAN Converter from ICP-DAS, Inc was
used to simulate a CAN node. This was done so that testing was not performed on
two devices created during the project. Using external devices that are rated as per
the communication standards validates testing results. The converter translates CAN
messages to USB so they may be interacted with via PC. 15cm male-male breadboarding
wires were used as the CAN transmission lines. Short wires were used to avoid reflections
and other physical effects on the line.
The software package used to complete software as MikroC Pro for PIC. Tha programming
language used was ’C’. The terminal function of MikroC Pro was used for initial serial
communications testing as well as troubleshooting. To simulate a Modbus slave, the
freely available software program ’Modbus Slave’ was used. This program is free for a
trial period of 30 days. This program uses COM ports to access the UART over USB.
The USB-CAN converter shipped with basic software that allows sending and receiving
of CAN messages and was used in this project.
3.3 Hardware Design 24
3.3 Hardware Design
Some of the traditional design choices are forgone here for the benefits of using tried and
tested equipment already available at GDA. Technical functionality is the key requirement
and should be observed first. Where possible, components used in existing GDA products
may be used if they meet the specification and it provides benefit to GDA through reduced
stocking costs or product familiarity. This is true regardless of whether the component
selected is not the ideal selection based on other criteria. As a general rule, where two
or more components meet all the requirements laid out, the cheapest component shall be
selected.
The other major design consideration is alignment with the software development environ-
ment. The circuitry found on the EasyPic Pro and add-on boards has proven functionality.
It makes sense to utilise these circuits as a template for two reasons; they are proven to
work and take away much of the risk of trying new methods, and they make the transfer
of software from the development environment to the final product much simpler. Minor
changes to microprocessor pin configurations will be required1.
Data-sheets for all devices mentioned by name in this section can be found in appendix G.
3.3.1 Microprocessor
The microprocessor is the central cog in the design. It affects the choice of all other
components. Selection of the device was largely driven by GDA. The desire was to use a
processor already deployed in other products and suitable for future commercial products.
GDA favours the PIC range of processors from MikroElektronika. The device still needed
to conform to the following requirements:
1. Ability to process CAN messages at data rates up to 1 Mbits per second and serial
messages up to 19.2 kbits per second.
2. Sufficient memory to buffer communications data and serve other functionalities
defined in ancillary circuitry later in the chapter.
3. Sufficient pins to service all functions of the bridge.
1This is due to the predefined pin configuration of the development board.
3.3 Hardware Design 25
4. Be available to use on the intended development equipment and with the selected
compiler and design environment.
Items one and two are critical in that they will affect the performance of the bridge’s
main functions. Item four is required so that the software design will integrate with
the hardware design correctly. Selectable PIC processors for this task far exceed the
requirements of item one. Below is a conservative calculation of the required memory
space:
Let’s assume that we need to buffer at any one time ten Modbus messages and ten CAN
messages. The non-data portions of the CAN frames will be filtered by the hardware for
us. We may need to buffer the entire Modbus frames. CAN frame requirements would
be:
Memcan = 8bytes× 10 = 80bytes (3.1)
This is fairly insignificant. Now we consider the modbus requirements. From figure 2.4,
we see a the maximum size of a complete Modbus ASCII frame is 513 bytes. So:
Memasc = 513bytes× 10 = 5, 130bytes (3.2)
We need at least 5.2 kbytes of memory for buffering alone using this conservative approach.
The microprocessor selected was a PIC 18F87K22 which operates up to 64MHz, supports
up to 128k bytes program memory, has 80 pins and is a supported chip on the selected
development board. The processor is to be operated at 5 volts.
3.3.2 CAN Interface
Using a PIC processor as the central processor for the network bridge gives two clear
options for implementing the CAN interface; select a PIC processor with an in-built CAN
module or select a PIC processor with an SPI module and utilise an external CAN-SPI
integrated circuit to allow the processor and CAN transceiver to communicate. The
process of selecting the CAN interface logically relies upon the selection of the processor.
3.3 Hardware Design 26
In order to make the individual modules of the network bridge more portable, it was
decided to use an external CAN device. The transceiver chip selected needed to support
the full ISO standards (usually referred to as CAN 2.0A and 2.0B in datasheets). It also
has to operate on the same supply voltage as the processor. In total, two CAN devices
are required; a CAN-SPI conversion integrate circuit (IC) and a CAN transceiver IC.
The devices selected were the MCP2515 and MCP2551 from Microchip. The SPI module
of the processor was used to communicate with the MCP2551 transceiver via the MCP2515
chip. Supporting circuitry was selected using the 3.3V CANSpi click board as a guide.
3.3.3 Serial Interface
To enable Modbus communication the bridge requires a serial interface. The physical
layer chosen for this project was RS-4852. This implementation required a transceiver to
convert signals from the processor to the correct levels for transmission on the serial bus.
The devices selected were DS485M from Texas Instruments. This is a product that had
been used on a previous GDA product. Supporting circuitry was selected using the RS485
Click board from MikroElektronika as a guide.
3.3.4 Power Supply
There is no guarantee of the supply voltage from the Building Management System.
GDA’s experience suggests that a 24V AC, 24V DC or lower voltage supply is likely.
Dealing with AC and assuming that the 24V AC supply occasionally spikes at 30V RMS.
The equation for the max voltage the power circuitry needs to with stand is:
Vmax = 30V ∗
√
2 = 42.43V (3.3)
The bridge’s functional circuitry is mostly digital so the supply requires rectification if
the source is AC. A bridge rectifier diode IC was selected to perform this task. The device
2UART is used for the software development stage and the final solution can be modified to make use
of RS-485.
3.3 Hardware Design 27
chosen was the DF04S, which accepts input bridge voltages up to 280V and an average
rectified forward current of 1.5A.
The next stage of the power supply design in the switching regulator. A linear power
supply was not considered. A 5V linear regulator would use too much power and generate
excessive heat considering the supply voltage could be as high as 24V. The regulator IC
chosen was the LM2671 from Texas Instruments. This device can tolerate input voltages
up to 45V, can supply 5V in a fixed output configuration and operates at 96% efficiency.
The final power consideration was analogue supply. The touch panel feedback is an
analogue signal connected to the processor. The analogue supply pin of the processor was
connected. Low pass filtering components were added to reduce high frequency noise on
the signals.
3.3.5 Isolation
Communication transmission lines from external sources could be the source of voltage
or current spikes. It is therefore important to isolate the communication interfaces from
the rest of the board circuitry for protection. In order to achieve this it was necessary to
isolate power supplies for those interfaces as well.
Isolation of the CAN interface was achieved by placing optical isolation ICs between the
MCP2515 CAN-SPI chip and the MCP2551 transceiver chip. Similarly, isolation of the
Modbus interfaces was achieved by placing optical isolation ICs between the processor
and the DS485M transceiver chip. The isolation ICs used were HCPL-2601S.
Optically isolated DC-DC regulators were used to isolate the power supplies for the com-
munications on the board. They take the supply 5V and isolate it for CAN and Modbus
to create separate power supplies. The isolated DC-DC converters ICs used were ROE-
0505S.
3.3.6 Ancillary Circuitry
In the event of a power failure that is localised to the area containing the bridge, a battery
backup system was added to allow the bridge to communicate the failure. The battery
3.3 Hardware Design 28
was designed to take over the supply of power when the standard supply dropped below a
certain level. A test point was added and connected to a processor pin for determination
of this level. This allows the bridge to self diagnose a power fault back to the BMS so
that it may be attended to. A battery test point was also added to provide battery level
feedback.
Five LEDs were included in the design for use as indicators. A power LED is lit when
the bridge power supply is active. There are two LEDs for Modbus communications; one
for transmission and one for reception. They are intended to illuminate when the RS-485
transceiver is operating. Similarly, the CAN communication has one LED indicating bus
activity3. The final LED is for error reporting. With the exception of the power LED, all
LEDs are connected to the processor and their operation is to be configured in software.
The bridge design includes a Graphical Liquid Crystal Display (GLCD) and touch screen
combination for use as a human-machine interface. The design used is adapted directly
from the EasyPic Pro v7 development board but is arranged on different pins. To specify
the limiting resistor for the supply voltage, the development board current was measured
using a multi-meter. The value of the resistor used on the bridge was adjusted to reflect
the 6V supply.
The operation of these devices are to be configured in software.
Numerous capacitors were used in the design of the bridge. Many were selected by
following recommendations from chip manufactures for use with ICs or the processor
such as decoupling capacitors. Some were also included due to the potential for long
track lengths on the PCB and the high frequencies encountered. Much of this part of
the design was carried out under guidance from GDA engineers rather than driven by
research carried out by the writer.
3One LED is sufficient since CAN is a differential system where both lines are used for transmission
and receival.
3.3 Hardware Design 29
3.3.7 Printed Circtuit Board
PCB arrangement was focussed on having the functionalities of the board in separate
areas. This was compounded by the use of isolation. Two layers were used; top and
bottom. The processor was located centrally and its decoupling capacitors and crystal
nearby. The power supply was placed at the bottom of the board. The CAN interface
and its isolated power supply were located to one side of the board. Likewise with the
Modbus circuitry to the other side. The communication headers were placed opposite
each other for aesthetics. Keep-out sections were placed around each of the communica-
tions interfaces containing the isolated components. Thick tracks were run through the
middle of the board for high current transfer. Three main ground planes were placed; a
standard ground plane and separate isolated ground planes for each of the communication
interfaces. Two smaller ground planes were also placed around each of the oscillators.
The GLCD was placed on the top layer as it is intended to be embedded in the lid of the
encapsulation. The LEDs are also located on the top layer. All headers and the contrast
potentiometer for the GLCD were located on the bottom layer since it is the accessible
side of the board post installation4.
Ideally all tracks would have been placed manually but time restraints did not allow this.
Some of the important track laying was carried out by hand but some use of Altium’s
auto-route feature were utilised.
4Assuming that the bridge is mounted as currently planned. GDA will be responsible for this.
3.4 Software Design 30
3.4 Software Design
The key software design principle is modularity. Ideally, GDA will be able to use separate
modules of this bridge in other projects. Where feasible, code was written in separate ’C’
files and combined using a header file inside a project. The design of the software was
approached on two levels; an overview of the whole bridge functionality illustrated using
data flows and then by considering the protocol implementations.
Logically, the bridge is both a CAN node and a Modbus ASCII master. CAN message
handling and Modbus message handling are established separately first. Interrupt sources
were to be used to receive messages and forward the data out of the other interface.
To visualise the process and also to aid development, a data flow diagrams (DFD) was
created to show the bridge operation. The figure can be found in chapter 4.
3.4.1 CAN Interface
MikroC Pro comes with a CANSpi library containing a suite of functions for the ini-
tialisation and operation of a CANSpi module attached to a PIC processor. The initial
design idea was to use an SPI interrupt to start the processing of a CAN message using
the library functions. CAN reception and transmission would be handled inside interrupt
routines. During testing this was found not to be possible and will be discussed in the
relevant chapter. A minor change was required. The interrupt routines were configured
to set flags that were processed in the main loop. Again during testing this was proven
ineffective for the CAN communications. Eventually the entire CAN functionality was
moved to the main function of the project. All initialisation and message handling was
processed there. For proof of concept, arbitrary configurations were used on the bridge.
Testing of the CAN interface was undertaken using the USB-CAN converter.
3.4.2 Modbus Interface
Modbus functionality had to be added to the bridge from scratch. Some existing Modbus
RTU code was available from GDA as a guide. During development, all serial commu-
nications were performed using the UART. The MikroC software includes a library for
3.4 Software Design 31
RS-485 which is overlaid onto the UART. The bridge was designed using UART and the
RS-485 implementation would only occur on the finished bridge (PCB).
The bridge is not a typical Modbus master. The logic for operation is not configured on
the bridge itself. This would be performed on the BMS CAN node. The bridge needs
only to communicate with a Modbus slave and report errors such as time-out and is not
required to poll directly. Facilitation of the communications was divided into five key
functions:
1. Serial Transmit
2. Modbus Transmit
3. Serial Receive
4. Modbus Receive
5. Longitudinal Redundancy Check (LRC)
The serial functions were developed first. To test their functionality the terminal window
in MikroC was used to send and receive UART communications. Once the serial functions
worked as desired, the Modbus functionality was created. Transmission was achieved first
by creating a function that took the data and encased it in a Modbus frame. Then the
Modbus receive functionality was created by coding a reversing of that process. Initially,
both were tested using the terminal. The LRC was the last function created as it required
working send and receive functions. Hand calculations were performed on messages sent
to ensure that the LRC was accurate.
3.4.3 Ancillary Functions
This section is devoted to the functionality not strictly related to one protocol or the
other. These are functions which support the translation between the two. CAN data
is treated as numeric but Modbus ASCII encodes as ASCII. An ASCII to Hex and Hex
to ASCII set of functions were created to allow the transition between the two encoding
schemes. A simple example follows:
Consider the hexadecimal number 0x2D. To send this as Modbus ASCII the bridge needs
3.4 Software Design 32
to convert each character into two characters, ’2’ and ’D’. ’2’ will be encoded as 0x32 and
’D’ will be encoded as 0x44. These values are taken from the ASCII table.
Functions were created to automate this process as well as its inverse. In order to separate
two digit hexadecimal numbers into a pair of single digit hexadecimal numbers, two
functions were written.
The literature shows the incompatibility in data sizes between the two protocols. A
method was required to successfully decompose and reconstitute Modbus frames with
data lengths of greater than 8 bytes into two or more CAN frames. Due to reasons
discussed in later sections, this was not implemented. The designed principle for this is
discussed in the next chapter.
3.4.4 Main
The original design of the main function was to initialise the communications modules
and provide GLCD functionality and LED indications. During the design it was noted
that the interrupt implementation of CAN proposed would not work. Interrupt flag
setting was implemented and this requires the response to them in main code. Code was
implemented to check the status of flags and respond with appropriate communication
operations. While the extended functionalities of the bridge such as the GLCD and LEDs
were designed for in hardware, their implementation in software falls out of the scope of
this project. Inclusion in hardware was given to allow this design to be built on in future.
3.5 Proposed Testing Methodology 33
3.5 Proposed Testing Methodology
The bridge’s functionality needs to be verified. A testing procedure was developed with
the aim of determining the capabilities of the bridge, its limitations and where it can be
improved.
This section is an outline of the intended testing procedure.
To be satisfied that the CAN and Modbus functionalities work as desired they must be
able to communicate with devices that conform with their standards. A series of tests
were designed to assess the performance of the bridge. All CAN related testing will be
conducted using the USB-CAN converter to simulate the BMS CAN node. Modbusslave
will be used to simulate the Modbus ASCII slave. The first test is to verify the concept.
The bridge should:
1. Receive a CAN frame
2. Extract the data
3. Put the data in a Modbus frame and send it
4. Receive a Modbus frame back and extract the new data
5. Put the new data into a CAN frame and send it back to the originating CAN node.
The device needs to successfully complete this test as the first stage. The parameters of
each protocol such as speed, filters, flags etcetera can be selected arbitrarily. The test
should be performed separately using the 11bit and the 29bit CAN identifiers to ensure
compliance with both standards (2.0A and 2.0B).
After successful completion of the first test the bridge should use the same testing proce-
dure to confirm that the bridge operates fully over the range of possible communication
speeds. This means up to 1Mbit on the CAN side and 19.2kbit on the Modbus side. Each
extreme from both protocols should be tested with each other, i.e. max CAN speed with
minimum Modbus speed etc. These tests will confirm whether the bridge can function
over the baud ranges given in the protocol standards.
The next suite of tests determine the performance of the bridge over that range. These
are to be facilitated using stress tests on the bridge. An amount of frames will be sent
3.5 Proposed Testing Methodology 34
from the USB-CAN converter dependant on the BMS messaging rate. The faster the rate,
the more messages that will be sent. A count of the number of frames that the BMS CAN
nodes send and receive will be kept. The success ratio is the number of frames received
divided by the number of frames sent. These results should be tabulated as percentages
and graphed for analysis.
Testing should be performed at differing baud rates to determine how the bridge performs
over the range of specified operation speeds. Four sets of parameters are to be used:
1. Maximum CAN baud and maximum Modbus baud
2. Minimum CAN baud and minimum Modbus baud;
3. Maximum CAN baud and minimum Modbus baud;
4. Minimum CAN baud and maximum Modbus baud
Performing the testing at the extremes will allow the performance of the bridge to be
specifiable within the boundary of those results.
3.5.1 RS485 Confirmation
There was no RS-485 enabled Modbus ASCII slave device to test with during the project.
The hardware design was adapted from the 3.3V RS-485 Click board from MikroElek-
tronika (MikroeElektronika 2012b). In order to prove the hardware concept of the serial
interface, testing was carried out using a RS-485 click board and an oscilloscope. The
RS-485 was connected to a bread board and terminated using a 120 ohm resistor. A
successful test would be achieved by the observation of an RS-485 master packet on the
bus. A photograph of the testing set-up with the bread board, terminating resistor and
oscilloscope can be found in appendix F.
3.5.2 Physical Cable Testing
In an attempt to rule out physical level issues, testing was carried out with the CAN
interface and different transmission lines. The majority of testing was completed using
fifteen centimetre male-male breadboarding wires. Tests were done using one meter and
3.6 Chapter Summary 35
ten meter lengths of twisted pair (as per the CAN physical specification). Measurements
were taken with an oscilloscope. If transmission lines were the cause of CAN transmission
errors, these tests would show evidence of abnormal signal levels. This may include
overshoot, jitter, ringing etcetera.
3.6 Chapter Summary
This chapter covered all aspects of the methodology. This included the key equipment
used, the hardware and software design approaches as well as the proposed testing meth-
ods.
Chapter 4
Design of the Network Bridge
4.1 Chapter Overview 37
4.1 Chapter Overview
This chapter details the hardware and software design elements of the network bridge. It
is worth re-iterating that several hardware components included in the design do not have
accompanying software elements. The bridge is to be expanded and developed further as
a commercial product and this requires a complete hardware base. Figure 4.1 shows the
overall logical design of the bridge. It is to operate as a CAN node and Modbus ASCII
master simultaneously.
Figure 4.1: Network Bridge Logical Overview
4.2 Hardware Design 38
4.2 Hardware Design
The hardware design process had two distinct phases; the schematic design and the PCB
layout. Each functional subsection of the bridge is detailed using focussed versions of
the schematic found in appendix E. This design will consider the major components of
the design and will not focus on simpler features such as current limiting resistors or
decoupling capacitors.
The final section will include the PCB layout of the bridge and justify the positioning
of components on the board. All ICs included in this design have selected extracts from
their data-sheets located in appendix G.
4.2.1 Microprocessor
The oscillator chosen is a 14.7456MHz crystal. The rationale for this selection was to use
a crystal with a frequency wholly divisible by 9600. This allows the UART to generate
the required bauds without error. Using crystals with non-divisible frequencies can cause
issues that will be discussed in a later chapter. The timing of the CAN-SPI interface is
set by the crystal connected to the MCP2515 IC and is not affected by this selection.
The programming header P2 is connected to SPI pins on the PIC to allow programming.
The MCLR pin is arranged with resistors R2, R1 and capacitor C35 to give a time constant
matched to the start-up time of the processor.
The processor data-sheet recommends 100nF capacitors for decoupling between the pos-
itive voltage pins and their associated grounded pins. Additional 10uF capacitors were
also included due to the high power requirements of the optical isolation employed on the
bridge. The value used was recommended by the GDA engineers.
4.2.2 CAN Interface
The MCP2515 IC is interfaced to the SPI1 pins of the processor. The reset and chip select
(CS) pins are connected to pins on port B of the processor and must be configured in
software. The oscillator used is a 10MHz crystal as recommended on the MCP2515 data-
sheet. The two data pins, RX and TX are connected to the MCP2551 CAN transceiver
4.2 Hardware Design 39
via the HCPI-2601S optical isolators. The isolated supply voltage and ground can also be
observed. This will be discussed in a later section. The header P4 is for connection of the
transmission lines. They are labelled CAN high and low and should only be connected as
such. The CAN interface is shown in figure 4.2.
Figure 4.2: CAN Communications Hardware Interface
4.2.3 Serial Interface
Figure 4.3: Serial Communications Hardware Interface
The RS-485 interface is shown in figure 4.3. There are 3 pins from the DS485M that
4.2 Hardware Design 40
communicate with the processor through the HCPI-2601S optical isolation chips. These
are the transmit enable pin and the two data pins (receive [RO] and transmit [DE]). The
receive enable pin is held low (on) via R19, a 390 ohm resistor. The intent is to use this
as a troubleshooting feature for transmission as the internal circuity of the DS485M will
mean transmitted messages will echo on the reception input. The jumpers J2 and J3
can be used to stop the transmission lines floating, which can create noise on the bus1.
Jumper J4 is used to enable a termination resistor when the bridge will be acting as the
first or last node on the bus. The header P3 is the transmission line connection for the
RS-485 bus.
4.2.4 Power Supply
Power to the bridge is supplied into P1. The bridge expects up to 24V that could be DC
or AC. Rectification is provided by the DF04S bridge rectifier. The rectified voltage is
passed to the LM2671 switching regulator. This device is configured to produce 6V. This
will allow the expected 1V drop across the diodes D4-D6 to produce 5V. All components
selected were specified using the data-sheet as a guide.
Figure 4.4: Power Supply Hardware
The processor is supplied from net VMI (the cathode end of D5 and D6). The commu-
nications interfaces are supplied from the output side of the voltage regulator U3. This
device has a rated drop-out of 40mV at 250mA essentially making the output voltage the
same as the input. The enable pin is connected to pin 27 on the processor. The rationale
is that this gives control of the power supply to the non-processor components of the
bridge to the processor. During a power outage, non-critical components can be disabled
and the processor put in sleep mode to prolong the life of the battery. The advantage of
1The calculation for this resistor value in the datasheet recommends a lower value than used. The
RS485 Click for MikroElectronica and a previous GDA device with a RS-485 interface use the value here.
4.2 Hardware Design 41
this strategy is that the processor will not require a reset and allows a diagnostic message
to be sent from the bridge to the BMS informing of a power outage. The diodes D3, D4,
D5 and D6 are required to prevent current draw into the regulator U2 or charging of the
battery.
The analogue supply is required for operation of the touch panel. The inductor L2 is for
low pass filtering of the analogue supply.
The isolated DC-DC converters U4 and U5 are for the CAN and Modbus isolated power
supplies.
4.2.5 Isolation
There are two isolation approaches present; the power isolation and the data isolation.
The data isolation refers to the HCP1-2601S optical isolators between the CAN and RS-
485 transceivers and the MCP2515 IC or processor respectively. These devices protect
the data lines of the communications interfaces. The isolated supplies provide power to
the communication circuitry on the outside edge side of the optical isolators.
4.2.6 Ancillary Circuitry
LED D11 is used to indicate power to the bridge. D7 is an indicator of serial reception.
D8 is an indicator of serial transmission. D9 indicates when there is activity on the CAN
bus. D10 is designed for use in fault indication. All LEDs bar D11 are software configured.
The communication indicator diodes are to be powered when the relevant activity occurs
on the buses. D10 is flexible and may be configured to meet user needs.
Figure 4.5: Indication LEDs
4.2 Hardware Design 42
The GLCD and touch panel combination were used during design and testing. The imple-
mentation used for the bridge is a near replica of the circuitry found on the development
board. Component R25 has been adjusted to account for the change in input voltage.
The calculations are below:
A 1.4V drop was measured across the resistor. Its value was 20ohms so
Ires = 1.4V/20Ω = 7mA (4.1)
The voltage drop will change as a result of the great supply voltage (6V) on the bridge
giving a drop of
Vnew = 1.4 + 1 = 2.4V (4.2)
Now we can see the new value of resistance required to maintain a current similar to the
original
Rnew = 2.4V/0.07A = 34.29Ω (4.3)
The next highest E12 series is selected at 39 Ohms. This is resistor R25.
4.2.7 Printed Circuit Board
The final PCB top and bottom layer layouts are found in appendix D. Appendix D
also contains 3D visualisations of the PCB. Both the top and bottom layer have been
utilised for ease of placement and aesthetics. Simple placement rules have been observed.
The layout is broken up into functional elements; power supply, CAN interface, Modbus
interface and the processor. The two communication interfaces are placed on either side of
the board. Both of these sections are optically isolated, have their own ground planes and
are bounded by keep-out sections. The power supply circuitry is located on the bottom
of the board. Isolated power is kept to the edges of the board and away from non-isolated
power. The processor is located centrally. Both crystal oscillators have ground planes
surrounding them for shielding. The inductor L1 was placed safely away from the feedback
of the regulator. Decoupling capacitors were placed near their respective ICs.
The processor was aligned so that the relevant pins for communications are easily ac-
cessible for the relevant communications interface. Communication headers are aligned
for aesthetics. LEDs for the communications are located on the same side of the board
as the interface. All circuitry that needs to be accessible by a technician is located on
4.2 Hardware Design 43
the bottom layer. The intention is to place the PCB in an ingress protection (IP) rated
enclosure with the GLCD and LEDs embedded in the lid and sealed. As such, only the
bottom layer of the PCB will be normally accessible. The design of this enclosure is not
within the scope of the project but was a design consideration.
4.3 Software Design 44
4.3 Software Design
This section details the code written for the network bridge. All code referred to here can
be located in appendix D. The modular approach to this software requires a header to tie
the code together. The header file ProjectDevBoard contains the function prototypes for
the project.
The first element of the design is the data flow diagram. The DFD shown in figure 4.6 is
the ideal DFD in that it assumes that serial peripheral interface (SPI) interrupts function
correctly. The tested bridge does not have this functionality and it is replaced with a
flag check within a continuous loop. The other processes, data stores and flows are not
affected by this change.
Figure 4.6: Bridge Data Flow Diagram
4.3 Software Design 45
Modbus functionality is confined to the C file ’Modbus’. There are several variables within
the global scope of the Modbus C file. The most important being the send and receive
buffers and frame length storage. There are six modbus functions:
1. modbus init - Initialisation of the Modbus interface.
2. TX serial - Transmission of serial data.
3. TX modbus - Creation of Modbus transmission frames.
4. RX serial - Reception of serial data.
5. RX modbus - Checking of LRC from serial receptions and data extraction.
6. LRC - Calculates the longitudinal redundancy check of a frame.
The initialisation function sets up the UART with the correct parameters for Modbus
communications. This includes the baud rate, synchronisation (asynchronous for Modbus)
and number of data bits2.
The serial transmission function should only be called after the Modbus transmission
function to ensure data integrity. As a result, the only function call is located inside the
Modbus transmit function. It receives the size of the data to send as an argument. The
send frame is put into the serial transmit register TXREG1, byte by byte until the full
frame is sent.
The Modbus transmission function receives a buffer of data and the buffer length as
arguments. An ASCII colon (hexadecimal 0x3A) is placed in position zero of the global
send frame. The contents of the argument data frame are then copied to the global send
frame. The LRC function is called and the result stored. Since the LRC will be a two byte
result it has to be split into two ASCII characters. This is performed by the functions
split first and split second. These two characters and the new line characters (ASCII
CR and LF) are appended to the end of the global send frame. The function then calls
TX serial to send the Modbus frame.
2Note that parity checking was not implemented due to reasons discussed later. However, instead of
the 7 data bits with a parity check required by the standard, 8 data bits with no parity was used since
the 8th bit is always 0 due to the hexadecimal value of the ASCII characters used.
4.3 Software Design 46
The first step in the serial reception function is to read the current byte off the UART. If
a colon has previously been received the variable named Go will be in set mode (equal to
one) and the function will extract the contents of the UART until the line feed character
is received. If Go is not set (equal to zero) and a colon is received, Go will be set and the
reception process can continue. Any other characters received in this circumstance will
be ignored. A count of the number of bytes in the received Modbus frame is maintained
for use in the RX modbus function.
The Modbus receive function copies the serial frame into a holding array ignoring the
colon character. The LRC of the received message is then checked and if correct, the data
only portion of the frame is placed back in the reception array3.
CAN functionality was entirely produced from the CANSpi library within the MikroC
environment. All CANSpi functions were called directly from the main program, Pro-
jectDevBoard. CAN flags for initialisation, sending and receiving are all cleared before
being set using predefined bitwise arguments. The CANspi interface is then initialised
and configured using the flag, mask and filter combinations. A brief description of the
operation of masks and filters can be found in appendix B. The module is then set in
operation mode where the two functions CANSPIWrite and CANSPIRead can be used to
send and receive CAN frames respectively. The interrupt service routine for the UART
reception is also found in the main program. It simply checks for the correct flag, calls
the serial reception function, sets a flag for the main loop and clears the interrupt flag.
The other functions written for this project include the ancillary functions for hexadecimal
to and from ASCII conversions. hex ascii and ascii hex makes use of the sequential order-
ing of ASCII characters for conversion between formats. The split first and split second
functions makes use of simple bitwise operations to extract the first four or second four
bits of a byte. This is used to take a two character byte and convert it into two, one
character bytes as required when converting to a Modbus ASCII frame. The comb digits
functions performs the inverse of this. This is used when converting Modbus ASCII frames
back to standard data to be sent on the CAN bus.
The last significant design component is the decomposition and reconstitution of multiple
CAN frames. For the scope of this project it was previously deemed unnecessary since
3The size of array is passed as an argument and as such the calling function will know the size of the
data frame.
4.4 Chapter Summary 47
Modbus data was unlikely to exceed 16 bytes. The design is included for completeness.
CAN data frames only have room for 8 bytes of data and Modbus ASCII could potentially
contain 504 bytes of data4. The Modbus data is ASCII encoded. Eight bytes of data can
only carry 4 bytes of information since a byte requires two characters. We only need
more than one CAN frame if the data size is greater than 16 bytes. To account for this
eventuality, the first data byte will carry information that determines the amount of data
related to the current frame. If the data to be received is less than or equal to 14 bytes,
the first byte is zero. If there is more data to follow the first byte is marked 0xFF. On
every subsequent frame the process is repeated until all data is sent and the first byte of
a CAN frame is zero.
4.4 Chapter Summary
This chapter detailed the hardware and software design of the bridge. A logical overview
was presented. Hardware components were specified and justified. The software design
was presented as data flows first, then as descriptions of code.
4While this is possible it is not anticipated in the intended application of the bridge. There may be a
need to send more than one CAN frame worth of data.
Chapter 5
Results and Discussion
5.1 Results 49
5.1 Results
The intention was to assess the bridge performance as outlined in the testing methodol-
ogy. Due to time constraints and GDA ordering cycles, a finished PCB was not attainable
during the project span, therefore, the tests were undertaken using a development board.
As the design of the PCB is consistent with the hardware components used on the de-
velopment board test platform1, it is reasonable to assume that the PCB would perform
similarly.
Given no RS-485 enabled Modbus ASCII devices were accessible for testing, UART over
USB was used to give access to PC based simulation software as an alternative2.
As a result of the testing set-up described, separate verification of the RS-485 functionality
of the PCB was required.
5.1.1 Proof of bridge concept
As stated in the methodology, the first test is to verify the concept of the bridge by
1. Receiving a CAN frame
2. Extracting the data
3. Placing the data in a Modbus frame and sending it to the slave
4. Receiving the Modbus slaves response frame and extracting the new data
5. Placing the new data into a CAN frame and sending it back to the originating CAN
node.
Figure 5.1 demonstrates the bridge concept by successfully completing all of the above
steps. In the figure, the movement of data is easily traceable between the CAN and
Modbus interfaces. Frames are being sent from the BMS simulating CAN node (right
window, top view) to the bridge, which in turn sends the data (01 02 03) on to the
Modbus slave. This is viewed as an ’RX’ line on the Modbus serial traffic viewer (left
1The test platform refers to the development board and CANSpi click board.
2This is Modbusslave program.
5.1 Results 50
window). The ’TX’ in the same window is the slave response with data ’00 00 08 00 00
01’ in ASCII format. The bridge then extracts this data from the Modbus frame and
sends it on the CAN bus to the BMS simulating CAN node (right window, bottom view).
It is important to note that the data returned by the Modbus slave simulator is not a
valid response to the transmitted frame. The simulator sends the same response to any
transmitted message.
Figure 5.1: Proof of bridge concept - complete transmission
5.1 Results 51
Table 5.1: Results for frame bridge frame loss - CAN baud 125kbps and Modbus baud 9.6kbps
CAN message rate (ms) Frames Sent Frames Received Success % Loss %
1000 100 100 100% 0%
750 100 100 100% 0%
500 100 100 100% 0%
250 200 200 100% 0%
200 400 379 95% 5%
150 400 285 71% 29%
125 400 238 60% 40%
100 400 191 48% 52%
50 800 191 24% 76%
25 800 96 12% 88%
10 1600 77 5% 95%
5.1.2 Bridge stress testing
Table 5.1 contains the results for stress testing of the bridge. It shows the percentage of
successful transmission and frame loss at different CAN messaging rates. CAN messaging
rates is the amount of time between CAN frame transmission from the BMS. In the
testing, the BMS is simulated using the USB-CAN converter.
Figure 5.2 is a graphical representation of the tabulated data above. What is evident
is that the bridge will successfully maintain 100% frame transmission when the CAN
messaging rate is slower than approximately 220ms at CAN baud 125kbps and Modbus
baud 9.6kbps. This leads to the conclusion that it takes the bridge about 220ms to
process a complete message transaction. The loss is linear, and proportional to the CAN
messaging rate. For example, when the messaging rate is 10ms, for every 77 frames we
receive, over 1500 frames are lost. This is a roughly 1:20 ratio consistent with the linear
loss conclusion.
5.1 Results 52
Figure 5.2: Percentage of frames received
5.1 Results 53
5.1.3 Proof of RS-485 concept
Figure 5.3: RS-485 master packet using 3.3V click board
As mentioned previously we needed to prove the concept of the RS-485 communication
hardware of the bridge hardware design. Testing was carried out as per the methodology
using a development board, RS-485 click board and an oscilloscope.
Figure 5.3 demonstrates this test. The start and stop bits are circled. This transmission
has two eight bit bytes as marked. The least significant bit is sent first so bytes are
read right to left. The value of byte one is 0x6D and the value of byte two is 0xA9.
This is consistent with the transmitted message and successfully demonstrates RS-485
communications are possible with the designed hardware.
5.1 Results 54
5.1.4 Physical Cable Testing
Figure 5.4 is the CAN bus as seen when the USB-CAN converter is reporting a trans-
mission error. The transmission line is the breadboarding wire. This frame repeated
periodically on the bus.
Figure 5.4: Short transmission line CAN traffic
Figure 5.5 is the CAN bus as seen when using the 1m twisted pair. It is the same frame
as viewed in figure 5.4, however now we see significant overshoot on rising edges. Removal
of the terminating resistor on the click board does not noticeably alter the image.
Figure 5.6 is the CAN bus as seen when using the 10m twisted pair. The overshoot is
still prevalent and is joined by significant ringing on the frame. Again the terminating
resistor had no meaningful effect.
To this point, transmission line tests had been performed using the development board
that generates the errors on the USB-CAN converter. Figure 5.7 is taken from the working
CAN bus on 10m twisted pair. The ringing and overshoot is present on this test as well.
This is a frame from the USB-CAN converter.
Figure 5.8 shows the response from the bridge on the working bus using 10m transmission
line. It is a much cleaner signal than the USB-CAN converter produces in any test.
5.1 Results 55
Figure 5.5: 1 meter twisted pair CAN traffic
Figure 5.6: 10 meter twisted pair CAN traffic
5.1 Results 56
Figure 5.7: 10 meter twisted pair CAN traffic on working bus
Figure 5.8: 10 meter twisted pair CAN response
5.2 Discussion 57
5.2 Discussion
Initial testing of the bridge was unsuccessful. The cause of the issue was pinpointed to
be either the bridge’s CAN interface, the USB-CAN converter or a combination of both.
These issues did not allow full completion of the testing as per the methodology. For the
testing that was performed, results are discussed below. Following that is a discussion of
the issues and limitations of the bridge, the methodology and the testing equipment.
5.2.1 Proof of Concept
The concept of the bridge has been demonstrated successfully. A full message was sent
and received through both bridge interfaces. This proves that according to the method-
ology outlined, the hardware and software designs of the bridge can perform the basic
functionality required.
5.2.2 Stress Tests
Initial testing showed malfunctions of the CAN interface, thus results for all stress testing
parameters were not obtained. The discussion of the cause of these errors is found in the
subsection labelled Issues and Limitations - CAN Interface.
The results that were attained showed that at CAN baud rate 125kbps and Modbus baud
9.6kbps, the bridge is able to complete, without loss, full CAN to Modbus and return
message translation in around 220ms. This effectively means that the bridge can be
polled by the BMS CAN node four times a second. This is far more than needed for a
practical BMS requirement. If it were possible to increase the baud rates for the interfaces,
it is likely we would see an increase in performance. This is unnecessary given the proven
performance is adequate. There is no known reason why gas detection equipment would
need to update its status at a faster rate.
There is a linear decrease in performance at faster messaging rates. The effect would be
significant if messaging times were required in that region. For the application of the
bridge that is not the case.
For all tests at all messaging rates, the number of CAN frames received back by the
5.2 Discussion 58
BMS CAN node simulator was exactly equal to the number of Modbus frames sent by
the bridge. This means that the frame loss must occur between the bridge’s CAN frame
reception and Modbus transmission. As it was not possible to alter the source code of
the bridge during testing, a counter could not be placed at these points in software. If
that were possible, it would identify where the loss had occurred and verify the assertion
above.
5.2.3 Proof RS-485 Concept
The testing results for the RS-485 tests showed the expected signal on the bus that
conforms to the RS-485 standard. This indicates that due to the consistency of design
between the test platform and the PCB, the PCB can be expected to perform similarly
and therefore conforms to the RS-485 standard.
5.2.4 Physical Cable Testing
The results of the physical cable testing showed that significant overshoot and ringing was
present on the bus during tests with different parameters. These results were consistent
across the working CAN bus and non-working CAN bus tests. This suggests that the
transmission errors experienced were not caused by the transmission lines.
5.2 Discussion 59
5.2.5 Discussion of issues and limitations - CAN Interface
The original design methodology for the CAN interface was to utilise the existing CANSpi
library. It was intended that SPI interrupt would be used to signal that SPI data had been
received. This would flag to the bridge that a CAN message was received. This approach
was not suitable. The CANSpi library initialisation function sets the parameters of the
SPI module. Under these conditions, SPI interrupts enabled within the main program do
not function. As a result, the interrupt method for CAN reception was abandoned. Each
pass through the main functions’ infinite loop tests whether a CAN message has been
received. This is the alternative solution.
Another issue encountered with using CANSpi library functions within interrupt routines
is their re-entrancy. When there is a possibility of a function being called from the
main program loop and an interrupt routine, the MikroC compiler throws a re-entrancy
error. This is to stop the interrupt call of the function overwriting the stack or data from
the original function call. This also occurred during testing of Modbus functions within
interrupts. The issue is resolvable by setting flags in interrupt services routines that are
checked in the main loop. This is the approach taken for the Modbus (UART) interrupts.
Two 5V CANSpi modules were used in early attempts to successfully initiate CAN com-
munications. Use of these devices was not successful. The CANSpi click board was
configured on the development board. One of the 5V CANSpi modules was configured
on another identical development board. Previous research in chapter 2 had shown that
5V and 3.3V CAN transceivers can exist on the same bus. When CAN messages were
not detected on either end, diagnostic checks were performed using an oscilloscope. The
inspection found that SPI data was not transferring from the CAN-SPI as expected. The
CAN-SPI chip was replaced on these boards and the testing was performed again. One of
the two CANSpi 5V board still did not function. The other now produced a signal that
resembled a CAN frame. The two different CANSpi modules still did not communicate
with each other. At this point, the USB-CAN converter had become available and testing
went forward on that platform only.
Tests performed with the USB-CAN converter and the development board fitted with the
CANSpi click board were challenging. The most significant issue was the inability of the
bridge to receive CAN messages. CAN frames were successfully sent from the bridge to
the USB-CAN converter. To use the CANSpi library certain flags, masks and filters need
5.2 Discussion 60
to be set. The data-sheet of the MCP2515 3 and the help file for the CANSpi library in
MikroC were difficult to reconcile. There is no consistency in naming. It takes educated
guessing or trial and error to identify correct parameters for use. The masks and filters
were ruled out as the cause. The issue was eventually identified to be with CAN flags. The
library example provided with MikroC was used as a guide. In this example the CANSpi
initialises with the 11 bit message type. The reception flags were configured for 29 bit
reception only. This was difficult to identify due to the lack of consistency between the
library help and component data-sheet. The change required to complete the test were
alterations of the flag ” CANSPI XTD MSG” to ” CANSPI STD MSG” in two locations
of the source code. This was a simple issue to resolve but time intensive to identify.
The above issues were found during early testing to demonstrate that the CANSpi library
was viable. The major issue with the CAN interface was discovered when the proof
of concept test was attempted. Inconsistencies were observed with the CAN interface.
The USB-CAN intermittently reported a transmission error indicated via the ’err’ LED
flashing. The error did not occur with any pattern which made troubleshooting difficult.
Occasionally, the USB-CAN converter would successfully send one or more CAN frames
and then stop working, giving the error indication. Other times it would not send any
successful CAN messages. An attempt was made to use the SPI to report the contents of
the registers in the CAN-SPI IC in the hopes of diagnosing the error. The code listing can
be found in appendix F. The initial conclusion was that the issue is related to differing
configurations of the USB-CAN converter and the initialisation functions of the CANSPI
library. There is insufficient information in either user manual to reconcile these issues
easily or in a timely manner. It is not possible to rule out equipment failure given that
the USB-CAN devices is a two port device and one of the two ports stopped working
during testing.
To this point, the CAN interface had been very inconsistent and only functioned spo-
radically. The functionality was sufficient for proof of concept testing. Diagnostics were
abandoned due to time limitations at this stage of the project.
During final testing and data gathering the bridge began to work flawlessly on the main de-
velopment board. This was without making any change to source code that had previously
not worked with any consistency. Uploading the same source code onto the secondary
development board did not work. This meant any further configuration of the source code
3The CAN-SPI IC on the bridge is the same as the one found on the click board by design.
5.2 Discussion 61
past this point was not possible. The only difference between the two development boards
are the crystals connected to the processor. They should not effect the CAN interface
given it has its own, separate oscillation source. The conclusion here is that the source
code may have become corrupted. This would explain why the latest source code version
does not function. Once rectified, it would be possible to carry out stress tests at the
different baud rates. Full exploration of board capabilities would also be possible.
What was possible was tested using the working development board with the configuration
parameters set in the source code. This is the CAN baud at 125kbps and Modbus baud
at 9.6kbps as described in the stress testing above. The CAN message type is the 11 bit
identifier version(CAN 2.0A).
Development of user written functions to access the CAN interface via SPI may address
some or all of the above issues. It would give full control over the interface. This would
also likely improve the performance of the bridge. The obvious downside is that a lot of
work would be required to recreate the functionality offered by the CANSpi library and
this is out of the scope of this project.
5.2 Discussion 62
5.2.6 Discussion of issues and limitations - Modbusslave simulator
Equipment issues were experienced with the Modbusslave simulator. This program has a
serial traffic viewer to allow the user to monitor outgoing and incoming serial messages in
ASCII format. When doing initial testing with the development board some irregularities
were observed. A screen capture of an example can be seen in figure 5.10. The data that
was sent is as per figure 5.9.
Figure 5.9: Code exert of serial data sent
Figure 5.10: Serial synchronisation errors with 16MHz crystal
The data being sent from the bridge was not consistent with what was received by the
Modbusslave traffic viewer. Reproducing the transmission and viewing the results on the
MikroC terminal produced the expected outcome. The issue was identified as a timing
error. The crystal on the development board was 16MHz. This led to small errors in
5.3 Chapter Summary 63
baud generation for the UART. This synchronisation error caused the Modbusslave to
receive characters not sent and to not receive characters actually sent. Replacement of
the 16MHz crystal with a 14.7456MHz crystal4 removed the error. Serial traffic then
appeared as expected. Interestingly, during compilation of results for this dissertation,
the second development board with a 16MHz crystal could not reproduce this error.
Whilst the change of crystal appeared to rectify the problem during the first encounter,
it is not possible to rule out other factors as the cause. Using a perfect divisor crystal is
still advisable when possible.
The resolution of the timing error led to further testing of the Modbusslave simulator. The
simulator was configured as per an example on the developers website. The development
board was then configured to send a test message that would extract some information
off the simulator in a known fashion. The results of this test were not as expected. The
simulator did receive and respond to the sent frame, but the response was not what was
expected. It was also not a known error response. Further testing showed that regardless
of the frame sent to the simulator, the same response is received (data component is 00 00
08 00 00 01). This can be seen in the results of the proof of concept. The version of the
simulator used was a free trial. As such the software does not offer full functionality. For
the purposes of testing the bridge it was adequate. It did prevent the testing of Modbus
frames with data sizes over 6 bytes. Responses are always the same as described above,
and as a result never contain enough (16bytes or more) data to test the decomposition
and reconstitution of large data frames.
5.3 Chapter Summary
This chapter has covered the results from testing the bridge, including proof of concept,
stress testing, RS-485 testing and the testing of physical cables. It also included a discus-
sion of the significance of these results and detailed discussion of the issues and challenges
encountered during the bridge design and testing.
4The same device found on the final bridge hardware. This discovery drove that selection.
Chapter 6
Conclusion and Future Work
6.1 Conclusions 65
6.1 Conclusions
The network bridge to translate between CAN and Modbus frames is of commercial
interest to GDA. Research showed the concept was feasible. A PIC microprocessor based
embedded system was designed to facilitate the protocol translation. The hardware (PCB)
and software (C code) were outlined in detail.
Relevant testing demonstrated both the proof of concept and initial performance. The
testing was limited but demonstrated the bridge will be able to respond fast enough for
the given application. The bridge is able to respond to four CAN messages per second at
CAN baud 125kbps and Modbus baud 9.6kbps. This is sufficient for the BMS application
and meets the main project objective.
Many issues were encountered with the implementation of the CAN interface and they
prevented further exploration of the bridge performance and capabilities. The cause of
these issues were identified to be the source code for the CAN interface. This was a result
of a lack of configuration control available to the user when utilising the inbuilt library
functions of the MikroC development environment.
A limitation of the Modbus simulator was experienced. It did not respond with accurate
or expected frames to legitimate requests. This issue did not affect the critical testing,
but did prevent the testing of decomposition and reconstitution of Modbus frames with
data sizes greater than sixteen bytes. The design of this process was still presented but
not implemented.
As the bridge did not reach a complete finished state, documentation was not completed
in full. Appendix I contains an outline of the intended content of these documents.
The main objectives of the project were met. The design was completed and proof
of concept demonstrated. Full testing and exploration of the bridge performance and
capabilities were not possible. The next section details relevant further work to rectify
the issues and develop this topic further.
6.2 Recommendations and Future Work 66
6.2 Recommendations and Future Work
The inconsistencies with the CAN interface are of most interest. It would be useful to
do further testing with the SPI to communicate directly with the CAN-SPI chip to trou-
bleshoot the CAN interface. If time was available, a full re-write of the CANSpi libraries
from scratch would give more control to the developer and allow better diagnostics. Once
complete, a full suite of stress testing could determine the full capabilities of the bridge.
To improve and expand the Modbus interface functionality a few simple changes could be
made. Full support of all parity types could be implemented. This is a simple fix requiring
the configuration of one bit per byte of the serial transmission. The decomposition and
reconstitution of data sizes greater than 16 bytes could be implemented. This would
require access to a more sophisticated Modbus slave simulator.
Modbus RTU functionality could be added to make the bridge more flexible. As seen
with existing commercial products, they are generally static in their implementation.
The implementation is relatively simple. The ASCII and Hex conversions are no longer
required, and the frames do not use delimiters. This makes the frame composition simpler
than Modbus ASCII. The added complexity comes in the sending of the frames. Interrupt
driven timers are required to adhere to the timing laws of the Modbus RTU transmission
scheme.
Finally, investigations into Modbus TCP could be carried out. This would require the
addition of an Ethernet hardware interface to the bridge, adding greater flexibility to the
device.
There are non-communications based work that would improve the bridge. The GLCD
and touch panel could be configured to allow status displays and customisation of the
bridge parameters such as baud rates. The software configuration for power failure and
LED operation (including errors) could be implemented.
If performance improvements were required, one way to achieve this might be to further
logically separate the CAN and Modbus interfaces. This would involve make the bridge a
complete standalone Modbus master that interacts with the Modbus slaves as per normal
Modbus operation. The bridge could maintain the key Modbus data in memory and
simply release it when a CAN request came through.
References
ADF web (2015), ‘Gateway/bridge: Can rom/to Modbus’, http://www.adfweb.com/
home/products/Can_modbus.asp?frompg=nav1_7. [Online; accessed April-2015].
ANSI (2014), Tia/eia Standard: Commercial Building Telecommunications Cabling Stan-
dard, Standard TIA/EIA-485, American National Standards Institute.
Blackman, J. & Monroe, S. (2013), Overview of 3.3v Can (controller area network)
Transceivers, Applications report, Texas Instruments.
Butzin, B., Golatowski, F., Niedermeier, C., Vicari, N. & Wuchner, E. (2014), A model
based development approach for building automation systems’, in ‘Emerging Tech-
nology and Factory Automation’, Institute of Electical and Electronic Engineers,
Barcelona.
CAN in Automation (2015a), ‘Can: Physical layer’, http://www.can-cia.org/index.
php?id=systemdesign-can. [Online; accessed April-2015].
CAN in Automation (2015b), ‘Controller area network’, http://www.can-cia.org/
index.php?id=systemdesign-can. [Online; accessed April-2015].
Cena, G., Bertolotti, I., Hu, T. & Valenzano, A. (2014), Design, verification, and per-
formance of a modbus-can adaptation layer, in ‘10th IEEE Workshop on Factory
Communication Systems’, Toulouse.
Corrigan, S. (2008a), Controller area network physical layer requirements, Applications
report, Texas Instruments, Texas.
Corrigan, S. (2008b), Introduction to the controller area network (can), Applications
report, Texas Instruments, Texas.
REFERENCES 68
de Sousa, M. & Portugal, P. (2011), Modbus, in B. Wilamowski & D. Irwin, eds, ‘The
Industrial Electronics Handbook: Industrial Communications Systems’, CRC Press,
chapter Modbus.
Fairchild Semiconductor Corporation (2006), ‘Single-channel: 6n137, hcpl-2601, hcpl-2611
dual-channel: Hcpl-2630, hcpl-2631 high speed-10 mbit/s logic gate optocouplers’,
Datasheet.
Fairchild Semiconductor Corporation (2015), ‘Df005s - df10s: Bridge rectifiers’,
Datasheet.
Ferreira, J. & Fonseca, J. (2011), Controller area network, in B. Wilamowski & D. Irwin,
eds, ‘The Industrial Electronics Handbook: Industrial Communications Systems’,
CRC Press, chapter Controller Area Network.
Gas Detection Australia (2015), ‘Usq fourth year project bachelor of beng electrical/elec-
tronic engineering’, Project Specification. Toowoomba.
Guohuan, L., Hao, Z. & Wei, Z. (2009), Research on designing method of can bus and mod-
bus protocol conversion interface, in ‘International Conference on Future BioMedical
Information Engineering’, Institute of Electrical and Electronic Engineers, Sanya.
HMS (2015), ‘Anybus communicator: Can’, http://www.anybus.com/products/
abccan.shtml. [Online; accessed April-2015].
Hui, L., Hao, Z. & Daogang, P. (2013), Research and application of communication
gateway of epa and modbus/tcp, in ‘5th International Conference on Computational
Intelligence and Communication Networks’, Mathura.
ICP DAS USA (2015), ‘I-7530a-mr: Modbus rtu to can converter’, http://www.
icpdas-usa.com/i_7530a_mr.html. [Online; accessed Apirl-2015].
IEEE (2015), Ethernet, Standard IEEE802.3, Institute of Electrical and Electronic Engi-
neers.
Institute of Engineers (1997), Towards sustainable engineering practice: engineering
frameworks for sustainability, Technical report, Institute of Engineers, Canberra.
ISO (2003a), Road vehicles - controller area network (can) - part 1: Data link layer
and physical signalling, Standard ISO 11989-1, International Organization for Stan-
darization.
REFERENCES 69
ISO (2003b), Road vehicles - controller area network (can) - part 2: High-speed medium
access unit, Standard ISO 11989-2, International Organization for Standarization.
Maxim Integrated (2006), ‘How far and how fast can you go with rs-485?’, https://www.
maximintegrated.com/en/app-notes/index.mvp/id/3884. Application Note.
Microchip (2010), ‘Mcp2551: High-speed can transceiver’, Datasheet.
Microchip (2011), ‘Pic18f87k22 family: 64/80-pin, high-performance, 1-mbit enhanced
flash mcus with 12-bit a/d and nanowatt xlp technology’, Datasheet.
Microchip (2012), ‘Mcp2515: Stand-alone can controller with spi interface’, Datasheet.
MikroeElektronika (2012a), CANSpi Click Manual v100, MikroeElektronika.
MikroeElektronika (2012b), RS485 Click Manual v100, MikroeElektronika.
Modbus Org (2006a), Modbus messaging on tcp/ip implemenation guide, Technical re-
port, Modbus Organisation, Inc.
Modbus Org (2006b), Modbus over serial line: Specification & implementation guide,
Technical report, Modbus Organisation, Inc.
Modbus Org (2006c), Modbus protocol specification, Technical report, Modbus Organi-
sation, Inc.
Modicon, Inc. (1996), Modbus protocol reference guide, Technical report, MODICON,
Inc., North Andover, Massachusetts. Rev. J.
RECOM (2012), ‘Roe0505s: Econoline dc/dc-converter’, Datasheet.
Rinaldi, J. (2010), ‘Modbus tcp vs. modbus rtu’, http://www.rtaautomation.com/
modbus-tcp-vs-modbus-rtu. [Online; accessed April-2015].
So, A. (2001), Building control and automation systems, in T. Samad, ed., ‘Perspectives
in Control Engineering Technologies, Applications and New Directions’, Wiley-IEEE
Press, chapter Building Control and Automation Systems.
Texas Instruments (1998), ‘Lm2671 simple switcher power converter high efficiency 500ma
step-down voltage regulator with features’, Datasheet.
Thomas, G. (2008), ‘Introduction to modbus serial and modbus tcp’, the EXTENSION:
A Technical Supplement to Control Network 9(5), 1–4.
REFERENCES 70
University of Southern Queensland (2012), ‘Electronic circuits: Study book’. Toowoomba.
Wang, L., Zhang, T., Li, K. & Ren, B. (2013), Study of can-modbus communications
adapter for low-voltage distribution system, in ‘International Conference on Mecha-
tronic Sciences, Electric Engineering and Computer’, IEEE, Shenyang.
Appendix A
Project Specification
72
ENG 4111/2 (or ENG8002) Research Project
Project Specification
For: Matthew Quinton
Topic: CAN bus to MODBUS network bridge to interface gas
detection units with Building Management Systems
Supervisors: Mark Pythian
James Boucher
Sponsorship: Faculty of Health, Engineering & Sciences
Gas Detection Australia Pty Ltd
Project Aim: The aim is to investigate, design and build a network bridge
to interface CAN bus enabled Building Management Sys-
tems (BMS) with MODBUS enabled gas sensors and control
units.
Program:
1. Review the literature to investigate the relevant CAN bus and MODBUS standards
and their implementations, how BMS function and any existing solutions for the
network bridge.
2. Based upon the literature and sponsor requirements create network bridge specifi-
cations including consideration for hardware connections, standards, device intelli-
gence and data integrity.
3. Develop a network bridge including hardware and software components for the spec-
ified hardware connection type.
4. Develop a testing procedure for the network bridge and verify correct functionality.
5. Produce all documentation including technical manual, operators manual, manu-
facturing procedure, programming guide and software manuals as necessary.
As time and resources permit:
1. Design and build/acquire/emulate a BMS system and test the network bridge in a
quasi-situation or on-site with a customers BMS and evaluate performance.
73
2. Investigate and implement other MODBUS hardware configurations as a separate
specification or additional board option
3. Investigate and implement other hardware connections options as a separate speci-
fication or additional board option
Agreed:
Student Name: Matthew Quinton
Date: 13th April 2015
Supervisor Name: Mark Phythian
Date: 13th April 2015
Appendix B
Controller Area Network
B.1 List of frame field descriptions 75
This appendix contains further technical information about the CAN protocol.
B.1 List of frame field descriptions
The following describe the fields of CAN frames as per ISO (2003a).
SOF Start of frame used to synchronise nodes after idle state (dominant bit).
Identifier Establishes message priority as per arbitration (11 or 29 bits).
RTR Remote transmission request dominant bit when information is required from
another node. The identifier determines the specific node requested.
IDE Identifier extension this means that a standard CAN identifier is being transmitted
with no extension (dominant single bit).
R0 Reserved bit unused at this stage.
DLC Data length code number of bytes being transmitted (4 bit).
Data Up to 64bits may be transmitted.
CRC Cyclic redundancy check 15 bits plus 1 bit delimiter contains checksum for error
detection.
ACK Receiving nodes overwrite this bit with dominant to indicate error free message
received. If the receiving node leaves as recessive the message is discarded and the sender
repeats transmission.
EOF End of frame 7 bit field indicates end of frame. Also disables bit stuffing. Dominant
means a stuffing error.
IFS Interframe space 7bit field contains time required to move a correctly received frame
to its position in a message buffer by the controller /citecorr2.
The extended frame includes the extra 18 bit identifier as well as three other fields.
SRR Substitute remote request bit replaces RTR and is a placeholder.
B.2 Physical Connection 76
IDE Identifier extension bit indicates that more identifier bits follow.
R1 Additional reserve bit .
B.2 Physical Connection
The physical medium is two wires and a separate ground connection. Unshielded 120
ohm twisted pair cabling is common. Using higher quality cable is recommended in
harsher environments. To minimise the effect of reflections on the cables terminating
resistors are required on both ends of the bus. Connectors used should also have the
same characteristic impedance as the line and terminating resistors /citecorr1. There
are several other considerations that need to be taken into account when designing CAN
bus networks but are largely beyond the scope of this project. The aim is to add a
node into an existing network and not to create or alter an existing or new network.
The characteristics of the connections are of importance and should be considered when
selecting components.
B.2.1 Topology
CAN is bus based. Replicated buses are not explicit in the standard but are possible
and research has been conducted around star. Star networks require a coupler or some
other central device to facilitate broadcasts to nodes. Faults have to be treated differently
when in star mode and this is the basis for significant research beyond the scope of this
project (Ferreira & Fonseca 2011).
B.2.2 Transmission and Signals
CAN is a differential signalling protocol. A high and a low signal is sent out on comple-
mentary connections. The message is dominant when the high is held high and the low
is held low (ISO 2003a). Typically, the bus is passively biased to 2.5V. The high voltage
is approximately 1V higher (3.5V) and the low voltage is approximately 1V lower (1.5V).
This gives a typical voltage differential of 2V (Corrigan 2008a). 3.3V or 5V transceivers are
common and can be interoperable with each other (Blackman & Monroe 2013). Figure B.1
B.2 Physical Connection 77
demonstrates the dominant and recessive voltages levels for the CAN bus. Dominant bits
are used in the arbitration process for multiple access.
Figure B.1: CAN bit levels (adapted from (ISO 2003a)).
B.2 Physical Connection 78
B.2.3 Encoding
CAN uses Non Return to Zero (NRZ) and as such only one timeslot is required per
bit (CAN in Automation 2015a). Figure B.2. shows the NRZ encoding scheme as well
as the Manchester encoding for point of difference. Manchester encoding uses the state
change to signify a bit where NRZ uses a level. The key difference is that NRZ simply
drives the bit value on the bus whilst Manchester schemes force a transition.
Figure B.2: NRZ and Manchester Encoding (adapted from (CAN in Automation 2015a)).
B.2 Physical Connection 79
B.2.4 Synchronisation and Bit Stuffing
The NRZ encoding scheme has no inherent synchronisation so this is achieved using a
start bit within the packets. Figure B.3 demonstrates the synchronisation issues with
NRZ. If a large number of consecutive bits of the same value are transmitted it can be
difficult to resynchronise due to the lack of a rising or falling edge. To overcome this
issue CAN uses bit stuffing to break sequences of 6 or more consecutive bits of the same
polarity. A bit of opposite polarity to the sequence is inserted after 5 consecutive bits.
Bit stuffing introduces extra overhead to transmission. The effect can be estimated if the
timing is an issuet (CAN in Automation 2015a).
Figure B.3: CAN bit stuffing (adapted from (CAN in Automation 2015a)).
B.2 Physical Connection 80
B.2.5 Errors
CAN has five error checking methods; three at message level and two at the bit level.
When any of these errors is detected, an error frame is generated by the receiving node.
The transmitting node will attempt to resend the frame until received correctly. The
three message level checks are the CRC, the ACK and the form check. The CRC is a
standard 15-bit checksum with a 1-bit delimiter. The ACK is comprised of two bits; the
ACK bit and a delimiter. The form check is carried out by checking the SOF, EOF, ACK
and CRC delimiters. During arbitration, conflicting bit values may be written to the bus
and this is also true of the acknowledge slot. If this is detected for any other bit an error
is generated. The second bit level error check is bit stuffing. If six consecutive bits of the
same polarity are received then an error is generated.
B.3 Masks and Filters 81
B.3 Masks and Filters
The following contains some information about how the filters and masks work in CAN
addressing (ISO 2003a).
Filters are a bitwise enabler of CAN IDs. In order for a message to make it through a
filter, 1s must be in place of the corresponding ID bits. For example:
ID = 3 - convert to binary - 00000000011 (for an 11 bit address)
Filter - convert to binary - 00000000000 - would not allow this ID through since the 0s in
the bit spacers of the ID filter
Filter - convert to binary - 00000000011 - would allow this ID through since the 1s enable
the spaces in the filter
The masks take precedence over the filters. In other words, the mask enables the filter.
For our previous example:
ID = 3 - convert to binary - 00000000011
Filter - convert to binary - 00000000000 - we saw before this would not allow ID 3 through,
unless we configure a mask to override it
Mask - convert to binary - 00000000000 - here we are saying we don’t care what the filter
says, let everything in. The mask 0s disable the corresponding bits in the filter.
Likewise, a mask of 11111111111 will not let any message through.
This setup gives you quite a lot of flexibility in how you handle messages, and through
which filters and buffers they pass.
Most of the abilities of these filters are not used within the scope of the bridge. They
are important on more complicated CAN networks and would need to be considered for
future commerical use of the bridge.
Appendix C
Modbus
C.1 Protocol Data Unit 83
C.1 Protocol Data Unit
The Protocol Data Units (PDU) is comprised of the function code and the data field of
a Modbus frame. There is a large list of functions available for Modbus. The most com-
monly used are those associated with accessing memory addresses (de Sousa & Portugal
2011). At this stage, a complete discussion of the available function codes is not required.
C.2 Error Checking
Modbus has two built in error checking facilities; parity checking and frame checking.
Parity checking is implemented by configuring network devices as either Even, Odd or No
parity. If Even or Odd is chosen then one bit is adjusted so that the data frame has the
same parity as the network configuration. This will detect bit errors where the number of
errors is odd only. Frame checking is achieved using a Cyclic Redundancy Check (CRC)
for Modbus RTU or Longitudinal Redundancy Check (LRC) for Modbus ASCII.
C.3 Physical Media
Some of the features of the protocol are not solely governed by the specification alone.
This is due to the fact that Modbus does not define a physical layer. The physical media
that carry it define some parameters. For this project the serial interface used is UART
and RS-485.
RS-485 is a two wire balanced system with a third common wire. Four wire Modbus is
possible to give full duplex capabilities to a network. This project is a two wire based
network. A requirement of Modbus serial is to have shielded cables where one end of each
cable is connected to protective ground (Modbus Org 2006b).
RS-485 allows multi-drop connections using a bus (trunk) with direct connections (daisy
chain) or derivations (drop) cables. Derivation cables must be no more than 20 meters
long (Modbus Organisation, Inc. 2006). 1200 meters is the maximum length for the trunk
cable (Maxim Integrated 2006).
C.4 RS 485 Data Rates 84
C.4 RS 485 Data Rates
The specification defines the two standard baud rates of 9600kbps and 19200kpbs of
which the latter is the default (Modbus Organisation, Inc. 2006). The maximum baud
listed in the specification is 115kpbs. It may be possible to operate Modbus on serial
lines at speeds of 10Mbps (Maxim Integrated 2006), although is a trade-off between run
length and speed and as such this speed will not be achievable at near maximum lengths.
Using techniques such as pre-emphasis and receiver equalisation it may be possible to
achieve data rates of 800kbps over 1200 meters and 50Mbps over lengths of hundreds of
meters (Maxim Integrated 2006).
C.5 Encoding and Synchronisation
RS-485 is an asynchronous differential system that utilises a start bit/s and stop bit/s
either side of the data. Timing between sender and receiver must be agreed upon ahead
of time and synchronisation is carried out relative to the leading edge of the start bit (?).
Appendix D
Network Bridge Source Code - C
D.1 C Header 86
D.1 C Header
This listing contains the header file where function prototypes are defined.
Listing D.1: Project Header.
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
Gas Detec t ion Aus t ra l i a
CANbus to Modbus Network Bridge
BENH Fina l Year Pro jec t
Matthew Quinton
0061024766
Pro jec t header
PIC : 18F87K22
V1.0D
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
//−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
//−−−−−−−−−−−−−−−−−−−−END OF HEADING−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
MODBUS FUNCTIONS
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
void modbus in it ( ) ;
void TX ser ia l (unsigned short numchar ) ;
void TX modbus(unsigned char∗ buf f , unsigned char l ength ) ;
void RX Seria l (unsigned char ∗ r e t ) ;
void RX modbus(unsigned char ∗ ret , unsigned short l ength ) ;
unsigned short LRC(unsigned char∗ bu f f e r , unsigned short numchar ) ;
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
GENERAL FUNCTIONS
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short h e x a s c i i (unsigned short d i g i t ) ;
unsigned short a s c i i h e x (unsigned d i g i t ) ;
unsigned short s p l i t f i r s t (unsigned short hex d ig ) ;
unsigned short s p l i t s e c o n d (unsigned short hex d ig ) ;
unsigned short comb dig i t s (unsigned short dig1 , unsigned short dig2 ) ;
D.2 Modbus Functions 87
D.2 Modbus Functions
This listing contains the Modbus functions using the UART for serial communications.
Listing D.2: Modbus Functions.
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
Gas Detec t ion Aus t ra l i a
CANbus to Modbus Network Bridge
BENH Fina l Year Pro jec t
Matthew Quinton
0061024766
Modbus ASCII Master Functions
PIC : 18F87K22
V1.0D
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
//−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
//−−−−−−−−−−−−−−−−−−−−END OF HEADING−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
De f i n i t i o n s and v a r i a b l e s
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
#include ” ProjectDevBoard . h”
unsigned short baud = 9600 ; // Baud ra t e
unsigned short par i t y = 0 ; // Par i ty (0 − even , 1 − odd , 2 − none )
unsigned short s t o p b i t s = 1 ; // Number o f s top b i t s (1 − even/odd par i t y , 2 − no pa r i t y )
unsigned short s l a v e ; // S lave address f o r TX and RX
unsigned short MBReceived = 0 ; //Modbus frame Recived f l a g
unsigned short Ser ia lCount = 0 ; //Number o f b i t r e c i v ed through s e r i a l
unsigned short S e r i a l B u f f e r [ 3 0 ] ; // Buf fer used to s t o r e p a r t i a l modbus frame
unsigned short ModbusRecFrame [ 3 0 ] ; // Send frame fo r Modbus
unsigned short ModbusSendFrame [ 3 0 ] ; // Receive frame fo r Modbus
unsigned short ModbusFrameLength ; // Length o f r e c e i v ed frame
const unsigned short co lon = 0x3A ; // Asc i i COLON charac t e r
const unsigned short c a r r e t = 0x0D ; // Asc i i c a r r i a g e re turn charac t e r
const unsigned short l i n f d = 0x0A ; // Asc i i l i n e f e ed charac t e r
unsigned short val msg ;
//−−−−−−−−−−−−−−−−−−−−END OF SECTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
D.2 Modbus Functions 88
FUNCTION: UART I n i t i a l i s a t i o n
Set up o f s e r i a l comms .
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
void modbus in it ( )
{
UART1 Init ( 9 6 0 0 ) ; // I n i t i a l i s e UART1
TXSTA.TX9 = 0 ; // 8 b i t TX
TXSTA.SYNC = 0 ; // Asynchronous
TXSTA.SENDB = 1 ; // Send break charac t e r
RCSTA.RX9 = 0 ; // 8 b i t RX
UART Set Active(&UART1 Read , 0 , &UART1 Data Ready , &UART1 Tx Idle ) ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Transmit s e r i a l
Argument : numchar − number o f charac t e r s to be t ransmi t t ed
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
void TX ser ia l (unsigned short numchar )
{
unsigned short i ;
for ( i = 0 ; i < numchar ; i++)
{
while (PIR1 . TX1IF == 0 ) ; // Check f o r TX bu f f e r space
TXREG1 = ModbusSendFrame [ i ] ; // Place next charac t e r in TX bu f f e r
}
Delay us ( 5 ) ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Modbus Transmit
Argument : unsigned char∗ b u f f − message to TX
unsigned char l e n g t h − l e n g t h o f message to TX
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
void TX modbus(unsigned char∗ buf f , unsigned char l ength )
{
unsigned char i ;
unsigned char new length = length + 5 ; // To a l l ow fo r Star t , LRC, end chars
unsigned char hex LRC ; // To s t o r e Hex va lue o f LRC
ModbusSendFrame [ 0 ] = co lon ; // In s e r t s t a r t charac t e r :
for ( i = 1 ; i < l ength +1; i++)
{
D.2 Modbus Functions 89
ModbusSendFrame [ i ] = bu f f [ i −1] ;
}
// Perform LRC and p lace in frame
hex LRC = LRC( buf f , l ength ) ;
ModbusSendFrame [ new length −4] = s p l i t f i r s t (hex LRC ) ;
ModbusSendFrame [ new length −3] = s p l i t s e c o n d (hex LRC ) ;
// Add car r i a g e re turn and l i n e f e ed to frame
ModbusSendFrame [ new length −2] = c a r r e t ;
ModbusSendFrame [ new length −1] = l i n f d ;
// Transmit on s e r i a l l i n e
TX ser ia l ( new length ) ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: S e r i a l Receive
Argument : unsigned char∗ r e t − b u f f e r to RX
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
void RX Seria l (unsigned char ∗ r e t )
{
unsigned short c , k ;
stat ic unsigned short go = 0 ;
int p ;
c = UART1 Read ( ) ;
i f (RCSTA1 & 0x06 ) // Check f o r frame error or overrun error
{
RCSTA.CREN = 0 ;
c = RCREG;
RCSTA.CREN = 1 ; // i f overrun or frame r e s e t r e c e i v e r
}
else
{
i f ( go )
{
S e r i a l B u f f e r [ Ser ia lCount ] = c ; // read b i t
Ser ia lCount++; // inc counter
i f ( c == l i n f d ) // t e s t i f frame f u l l
{
for ( k = 0 ; k < Ser ia lCount ; k++) //Swap b u f f e r in t o modbus frame
{
r e t [ k+1] = S e r i a l B u f f e r [ k ] ; // copy by t e
}
r e t [ 0 ] = Ser ia lCount ;
go = 0 ;
MBReceived = 1 ; //Flag t ha t modbus frame re c i v ed
Ser ia lCount = 0 ; // r e s e t the s e r i a l b i t counter
}
}
else
{
D.2 Modbus Functions 90
i f ( c == colon )
{
S e r i a l B u f f e r [ Ser ia lCount ] = c ; // read b i t
Ser ia lCount++; // inc counter
go = 1 ;
}
}
}
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Modbus Receive
Argument : unsigned char∗ r e t − message to RX
unsigned shor t l e n g t h − l e n g t h o f message to RX
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
void RX modbus(unsigned char ∗ ret , unsigned short l ength )
{
unsigned short p ;
unsigned short g ;
unsigned short r x l r c ;
unsigned char h o l d a r r [ 3 0 ] ;
unsigned short new len = length − 5 ;
for (p = 0 ; p < new len + 1 ; p++) // Transfer to ho l d ing array
{
h o l d a r r [ p ] = a s c i i h e x ( r e t [ p +1 ] ) ;
}
// Extrac t LRC from frame
r x l r c = comb dig i t s ( a s c i i h e x ( r e t [ l ength − 3 ] ) , a s c i i h e x ( r e t [ l ength − 2 ] ) ) ;
for ( g = 0 ; g < new len ; g++)
{
r e t [ g ] = h o l d a r r [ g +1] ; // Transfer data on ly back to frame array
}
i f (LRC( ret , new len ) != r x l r c ) // Check f o r LRC
r e t [ g ] == 0xFF ; // LRC error
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Long i tud ina l Redunancy Check
Argument : unsigned shor t numchar − number o f charac t e r s in frame
unsigned char∗ b u f f e r − frame to be LRC
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short LRC(unsigned char∗ bu f f e r , unsigned short numchar )
{
D.2 Modbus Functions 91
unsigned short sum = 0 ;
unsigned short i = 0 ;
for ( i = 0 ; i < numchar ; i++)
{
sum = sum + b u f f e r [ i ] ; // Sum frame
}
return (˜ ( sum | 0 b1111111100000000 ) ) + 1 ; // Perform 2s compliment
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
D.3 Ancillary Functions 92
D.3 Ancillary Functions
This listing contains the ancillary functions used in the network bridge.
Listing D.3: Ancillary Functions.
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
Gas Detec t ion Aus t ra l i a
CANbus to Modbus Network Bridge
BENH Fina l Year Pro jec t
Matthew Quinton
0061024766
Non communication f unc t i on s
PIC : 18F87K22
V1.0D
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
//−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
//−−−−−−−−−−−−−−−−−−−−END OF HEADING−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
#include ” ProjectDevBoard . h”
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Hex to Asc i i
Argument : hex char to conver t
Return : a s c i i va lue o f charac t e r (0 i f e r ror )
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short h e x a s c i i (unsigned short d i g i t )
{
i f ( d i g i t >= 0 && d i g i t <=9)
return d i g i t + 0x30 ;
else i f ( d i g i t > 9 && d i g i t < 16)
return d i g i t + 0x37 ;
else
return 0 ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Asc i i to hex
Argument : a s c i i char to conver t
Return : hex va lue o f charac t e r (0 i f e r ror )
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short a s c i i h e x (unsigned d i g i t )
D.3 Ancillary Functions 93
{
i f ( d i g i t >= 0x30 && d i g i t <=0x39 )
return d i g i t − 0x30 ;
else i f ( d i g i t > 0x40 && d i g i t < 0x47 )
return d i g i t − 0x37 ;
else
return 0 ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: S p l i t d i g i t s f i r s t
Argument : hex number where f i r s t d i g i t i s to be e x t r a c t e d
Return : ex t raced f i r s t d i g i t
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short s p l i t f i r s t (unsigned short hex d ig )
{
return hex d ig >> 4 ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: S p l i t d i g i t s second
Argument : hex number where second d i g i t i s to be e x t r a c t e d
Return : ex t raced second d i g i t
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short s p l i t s e c o n d (unsigned short hex d ig )
{
return hex d ig & 0b00001111 ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
FUNCTION: Combine d i g i t s
Argument : two d i g i t s to be combined
Return : va lue o f d i g i t s combined
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
unsigned short comb dig i t s (unsigned short dig1 , unsigned short dig2 )
{
unsigned int a = 0 ;
a = dig1 << 4 ;
a = a | dig2 ;
return a ;
}
//−−−−−−−−−−−−−−−−−−−−END OF FUNCTION−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
D.4 Main Function 94
D.4 Main Function
This listing contains the main function. Note that the CAN functionality are not a
separate listing and appear within this listing.
Listing D.4: Main Program.
/∗−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
Gas Detec t ion Aus t ra l i a
CANbus to Modbus Network Bridge
BENH Fina l Year Pro jec t
Matthew Quinton
0061024766
Main Program
PIC : 18F87K22
V1.0D
/−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−∗/
//−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
//−−−−−−−−−−−−−−−−−−−−END OF HEADING−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−
#include ” ProjectDevBoard . h”
unsigned char Can In i t F lags , Can Send Flags , Can Rcv Flags ; // can f l a g s
unsigned char Rx Data Len ; // r e c e i v ed data l en g t h in by t e s
char RxTx Data [ 8 ] ; // can rx / t x data b u f f e r
char Msg Rcvd ; // recep t i on f l a g
const long ID 1st = 12111 , ID 2nd = 3 ; // node IDs
long Rx ID ;
unsigned short new data ;
unsigned char RX M data [ 3 0 ] ;
unsigned char RX S data [ 3 0 ] ;
unsigned short RX S Len ;
unsigned char i ;
// CANSPI module connec t ions
s b i t CanSpi CS at RE0 bit ;
s b i t CanSpi CS Direct ion at TRISE0 bit ;
s b i t CanSpi Rst at RC0 bit ;
s b i t CanSpi Rst Direct ion at TRISC0 bit ;
// End CANSPI module connec t ions
// Uart i n t e r r u p t s e r v i c e rou t ine
void i n t e r r u p t ( )
{
i f (PIR1 . RC1IF)
D.4 Main Function 95
{
RX Seria l ( RX S data ) ;
PIR1 . RC1IF = 0 ;
new data = 1 ;
}
}
void main ( ) {
// Conf igure AN pins as d i g i t a l I /O
ANCON0 = 0 ;
ANCON1 = 0 ;
ANCON2 = 0 ;
// Enable i n t e r r u p t s
INTCON. GIE = 1 ;
INTCON. PEIE = 1 ;
PIE1 . RC1IE = 1 ;
// Clear f l a g s
Can In i t F lag s = 0 ;
Can Send Flags = 0 ;
Can Rcv Flags = 0 ;
// Confg ire CAN f l a g s
Can Send Flags = CANSPI TX PRIORITY 0 &
CANSPI TX STD FRAME &
CANSPI TX NO RTR FRAME;
Can In i t F lag s = CANSPI CONFIG SAMPLE THRICE &
CANSPI CONFIG PHSEG2 PRG ON &
CANSPI CONFIG STD MSG &
CANSPI CONFIG DBL BUFFER ON &
CANSPI CONFIG ALL VALID MSG ;
// I n i t i a l s e communications
// S e r i a l
modbus in it ( ) ;
Delay ms ( 1 0 0 ) ;
// SPI
SPI1 In i t ( ) ;
Delay ms ( 1 0 0 ) ;
// Clear Uart r e c e i v ed f l a g
new data = 0 ;
// CAN I n i t i a l i s a t i o n
CANSPIIni t ia l i ze ( 1 , 5 , 3 , 3 , 1 , Can In i t F lag s ) ; // I n i t i a l i z e e x t e r na l CANSPI module @ 125kHz
CANSPISetOperationMode ( CANSPI MODE CONFIG, 0xFF ) ;
CANSPISetMask( CANSPI MASK B1,−1 , CANSPI CONFIG STD MSG ) ;
CANSPISetMask( CANSPI MASK B2,−1 , CANSPI CONFIG STD MSG ) ;
D.4 Main Function 96
CANSPISetFilter ( CANSPI FILTER B2 F4 , ID 2nd , CANSPI CONFIG STD MSG ) ;
// s e t NORMAL mode a f t e r i n i t i a l i s a t i o n
CANSPISetOperationMode ( CANSPI MODE NORMAL, 0xFF ) ;
// I n f i n i t e loop to proces s messages to RX and TX
while (1 )
{
// Check f o r CAN rece i v ed
Msg Rcvd = CANSPIRead( Rx ID , RxTx Data , Rx Data Len , Can Rcv Flags ) ;
i f ( Msg Rcvd == 0xFF)
{
// I f CAN rece i v ed send on modbus
TX modbus( RxTx Data , 6 ) ;
Msg Rcvd = 0 ;
}
i f ( new data )
{
// Process here i f UART in t e r r u p t
RX S Len = RX S data [ 0 ] ;
RX modbus( RX S data , RX S Len ) ;
// Write Modbus data to CAN
CANSPIWrite ( ID 1st , RX S data , RX S Len−5, Can Send Flags ) ;
new data = 0 ;
}
}
}
Appendix E
Hardware Design Images
E.1 Schematic 98
E.1 Schematic
11
22
33
44
55
66
77
88
D
D
C
C
B
B
A
A
Sc
al
e
Sh
ee
t
Si
ze
FC
SM
 N
o.
DW
G
 N
o.
Re
v
A3
G
D
C
A
N
M
O
D
 V
1.
6
1 o
f 1
1.
6
GD
CM
-0
02
Dr
aw
n 
By
:
M
at
th
ew
 Q
ui
nt
on
Ti
tle
:
23
/10
/15
Da
te
C2 10
0n
F
TX
-C
AN
1
RX
-C
AN
2
CL
KO
UT
3
TX
0R
TS
4
TX
1R
TS
5
TX
2R
TS
6
MCP2515
OS
C2
7
OS
C1
8
GN
D
9
RX
1B
F
10
RX
0B
F
11
IN
T
12
SC
K
13
SI
14
SO
15
CS
16
RE
SE
T
17
VD
D
18
U1
0
M
CP
25
15
1 2
X2 10
M
Hz
C2
6
22
pF
C2
5
22
pF
R2
4
10
k
R1
5
56
 O
hm
R1
6
56
 O
hm
R14
4K7
R18
4K7
R17
120 Ohm
12
J4 Ju
m
pe
r
R1
9
39
0
GN
D_
M
OD
_I
SO
GN
D_
CA
N_
IS
O
GN
D_
CA
N_
IS
O
+5
V_
CA
N_
IS
O
+5
V_
RS
48
5_
IS
O
GN
D_
M
OD
_I
SO G
ND
_M
OD
_I
SO
GN
D_
M
OD
_I
SO
12
X1 14
.7
45
6M
Hz
C5
4
22
pF
C5
3
22
pF
GN
D
GN
D
GN
D
GN
D
VC
AP
VC
AP
C5
2
10
uF
GN
D
GN
D
VI
N
C3
10
nF
CB
1
SS
2
SY
NC
3
FB
4
ON
/O
FF
5
GN
D
6
VI
N
7
VS
W
8
LM2671
U2 LM
26
71
-5
.0
 S
wi
tc
hi
ng
 R
eg
ul
at
or
L1 10
0u
H 
@
 >
0.
5 
A
D2
3.
3A
, 5
0V
 S
ch
ot
tk
y 
Re
ct GN
D
GN
D
12
J3 Ju
m
pe
r
12
J2 Ju
m
pe
r
1 2 3
P3 RS
48
5A B G
ND
GN
D
CA
NH
CA
NL
+5
V
C2
1
10
0n
F
GN
D_
M
OD
_I
SO
GN
D_
CA
N_
IS
O
+5
V_
CA
N_
IS
O
DC
-D
C
-V
in
1
+V
in
2
-V
ou
t
3
+V
ou
t
4
U5 RO
E-
05
05
S
GN
D
GN
D
DC
-D
C
-V
in
1
+V
in
2
-V
ou
t
3
+V
ou
t
4
U4 RO
E-
05
05
S
C1
7
10
0n
F
R23
820R
R2
0
1k
R8
1k
R9 82
0R
R1
0
82
0R
R1
2
82
0R
R21
820R
GN
D
M
CL
R
GN
D
R1 10
0k
12
J1 Ju
m
pe
r G
ND
RO
1
RE
2
DE
3
DI
4
GN
D
5
A
6
B
7
VC
C
8
U9 DS
48
5M
R1
1
1k R1
3
1k
Ce
r
Ce
r
Ce
r
Ce
r
Ca
p's
 a
cr
os
s p
ai
rs 
of
 V
dd
 a
nd
 V
ss
+5
V
C1
9
10
0u
F
C1
8
10
uF
+5
V
C1
5
10
0u
F
C1
4
10
uF
A
2
GN
D
5
VO
6
VC
C
8
VE
7
K
3
U8 HC
P1
-2
60
1.
S
A
2
GN
D
5
VO
6
VC
C
8
VE
7
K
3
U7 HC
P1
-2
60
1.
S
A
2
GN
D
5
VO
6
VC
C
8
VE
7
K
3
U6 H
CP
1-
26
01
.S
A
2
GN
D
5
VO
6
VC
C
8
VE
7
K
3
U1
1
HC
P1
-2
60
1.
S
A
2
GN
D
5
VO
6
VC
C
8
VE
7
K
3
U1
2
HC
P1
-2
60
1.
S
+5
V
GN
D
GN
D
+5
V
GN
D
R2
2
1k
TX
D
GND+5V
RX
D
VR
EF
CA
NL
CA
NH R
S
U1
3
M
CP
25
51
+5
V
+5
V
+5
V
PG
D
PG
C
M
CL
R
PG
D
PG
C
SC
K2
SD
I2
SD
O2
SC
K2
SD
I2
SD
O2
1
2
3
4
5
6
7
8
9
10
P2 He
ad
er
 2
x5
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20P6 GL
CD
GN
D
+5
V
GN
D
+6
V
10
K
RV
1
GN
D
Q1 BC
85
7B
Q3 BC
85
0C
Q2 BC
85
7B
Q4 BC
85
0C
Q5 BC
85
0C
GN
D
C5
6
10
0n
F
C5
7
10
0n
F
Re
ad
_X
Re
ad
_Y
DR
IV
EA
DR
IV
EB
DR
IV
EA
+5
V_
A
DR
IV
EB
Re
ad
_X
Re
ad
_Y
1 2 3 4
P5
04
FM
N-
BM
TT
N-
A-
TF
GN
D
Bo
tto
m
Le
ft
To
p
Ri
gh
t
+5
V_
RS
48
5_
IS
O
+5
V_
RS
48
5_
IS
O
+5
V_
RS
48
5_
IS
O
~ ~
-+
Re
ct
ifi
er
D1 DF
04
S
1 2 3
P4 C
AN
C_
GN
D
C5
5
10
uF
RH
2/
A1
8
1
RH
3/
A1
9
2
RE
1/
AD
9/
W
R/
P2
C
3
RE
0/
AD
8/
RD
/P
2D
4
RG
0/
EC
CP
3/
P3
A
5
RG
1/
TX
2/
CK
2/
AN
19
/C
3O
UT
6
RG
2/
RX
2/
DT
2/
AN
18
/C
3I
NA
7
RG
3/
CC
P4
/P
3D
/A
N1
7/
C3
IN
B
8
RG
5/
M
CL
R
9
RG
4/
CC
P5
/P
1D
/R
TC
C/
T7
CK
I/T
5G
/A
N1
6/
C3
IN
C
10
VS
S
11
VD
DC
OR
E/
VC
AP
12
RF
7/
SS
1/
AN
5
13
RF
6/
AN
11
/C
1I
NA
14
RF
5/
AN
10
/C
1I
NB
15
RF
4/
AN
9/
C2
IN
A
16
RF
3/
AN
8/
C2
IN
B/
CT
M
UI
17
RF
2/
AN
7/
C1
OU
T
18
RH
7/
AN
15
/P
1B
/C
CP
6
19
RH
6/
AN
14
/P
1C
/C
CP
7/
C1
IN
C
20
RH
5/
AN
13
/P
3B
/C
CP
8/
C2
IN
D
21
RH
4/
AN
12
/P
3C
/C
CP
9/
C2
IN
C
22
RF
1/
AN
6/
C2
OU
T/
CT
DI
N
23
EN
VR
EG
24
AV
DD
25
AV
SS
26
RA
3/
AN
3/
VR
EF
+
27
RA
2/
AN
2/
VR
EF
-
28
RA
1/
AN
1
29
RA
0/
AN
0/
UL
PW
U
30
VS
S
31
VD
D
32
RA
5/
AN
4/
HL
VD
IN
/T
1C
KI
/T
3G
33
RA
4/
T0
CK
I
34
RC
1/
SO
SC
/E
CC
P2
/P
2A
35
RC
0/
SO
SC
O/
SC
KL
I
36
RC
6/
TX
1/
CK
1
37
RC
7/
RX
1/
DT
1
38
RJ
4/
BA
0
39
RJ
5/
CE
40
RJ
6/
LB
41
RJ
7/
UB
42
RC
2/
EC
CP
1/
P1
A
43
RC
3/
SC
K1
/S
CL
1
44
RC
4/
SD
I1
/S
DA
1
45
RC
5/
SD
O1
46
RB
7/
KB
I3
/P
GD
47
VD
D
48
OS
C1
/C
LK
I/R
A7
49
OS
C2
/C
LK
O/
RA
6
50
VS
S
51
RB
6/
KB
I2
/P
GC
52
RB
5/
KB
I1
/T
3C
KI
/T
1G
53
RB
4/
KB
I0
54
RB
3/
IN
T3
/E
CC
P2
/P
2A
/C
TE
D2
55
RB
2/
IN
T2
/C
TE
D1
56
RB
1/
IN
T1
57
RB
0/
IN
T0
/F
LT
O
58
RJ
3/
W
RH
59
RJ
2/
W
RL
60
RJ
1/
OE
61
RJ
0/
AL
E
62
RD
7/
AD
7/
PS
P7
/S
S2
63
RD
6/
AD
6/
PS
P6
/S
CK
2/
SC
L2
64
RD
5/
AD
5/
PS
P5
/S
DI
2/
SD
A2
65
RD
4/
AD
4/
PS
P4
/S
DO
2
66
RD
3/
AD
3/
PS
P3
67
RD
2/
AD
2/
PS
P2
68
RD
1/
AD
1/
PS
P1
/T
5C
KI
/T
7G
69
VS
S
70
VD
D
71
RD
0/
AD
0/
PS
P0
/C
TP
L
72
RE
7/
AD
15
/E
CC
P2
/P
2A
73
RE
6/
AD
14
/P
1B
/C
CP
6
74
RE
5/
AD
13
/P
1C
/C
CP
7
75
RE
4/
AD
12
/P
3B
/C
CP
8
76
RE
3/
AD
11
/P
3C
/C
CP
9/
RE
F0
77
RE
2/
AD
10
/C
S/
P2
B/
CC
P1
0
78
RH
0/
A1
6/
AN
23
79
RH
1/
A1
7/
AN
22
80
U1 PI
C1
8F
87
K2
2-
I/P
T
D1
1
PO
W
ER
D7 RS
TX
D8 RS
RX
D9 CA
N
GN
D
D1
0
FAULT
+6
V
R4
0
82
0R
GN
D
56
0
R3
6
56
0
R3
7
56
0
R3
8
56
0
R3
9
C4 1u
F
GN
D
C3
1
10
0n
F
C2
0
22uF 6V3
C1
6
22uF 6V3
Ce
r
Ce
r
C2
2
10
uF
C2
7
10
uF
C2
3
10
uF
C2
4
10
0n
F
C3
5
10
uF
 6
V3
L2 33
uH
C4
0
10
uF
GN
D
+5
V_
A
+5
V_
A
+5
V_
A +5
V_
A
+5
V_
A
GN
D
GN
D_
CA
N_
IS
O
+5
V_
RS
48
5_
IS
O
C3
2
10
0n
F
C3
3
10
0n
F
C3
4
10
0n
F
C4
1
10
0n
F
GN
D
C5
22uF 6V3
C6
22uF 6V3
C1
>22uF 50V
Ce
r
+5
V_
A
GN
D_
M
OD
_I
SO
C4
4
10
uF
C4
3
10
uF
C4
2
10
uF
GN
D_
CA
N_
IS
O
+5
V_
CA
N_
IS
O
C2
8
10
0n
F
C2
9
10
0n
F
C3
0
10
0n
F
+5
V_
CA
N_
IS
O
+5
V_
CA
N_
IS
O
Ca
p's
 fo
r U
6,
 U
7,
 U
8 
an
d 
U9
Ca
p's
 fo
r U
11
, U
12
 a
nd
 U
13
C4
7
10
0n
F
C4
8
10
0n
F
C4
9
10
0n
F
R2 10
0R
R2
5
39
 O
hm
R2
6 1k
R2
7 1k
R2
8
10
k
R2
9
10
k
R3
0
10
k
R3
1
10
k
R3
2
10
0k
R3
3
1k R
34 10
k
R3
5
10
0k
C1
0
100nF GN
D
C8 10
0n
FD3S1
G
D4 S1
G
BT
1
2x
3V
 L
i G
ND
R5 33
k
R6
68
k
R4 33
0k
R3 68
0k
GN
D
Vs
p
Vp
p
GN
D
GN
D
Vs
p
Vp
p
Vp
p
Vs
p
C3
6
10
nF
C3
7
10
0n
F
GN
D
GN
D
+6
V
D5 S1
G
D6 S1
G
VM
I
VM
I
M
CU
_V
CC
M
CU
_V
CC
M
CU
_V
CC
+5
V_
In
EN
_P
C7 10
0n
F
A
+5
V_
RS
48
5_
IS
O
A
B
B
RS
48
5_
Rx
RS
48
5_
Rx
RS
48
5_
TE
RS
48
5_
TE
RS
48
5_
Tx
RS
48
5_
Tx
RE
RE
GN
D_
M
OD
_I
SO
GN
D_
M
OD
_I
SO
GN
D_
CA
N_
IS
O
CA
N_
RE
SE
T
CA
N_
RE
SE
T
CA
N_
CS
CA
N_
CS
CA
N_
SO
CA
N_
SI
CA
N_
SC
K
CA
N_
IN
T
CA
N_
SO
CA
N_
SI
CA
N_
SC
K
CA
N_
IN
T
GN
D_
M
OD
_I
SO
+5
V_
RS
48
5_
IS
O
C1
2
22uF 6V3
C1
3
10
0n
F
EN
_P
R7
10k
GN
D
C9
22uF 6V3
GN
D
+5
V
In GN
D
EN
Ou
t
NR
/F
B
U3 TP
S7
32
50
DB
VT
C1
1
1u
F
GN
D
+5
V_
In
+5
V
GN
D
+5
V
GN
D
12
P1 24
V
PIBT101 PIBT102C
OB
T1
PIC101PIC102
CO
C1
PIC201 PIC202
CO
C2
PI
C3
01
PI
C3
02
CO
C3
PI
C4
01
PI
C4
02CO
C4
PIC501 PIC502C
OC
5
PIC601 PIC602C
OC
6 PIC701PIC702 C
OC
7
PIC801PIC802
CO
C8
PIC901 PIC902C
OC
9
PIC1001PIC1002
CO
C1
0
PIC1101PIC1102
CO
C1
1
PIC1201 PIC1202C
OC
12
PIC1301 PIC1302
CO
C1
3
PIC1401 PIC1402
CO
C1
4PIC15
01 PIC1502
CO
C1
5
PIC1601 PIC1602
CO
C1
6PIC17
01 PIC1702
CO
C1
7
PIC1801 PIC1802
CO
C1
8
PIC1901 PIC1902
CO
C1
9
PIC2001 PIC2002
CO
C2
0PIC2101 PIC2102
CO
C2
1
PIC2201PIC2202
CO
C2
2
PIC2301 PIC2302
CO
C2
3 PIC2401PIC2402
CO
C2
4
PI
C25
01
PI
C25
02
CO
C2
5
PI
C26
01
PI
C26
02
CO
C2
6
PIC2701 PIC2702
CO
C2
7
PIC2801PIC2802
CO
C2
8
PIC2901PIC2902
CO
C2
9 PIC30
01PIC3002
CO
C3
0
PIC3101PIC3102
CO
C3
1
PIC3201PIC3202
CO
C3
2 PIC3301PIC3302
CO
C3
3 PIC3401PIC3402
CO
C3
4
PIC3501PIC3502
CO
C3
5
PIC3601PIC3602
CO
C3
6
PIC3701PIC3702
CO
C3
7
PIC4001 PIC4002
CO
C4
0
PIC4101PIC4102
CO
C4
1
PIC4201PIC4202 C
OC
42
PIC4301PIC4302 C
OC
43 PIC4401PIC4402
CO
C4
4 PIC4701PIC4702
CO
C4
7 PIC4801PIC4802 C
OC
48
PIC4901PIC4902 C
OC
49
PIC5201 PIC5202
CO
C5
2
PI
C53
01
PI
C53
02
CO
C5
3
PI
C5
40
1
PI
C5
40
2
CO
C5
4
PIC5501PIC5502
CO
C5
5
PIC5601PIC5602
CO
C5
6
PIC5701PIC5702
CO
C5
7
PI
D1
01
PI
D1
02
PI
D1
03
PI
D1
04C
OD
1
PID20APID20K
CO
D2
PI
D3
0A
PI
D3
0K
CO
D3
PI
D4
0A
PI
D4
0K
CO
D4PI
D5
0A
PI
D5
0K
CO
D5
PI
D6
0A
PI
D6
0K
CO
D6
PID70A PID70KCO
D7
PID80A PID80KCO
D8
PID90A PID90KCO
D9
PID100A PID100K
CO
D1
0
P
I
D
1
1
0
A
P
I
D
11
0K
CO
D1
1
P
I
J
10
1
PI
J1
02
CO
J1
P
I
J
20
1
P
I
J
20
2
CO
J2
PI
J3
01
P
I
J
30
2
CO
J3
P
I
J
40
1
P
I
J
40
2
CO
J4
PI
L1
01
PI
L1
02
CO
L1
PI
L2
01
PI
L2
02
CO
L2
PI
P1
01
PI
P1
02
CO
P1
PI
P2
01
PI
P2
02
PI
P2
03
PI
P2
04
PI
P2
05
PI
P2
06
PI
P2
07
PI
P2
08
PI
P2
09
PI
P20
10
CO
P2
PI
P3
01
PI
P3
02
PI
P3
03
CO
P3
PI
P4
01
PI
P4
02
PI
P4
03
CO
P4
PI
P5
01
PI
P5
02
P
I
P
50
3
P
I
P
50
4C
OP
5
PI
P6
01
PI
P6
02
PI
P6
03
PI
P6
04
PI
P6
05
PI
P6
06
PI
P6
07
PI
P6
08
PI
P6
09
PI
P6
01
0
PI
P6
01
1
PI
P6
01
2
PI
P6
01
3
PI
P6
01
4
PI
P6
01
5
PI
P6
01
6
PI
P6
01
7
P
I
P
60
18
PI
P6
01
9
PI
P6
02
0
CO
P6
PIQ101
P
I
Q1
02
P
I
Q1
03
CO
Q1
PIQ201
P
I
Q2
02
P
I
Q2
03
CO
Q2
PIQ301 PI
Q
3
0
2
P
I
Q3
03
CO
Q3
P
I
Q4
01
PIQ402 PIQ403COQ
4
P
I
Q
5
0
1
PIQ502PIQ503 COQ
5
PIR101PIR102 C
OR
1
PI
R2
01
PI
R2
02C
OR
2
PI
R3
01
PI
R3
02
CO
R3
PI
R4
01
PI
R4
02
CO
R4
PIR501 PIR502C
OR
5
PI
R6
01
PI
R6
02
CO
R6
PIR701PIR702 COR7
PIR801 PIR802COR8
PI
R9
01
PI
R9
02CO
R9
PIR1001PIR1002 C
OR
10
PI
R1
10
1
PI
R1
10
2
CO
R1
1
PIR1201PIR1202 C
OR
12
PI
R13
01
PI
R13
02
CO
R1
3
PIR1401 PIR1402COR14 PIR1
50
1
PI
R1
50
2
CO
R1
5
PI
R1
60
1
PI
R1
60
2
CO
R1
6
PIR1701 PIR1702COR17
PIR1801 PIR1802COR18
PIR1901 PIR1902
CO
R1
9
PIR2001PIR2002 C
OR
20
PIR2101PIR2102 COR21
PI
R22
01
PI
R22
02C
OR
22
PIR2301 PIR2302COR23
PIR2401 PIR2402
CO
R2
4
PI
R25
01
PI
R25
02CO
R2
5
PI
R2
60
1
PI
R2
60
2CO
R2
6
PI
R2
70
1
PI
R2
70
2CO
R2
7
PIR2801 PIR2802C
OR
28
PI
R2
90
1
PI
R2
90
2
CO
R2
9
PIR3001PIR3002 C
OR
30
PI
R3
10
1
PI
R3
10
2CO
R3
1
PIR3201 PIR3202C
OR
32
PIR3301 PIR3302C
OR
33
PI
R3
40
1
PI
R3
40
2
CO
R3
4
PIR3501PIR3502 C
OR
35
PIR3601 PIR3602C
OR
36
PIR3701 PIR3702C
OR
37
PIR3801 PIR3802C
OR
38
PIR3901 PIR3902C
OR
39
PI
R4
00
1
PI
R4
00
2
CO
R4
0
PIRV101 PIRV102
PI
RV
10
3
C
O
R
V
1
P
I
U
1
0
1
P
I
U
1
0
2
P
I
U1
03
P
I
U
1
0
4
P
I
U
1
0
5
P
I
U
1
0
6
P
I
U
1
0
7
P
I
U1
08
P
I
U
1
0
9
PI
U1
01
0
P
I
U
10
11
P
I
U
10
12
P
I
U
10
13
P
I
U
10
14
P
I
U
10
15
P
I
U
10
16
PI
U1
01
7
PI
U1
01
8
P
I
U
10
19
PI
U1
02
0
PI
U1
02
1
P
I
U
10
22
P
I
U
10
23
P
I
U
10
24
P
I
U
10
25
P
I
U
10
26
P
I
U
10
27
P
I
U
10
28
P
I
U
10
29
PI
U1
03
0
P
I
U
10
31
P
I
U
10
32
PI
U1
03
3
P
I
U
10
34
P
I
U
10
35
P
I
U
10
36
P
I
U
10
37
P
I
U
10
38
P
I
U
10
39
P
I
U
10
40
P
I
U
10
41
PI
U1
04
2
P
I
U
10
43
PI
U1
04
4
P
I
U
10
45
P
I
U
10
46
P
I
U
10
47
P
I
U
10
48
P
I
U
10
49
PI
U1
05
0
PI
U1
05
1
P
I
U
10
52
PI
U1
05
3
P
I
U
10
54
P
I
U
10
55
P
I
U
10
56
P
I
U
10
57
PI
U1
05
8
P
I
U
10
59
PI
U1
06
0
P
I
U
10
61
P
I
U
10
62
P
I
U
10
63
P
I
U
10
64
PI
U1
06
5
P
I
U
1
0
6
6
P
I
U
10
67
P
I
U
10
68
P
I
U
10
69
PI
U1
07
0
PI
U1
07
1
PI
U1
07
2
PI
U1
07
3
P
I
U
10
74
P
I
U
10
75
P
I
U
10
76
P
I
U
10
77
PI
U1
07
8
PI
U1
07
9
PI
U1
08
0
CO
U1PIU
20
1
PI
U2
02
PI
U2
03
PI
U2
04
PI
U2
05
PI
U2
06
PI
U2
07
PI
U2
08C
OU
2
PI
U3
01
PI
U3
02
PI
U3
03
PI
U3
04
PI
U3
05
CO
U3
P
I
U
4
0
1
P
I
U
4
0
2
P
I
U
4
0
3
P
I
U
4
0
4
CO
U4
P
I
U
5
0
1
P
I
U
5
0
2
P
I
U
5
0
3
P
I
U
5
0
4
CO
U5
PI
U6
02
PI
U6
03
PI
U6
05
PI
U6
06
PI
U6
07
PI
U6
08
CO
U6
PI
U7
02
PI
U7
03
PI
U7
05
PI
U7
06
PI
U7
07
PI
U7
08C
OU
7
PI
U8
02
PI
U8
03
PI
U8
05
PI
U8
06
PI
U8
07
PI
U8
08C
OU
8
P
I
U
9
0
1
P
I
U
9
0
2
P
I
U
9
0
3
P
I
U9
04
P
I
U9
05
P
I
U
9
0
6
P
I
U
9
0
7
P
I
U
9
0
8
CO
U9
P
I
U
1
0
0
1
P
I
U
1
0
0
2
P
I
U
1
0
0
3
P
I
U
1
0
0
4
P
I
U
1
0
0
5
P
I
U
1
0
0
6
P
I
U
1
0
0
7
P
I
U
1
0
0
8
P
I
U
1
0
0
9
P
I
U
1
0
0
1
0
P
I
U
10
01
1
P
I
U
1
0
0
1
2
P
I
U
10
01
3
P
I
U
1
0
0
1
4
P
I
U
1
0
0
1
5
P
I
U
10
01
6
P
I
U
1
0
0
1
7
P
I
U
1
0
0
1
8C
OU
10
PI
U1
10
2
PI
U11
03
PI
U1
10
5
PI
U1
10
6
PI
U1
107
PI
U1
10
8CO
U1
1
PI
U1
20
2
PI
U1
20
3
PI
U1
20
5
PI
U1
20
6
PI
U12
07
PI
U1
208C
OU
12
PI
U13
01
PIU1302PIU1303
PI
U1
30
4
PI
U1
30
5
PI
U1
30
6
PI
U1
30
7
PI
U13
08
CO
U1
3
PIX101PIX102 C
OX
1
PIX201 PIX202C
OX
2
PIC1201
PIC1301
PIC1401
PIC1501
PIC1801
PIC1901
PIC2301
PIC2402
PIC2802
PIC3102
PI
P6
01
7
PIR801
PIR1002 PIR1202
PIR2002 PIR2102
PI
U3
04
P
I
U
4
0
2
P
I
U
5
0
2
PI
U6
07
PI
U6
08
P
I
U
1
0
0
1
8
PI
U1
107
PI
U1
10
8
PIC4001
PIC4102
PIC5502
PI
L2
02
P
I
Q1
02
P
I
Q2
02
PI
R2
60
2
PI
R2
70
2
PIR3301
P
I
U
10
25
PIC1601
PIC1701
PIC2701
PIC2902
PIC3002
PI
R22
02
PIR2301
P
I
U
4
0
4
PI
U12
07
PI
U1
208
PIU1303
PIC901
PIC1002
PI
D3
0K
PI
D4
0K
PI
U2
04
PI
U3
01
PIC2001
PIC2101
PIC2202
PIC3202
PIC3302
PIC3402
PI
R9
01
PI
R1
10
1
PI
R13
02
PIR1401
P
I
U
5
0
4
PI
U7
07
PI
U7
08
PI
U8
07
PI
U8
08
P
I
U
9
0
8
PIC501
PIC601
PIC702
PI
D3
0A PI
D5
0A
P
I
D
1
1
0
A
PI
L1
02
PIR502
PI
R25
01
P
I
J
20
1P
IR
15
01
P
I
U
9
0
6
P
I
J
30
2P
IR
16
01
P
I
U
9
0
7
P
I
U
10
54
P
I
U
10
01
6
P
I
U
10
57
P
I
U
1
0
0
1
2
PI
U1
05
3
P
I
U
1
0
0
1
7
PI
U1
04
4
P
I
U
10
01
3
P
I
U
10
45
P
I
U
1
0
0
1
5
P
I
U
10
46
P
I
U
1
0
0
1
4
PI
R2
60
1
PI
R2
90
2
PIR3002
PI
R3
10
2
P
I
U
10
34
PIR3302 PIR34
01
PI
U1
03
3
PIR702
P
I
U
10
27
PI
U3
03
PIBT102
PIC101
PIC202
PI
C4
01
PIC502
PIC602
PIC701
PIC801
PIC902
PIC1001
PIC1101
PIC1202
PIC1302
PIC1402
PIC1502
PIC1802
PIC1902
PIC2302
PIC2401
PI
C25
02
PI
C26
02
PIC2801
PIC3101
PIC3501
PIC3601
PIC3701
PIC4002
PIC4101
PIC4201
PIC4301
PIC4401
PIC4701
PIC4801
PIC4901
PIC5202
PI
C53
01
PI
C5
40
1
PIC5501
PIC5701
PI
D1
02
PID20A
PID70K
PID80K
PID90K
PID100K
P
I
J
10
1
PI
P2
09
PI
P20
10
PI
P6
01
P
I
P
60
18
P
I
Q
3
0
2
PIQ502
PI
R3
01
PI
R6
02
PIR701
PIR3501
PI
R4
00
1
PIRV102
P
I
U
10
11
P
I
U
10
26
P
I
U
10
31
PI
U1
05
1
PI
U1
07
0
PI
U2
06
PI
U3
02
P
I
U
4
0
1
P
I
U
5
0
1
PI
U6
05
P
I
U
1
0
0
9
PI
U1
10
5
PIC1602
PIC1702
PIC2702
PIC2901
PIC3001
PI
P4
03
PIR2402
P
I
U
4
0
3
PI
U1
20
5
PIU1302
PIC2002
PIC2102
PIC2201
PIC3201
PIC3301
PIC3401
PI
P3
03
PIR1802
PIR1902
P
I
U
5
0
3
PI
U7
05
PI
U8
05
P
I
U9
05
PI
P2
07
PI
R2
01
P
I
U
1
0
9
NL
MC
LR
PIC4202
PIC4302
PIC4402
PIC4702
PIC4802
PIC4902
PI
L2
01
PI
P2
01
PIR102
P
I
U
10
32
P
I
U
10
48
PI
U1
07
1
PIBT101
PIC802
PI
D4
0A
PI
D6
0A
PI
R4
02
PI
C3
01
PI
U2
01
PI
C3
02
PID20K
PI
L1
01
PI
U2
08
PI
C4
02
PI
U2
02
PIC1102
PI
U3
05
PI
C25
01
P
I
U
1
0
0
8
PIX201
PI
C26
01
P
I
U
1
0
0
7
PIX202
PIC3502
PI
J1
02PIR101
PI
R2
02
PI
C53
02
PI
U1
05
0
PIX102
PI
C5
40
2
P
I
U
10
49
PIX101
PIC5602
PIQ402
PIR3201
PI
D1
03
PI
P1
01
PI
D1
04
PI
P1
02
PID70APIR3602
PID80APIR3702
PID90APIR3802
PID100APIR3902
P
I
D
11
0KP
IR
40
02
P
I
J
20
2PIR1402
PI
J3
01
PIR1801
P
I
J
40
1 PIR1701
P
I
J
40
2
PI
P3
01
PI
R1
50
2
PI
P3
02
PI
R1
60
2PIR1702
PI
P4
01
PI
U1
30
7
PI
P4
02
PI
U1
30
6
P
I
P
50
3
P
I
Q1
03
P
I
P
50
4
P
I
Q2
03
PI
P6
02
PI
R25
02
PI
P6
03
PIRV101
PI
P6
04
PI
U1
01
8
PI
P6
05
P
I
U
1
0
4
PI
P6
06
P
I
U1
03
PI
P6
07
PI
U1
07
8
PI
P6
08
P
I
U
10
77
PI
P6
09
P
I
U
10
76
PI
P6
01
0
P
I
U
10
75
PI
P6
01
1
P
I
U
10
74
PI
P6
01
2
PI
U1
07
3
PI
P6
01
3
PI
U1
01
7
PI
P6
01
4
P
I
U
10
16
PI
P6
01
5
P
I
U
10
15
PI
P6
01
6
PI
RV
10
3
PI
P6
01
9
P
I
U
10
14
PI
P6
02
0
P
I
U
10
13
PIQ101PIR3001
PIQ201PIR2802
PIQ301PIR2901
P
I
Q3
03
PI
R2
70
1 PIR2801
P
I
Q4
01
PI
R3
10
1
P
I
Q
5
0
1
PI
R3
40
2
PI
R9
02
PI
U6
02
PIR1001
PI
U7
02
PI
R1
10
2 PI
U7
06
P
I
U
9
0
3
PIR1201
PI
U8
02
PI
R13
01 PI
U8
06
P
I
U9
04
PIR2001
P
I
U
1
0
0
2
PI
U1
10
6
PIR2101
PI
U1
20
2
PI
R22
01
PI
U1
20
6
PI
U13
01
PIR2302
PI
U1
10
2
PIR2401
PI
U13
08
PIR3601
P
I
U
10
62
PIR3701
P
I
U
10
61
PIR3801
PI
U1
06
0
PIR3901
P
I
U
10
59
P
I
U
1
0
1
P
I
U
1
0
2
P
I
U
1
0
5
PI
U1
01
0
P
I
U
10
19
PI
U1
02
0
PI
U1
02
1
P
I
U
10
22
P
I
U
10
23
P
I
U
10
24
P
I
U
10
35
P
I
U
10
36
P
I
U
10
37
P
I
U
10
38
P
I
U
10
39
P
I
U
10
40
P
I
U
10
41
PI
U1
04
2
P
I
U
10
43
P
I
U
10
55
P
I
U
10
56
P
I
U
10
63
P
I
U
10
67
P
I
U
10
68
P
I
U
10
69
PI
U1
07
2
PI
U1
07
9
PI
U1
08
0
PI
U2
03
PI
U2
05
PI
U6
03
P
I
U
9
0
1
P
I
U
1
0
0
1
PI
U1
20
3
P
I
U
1
0
0
3
P
I
U
1
0
0
4
P
I
U
1
0
0
5
P
I
U
1
0
0
6
P
I
U
1
0
0
1
0
P
I
U
10
01
1
PI
U11
03
PI
U1
30
4
PI
U1
30
5
PI
P2
03
P
I
U
10
52
PI
P2
05
P
I
U
10
47
PIR1901
P
I
U
9
0
2
PIC5601
PI
P5
02
PIQ403
PIR3202
PI
U1
03
0
PIC5702
PI
P5
01
PIQ503
PIR3502
P
I
U
10
29
PIR802
P
I
U
1
0
7
PI
U6
06
P
I
U1
08
PI
U7
03
P
I
U
1
0
6
PI
U8
03
PI
P2
08
P
I
U
10
64
PI
P2
04
PI
U1
06
5
PI
P2
06
P
I
U
1
0
6
6
PIC5201
P
I
U
10
12
PIC102
PIC201
PI
D1
01
PI
U2
07
PI
D5
0K
PI
D6
0K
PI
P2
02
PIC3602PIR501PIR
60
1
PI
U1
05
8
PIC3702
PI
R3
02PI
R4
01
P
I
U
10
28
E.2 PCB Top Layer 99
E.2 PCB Top Layer
PABT102 PABT101
CO
BT
1
PAC
101
PAC
102
CO
C1
PAC2
02
PAC
201
CO
C2
PAC
302PAC3
01
COC
3
PAC
402
PAC
401COC
4
PAC501
PAC502
CO
C5
PAC601
PAC602
CO
C6
PAC702
PAC701
CO
C7
PAC
802PAC8
01
CO
C8
PAC
902
PAC
901
CO
C9 PAC1
001
PAC
100
2
CO
C1
0
PAC1
102
PAC
110
1
CO
C11
PAC
120
2
PAC1
201
CO
C12
PAC13
01
PAC1
302
CO
C1
3
PAC140
2P
AC140
1
CO
C1
4
PAC1502
PAC150
1
CO
C1
5
PAC160
2
PAC160
1C
OC
16
PAC170
2
PAC170
1C
OC
17
PAC180
2
PAC180
1
CO
C1
8
PAC190
2
PAC190
1
CO
C1
9
PAC2002
PAC2001
CO
C2
0
PAC2102
PAC2101
CO
C2
1
PAC22
02
PAC22
01 COC22
PAC23
02
PAC230
1
CO
C2
3
PAC240
2
PAC240
1
CO
C2
4
PAC2
502
PAC25
01COC
25
PAC2
602
PAC2
601
COC26
PAC270
2
PAC2701
CO
C2
7
PAC28
01
PAC280
2
CO
C2
8
PAC
290
2
PAC
290
1 COC29 PAC300
2
PAC
300
1 COC30
PAC3102
PAC310
1
CO
C3
1
PAC
320
1
PAC
320
2 COC32PAC3302 PAC3301COC33
PAC3
402
PAC3
401 COC34
PAC
350
1
PAC
350
2 COC35
PAC3
602
PAC36
01
CO
C3
6
PAC370
2PA
C3701
CO
C3
7
PAC
380
2
PAC3
801
CO
C3
8
PAC3
902
PAC39
01
CO
C3
9
PAC4
002
PAC
400
1COC40
PAC41
01
PAC4
102COC41
PAC42
02
PAC420
1
C
O
C
4
2
PAC4302
PAC430
1CO
C4
3 PAC44
01
PAC4
402
COC44
PAC470
2
PAC4701
CO
C4
7
PAC480
2P
AC480
1 C
OC
48
PAC4
901
PAC
490
2
COC49
PAC5
202
PAC52
01
CO
C5
2
PAC5
302
PAC5
301
CO
C5
3
PAC5
402
PAC5
401
CO
C5
4
PAC550
2PA
C5501C
OC
55
PAC5602
PAC5601
CO
C5
6
PAC5
702
PAC57
01COC57
PAD10
3
PAD102
PAD10
4
PAD101
COD
1PAD20
K PAD20ACOD2 PA
D30A PAD3
0K
CO
D3
PAD4
0A
PAD4
0K
CO
D4
PAD5
0A
PAD5
0KCOD5
PAD6
0A
PAD6
0KCOD6
PAD7
0K
PAD7
0A
CO
D7
PAD8
0K
PAD8
0A
CO
D8
PAD9
0A
PAD9
0K
CO
D9
PAD10
0K
PAD10
0A
CO
D1
0
PAD11
0A
PAD11
0K
CO
D1
1
PAJ10
2
PAJ1
01
COJ
1
PAJ2
02
PAJ2
01
COJ2
PAJ3
02
PAJ3
01
COJ3
PAJ4
02
PAJ4
01
COJ4
PAL102
PAL101
CO
L1
PAL
202
PAL
201
COL
2
PAP1
01
PAP1
02
COP
1
PAP2
02
PAP201
0
PAP2
08
PAP2
04
PAP2
06
PAP2
05
PAP2
03
PAP2
01
PAP2
07
PAP20
9
CO
P2
PAP30
1
PAP3
03
PAP3
02
CO
P3
PAP40
1
PAP40
3
PAP40
2 COP
4
PAP50
4PA
P503
PAP5
02P
AP5
01
CO
P5
PAP60
20
PAP60
17
PAP60
18
PAP601
9
PAP60
16
PAP60
11
PAP6
08
PAP60
9
PAP60
10
PAP6
06
PAP6
05
PAP6
04
PAP6
01
PAP6
02
PAP6
03
PAP6
07
PAP601
4
PAP60
13
PAP60
12
PAP60
15
PAP60
0
CO
P6
PA
Q1
02
PAQ
101
PA
Q1
03
CO
Q1
PA
Q2
02
PA
Q2
01
PAQ2
03
CO
Q2
PA
Q30
2
PA
Q30
1
PA
Q3
03
CO
Q3
PA
Q4
02
PAQ
401
PA
Q40
3
CO
Q4
PAQ502
PAQ501PA
Q503
CO
Q5
PAR
101 PAR1
02
CO
R1
PAR
201
PAR
202 CO
R2
PAR
301
PAR
302 CO
R3
PAR
401
PAR
402
CO
R4
PAR501
PAR502
CO
R5
PAR60
1PA
R602
CO
R6
PAR
702
PAR
701
CO
R7
PAR8
02
PAR801
CO
R8
PAR
901
PAR
902
CO
R9
PAR1
002
PAR1
001COR10
PAR
1101
PAR
1102 COR11
PAR120
2
PAR12
01
CO
R1
2
PAR
1302
PAR
1301COR13
PAR140
2
PAR140
1
CO
R1
4
PAR150
2
PAR150
1C
O
R
15
PAR1602
PAR1601
CO
R1
6
PAR170
2
PAR170
1 C
OR
17
PAR1802
PAR1801
CO
R1
8
PAR1902
PAR1901
CO
R1
9
PAR2002
PAR200
1
CO
R2
0
PAR2102
PAR210
1
CO
R2
1
PAR22
02
PAR
2201 COR22PAR2302 PAR2301 COR23
PAR240
2P
AR240
1
CO
R2
4
PAR2501
PAR250
2
CO
R2
5
PAR2602
PAR260
1
CO
R2
6
PAR270
2PA
R2701C
OR
27
PAR28
02
PAR28
01 CO
R2
8
PAR2902
PAR2901
CO
R2
9
PAR300
2
PAR300
1
CO
R3
0
PAR3102
PAR3101
CO
R3
1
PAR320
2
PAR320
1C
OR
32
PAR330
2
PAR3301
CO
R3
3
PAR3402
PAR340
1CO
R3
4
PAR
3502 PAR35
01COR35
PAR36
02
PAR360
1 COR
36
PAR370
2
PAR370
1 COR
37
PAR38
02
PAR38
01
CO
R3
8
PAR390
2PA
R3901
CO
R3
9
PAR400
2
PAR400
1 COR
40
PARV10
2
PARV10
3
PARV101
CO
RV
1
P
A
U
1
0
1
PA
U1
02
P
A
U
1
0
3
P
A
U
1
0
4
PA
U1
05
P
A
U
1
0
6
PA
U1
07
P
A
U
1
0
8
P
A
U
1
0
9
PA
U1
01
0
P
A
U
1
0
1
1
PA
U1
01
2
P
A
U
1
0
1
3
PA
U1
01
4
PA
U1
01
5
P
A
U
1
0
1
6
PA
U1
01
7
P
A
U
1
0
1
8
PA
U1
01
9
P
A
U
1
0
2
0
PAU1021PAU1022PAU1023PAU1
024PAU1025PAU1026PAU1027P
AU1028PAU1029PAU1030
PAU1031PAU1032PAU1033PAU1
034PAU1035PAU1036PAU1
037PAU1038PAU1039PAU104
0PAU1
0
4
1
PA
U1
04
2
P
A
U
1
0
4
3
PA
U1
04
4
P
A
U
1
0
4
5
PA
U1
04
6
PA
U1
04
7
P
A
U
1
0
4
8
PA
U1
04
9
P
A
U
1
0
5
0
PA
U1
05
1
P
A
U
1
0
5
2
P
A
U
1
0
5
3
PA
U1
05
4
P
A
U
1
0
5
5
PA
U1
05
6
P
A
U
1
0
5
7
P
A
U
1
0
5
8
PA
U1
05
9
P
A
U
1
0
6
0
PAU1061PAU1062PAU1063PAU1064PAU1065PAU1066PAU1067PAU1068PAU1069PAU1070PAU1071PAU1072PAU1073PAU1074PAU1075PAU1076PAU1077PAU1078PAU1079PAU1080
COU
1
PA
U2
01
PA
U2
02
PA
U2
03
PA
U2
04
PA
U2
08
PA
U2
07
PA
U2
06
PA
U2
05
CO
U2
PAU
304
PAU
305
PAU
303PAU3
02
PAU
301CO
U3
PAU401
PAU403
PAU402
PAU404
CO
U4
PAU504
PAU502
PAU503
PAU501
CO
U5
PAU
605
PAU
606
PAU
607
PA
U60
8
PAU
603
PAU
602
PAU
604
PA
U60
1
CO
U6
PAU
701
PAU
704
PAU
702
PAU
703
PAU
708
PAU
707
PAU
706
PAU
705
CO
U7
PAU
805
PAU
806
PAU
807
PAU
808
PAU
803
PAU
802
PAU
804
PAU
801COU8
PAU901
PAU902PA
U903PAU
904
PAU908
PAU907PA
U906PAU
905
CO
U9
PA
U10
07
PA
U1
00
6
PA
U10
05
PA
U1
00
1
PA
U10
02
PA
U1
00
3
PA
U1
00
4
PA
U10
012
PA
U1
00
13
PA
U10
014
PA
U1
00
18
PA
U10
017
PA
U1
00
16
PA
U1
00
15
PA
U1
00
11
PA
U1
00
10
PA
U1
00
8
PA
U1
00
9
CO
U1
0
PAU
110
5
PAU1
106
PAU1
107
PAU
110
8
PAU1
103
PAU1
102
PAU
110
4
PAU
110
1
CO
U1
1
PAU1
205
PAU1
206
PAU1
207
PAU
120
8
PAU1
203
PAU1
202
PAU1
204
PAU
120
1
CO
U1
2
PAU
130
5
PA
U1
30
6
PAU
130
7
PA
U1
30
8
PAU
130
4
PA
U1
30
3
PAU
130
2
PA
U1
30
1
CO
U1
3
PAX101PAX102 C
OX
1
PAX201PAX202
CO
X2
PAC1
201
PAC13
01
PAC14
01
PAC150
1
PAC180
1
PAC190
1
PAC230
1
PAC240
2
PAC280
2
PAC3102
PAC3
801
PAC39
01
PAR801
PAR1
002
PAR120
2
PAR2002 PAR2102
PAU
304
PAU402
PAU502PAU60
7
PA
U60
8
PA
U1
00
18
PAU1
107
PAU
110
8
PAC
400
1
PAC4
102
PAC550
2
PAL
202
PA
Q1
02
PA
Q2
02
PAR2602
PAR270
2
PAR3301
PAU1025
PAC160
1
PAC170
1
PAC2701
PAC
290
2
PAC3
002
PAR22
02
PAR
2301
PAU404PAU
1207
PAU
120
8
PA
U1
30
3
PAC
901
PAC
100
2
PAD3
0K
PAD4
0K
PA
U2
04
PAU
301
PAC2001PAC2101
PAC22
02
PAC
320
2
PAC
330
2
PAC3
402
PAR
901
PAR
1101
PAR
1302
PAR140
1
PAU504
PAU
707
PAU
708
PAU
807
PAU
808
PAU908
PAC501 PAC601PAC702
PAD3
0A
PAD5
0A
PAD11
0A
PAL102 PAR502PAR2501
PAJ2
01
PAR150
1
PAU906
PAJ3
02
PAR1601
PAU907
PA
U1
05
4
PA
U1
00
16
P
A
U
1
0
5
7
PA
U10
012
P
A
U
1
0
5
3
PA
U10
017
PA
U1
04
4
PA
U1
00
13
P
A
U
1
0
4
5
PA
U1
00
15
PA
U1
04
6
PA
U10
014
PAR260
1
PAR2902PAR3002PAR3102
PAU1034
PAR330
2
PAR340
1
PAU1033
PAR
702
PAU1027
PAU
303
PABT102
PAC
101
PAC2
02
PAC
401
PAC502 PAC602PAC701
PAC8
01
PAC
902
PAC1
001
PAC
110
1
PAC
120
2P
AC13
02
PAC140
2PAC1502
PAC180
2
PAC190
2
PAC23
02 PAC240
1
PAC2
502
PAC2
602
PAC28
01
PAC310
1
PAC
350
1
PAC36
01
PAC3701
PAC
380
2
PAC3
902
PAC4
002
PAC41
01
PAC420
1PAC43
01
PAC44
01
PAC4701P
AC480
1 PAC4
901
PAC5
202
PAC5
301
PAC5
401
PAC550
1
PAC57
01
PAD102PAD20A
PAD7
0K
PAD8
0K
PAD9
0K
PAD10
0K
PAJ1
01
PAP20
9
PAP201
0
PA
Q30
2 PAQ502
PAR
301
PAR602
PAR
701
PAR35
01
PAR400
1
PARV10
2
P
A
U
1
0
1
1
PAU1026
PAU1031
PA
U1
05
1
PAU1070
PA
U2
06
PAU3
02
PAU401
PAU501
PAU
605
PA
U1
00
9
PAU
110
5
PAC160
2
PAC170
2
PAC270
2
PAC
290
1
PAC
300
1
PAP40
3
PAR240
2
PAU403
PAU1
205
PAU
130
2
PAC2002PAC2102
PAC22
01
PAC
320
1
PAC
330
1
PAC3
401 PAP3
03
PAR1802
PAR1902
PAU503
PAU
705
PAU
805 PAU905
PAP2
07
PAR
201 PA
U
1
0
9
PAC42
02
PAC4302
PAC4
402
PAC470
2
PAC480
2
PAC
490
2
PAL
201
PAP2
01
PAR1
02
PAU1032
P
A
U
1
0
4
8
PAU1071
PABT101
PAC
802
PAD4
0A
PAD6
0A
PAR
402
PAC3
01
PA
U2
01
PAC
302
PAD20K
PAL101
PA
U2
08
PAC
402
PA
U2
02
PAC1
102 PAU305
PAC25
01
PA
U1
00
8
PAX201
PAC2
601
PA
U10
07
PAX202
PAC
350
2
PAJ10
2
PAR
101
PAR
202
PAC5
302
P
A
U
1
0
5
0
PAX102
PAC5
402
PA
U1
04
9
PAX101
PAC5602 PAQ4
02
PAR320
1
PAD10
3
PAP1
01
PAD10
4
PAP1
02
PAD7
0A PAR360
2
PAD8
0A PAR370
2
PAD9
0A
PAR38
02
PAD10
0A
PAR390
2
PAD11
0K PAR4
002
PAJ2
02
PAR140
2
PAJ3
01
PAR1801
PAJ4
01
PAR170
1
PAJ4
02
PAP30
1
PAR150
2
PAP3
02
PAR1602PAR1702
PAP40
1
PAU
130
7
PAP40
2
PA
U1
30
6
PAP
503
PA
Q1
03
PAP50
4
PAQ2
03
PAR250
2
PARV101
P
A
U
1
0
1
8
P
A
U
1
0
4
P
A
U
1
0
3
PAU1078PAU1077PAU
1076PAU1075PAU1074PAU
1073
PA
U1
01
7
P
A
U
1
0
1
6
PA
U1
01
5
PARV10
3
PA
U1
01
4
P
A
U
1
0
1
3
PAQ
101
PAR300
1
PA
Q2
01
PAR28
02
PA
Q30
1
PAR2901
PA
Q3
03
PAR270
1
PAR28
01
PAQ
401 PAR3101
PAQ501
PAR3402
PAR
902
PAU
602
PAR1
001
PAU
702
PAR
1102
PAU
706
PAU903
PAR12
01
PAU
802
PAR
1301
PAU
806 PAU904
PAR200
1
PA
U10
02
PAU1
106
PAR210
1 PA
U120
2
PAR
2201
PAU1
206
PA
U1
30
1
PAR
2302
PAU1
102
PAR24
01P
AU
13
08
PAR360
1
PAU1062
PAR370
1
PAU1061
PAR38
01
P
A
U
1
0
6
0
PAR3901
PA
U1
05
9
PAU
603
PAU901
PA
U1
00
1
PAU1
203
PAU1
103
PAU
130
4
PAP2
03
P
A
U
1
0
5
2
PAP2
05
PA
U1
04
7
PAR1901
PAU902
PAC5601
PAP5
02
PA
Q40
3
PAR320
2
PAU1030
PAC5
702
PAP
501
PAQ503
PAR
3502
PAU1029
PAR8
02
PA
U1
07
PAU
606
P
A
U
1
0
8
PAU
703
P
A
U
1
0
6
PAU
803
PAP2
08
PAU1064
PAP2
04
PAU1065PAP20
6
PAU1066
PAC52
01
PA
U1
01
2
PAC
102
PAC
201
PAD101
PA
U2
07
PAD5
0K
PAD6
0K
PAP2
02
PAC3
602
PAR501
PAR60
1
P
A
U
1
0
5
8
PAC370
2
PAR
302
PAR
401
PAU1028
E.3 PCB Bottom Layer 100
E.3 PCB Bottom Layer
PABT102 PABT101
CO
BT
1
PAC
101
PAC
102
CO
C1
PAC2
02
PAC
201
CO
C2
PAC
302PAC3
01
COC
3
PAC
402
PAC
401COC
4
PAC501
PAC502
CO
C5
PAC601
PAC602
CO
C6
PAC702
PAC701
CO
C7
PAC
802PAC8
01
CO
C8
PAC
902
PAC
901
CO
C9 PAC1
001
PAC
100
2
CO
C1
0
PAC1
102
PAC
110
1
CO
C11
PAC
120
2
PAC1
201
CO
C12
PAC13
01
PAC1
302
CO
C1
3
PAC140
2P
AC140
1
CO
C1
4
PAC1502
PAC150
1
CO
C1
5
PAC160
2
PAC160
1C
OC
16
PAC170
2
PAC170
1C
OC
17
PAC180
2
PAC180
1
CO
C1
8
PAC190
2
PAC190
1
CO
C1
9
PAC2002
PAC2001
CO
C2
0
PAC2102
PAC2101
CO
C2
1
PAC22
02
PAC22
01 COC22
PAC23
02
PAC230
1
CO
C2
3
PAC240
2
PAC240
1
CO
C2
4
PAC2
502
PAC25
01COC
25
PAC2
602
PAC2
601
COC26
PAC270
2
PAC2701
CO
C2
7
PAC28
01
PAC280
2
CO
C2
8
PAC
290
2
PAC
290
1 COC29 PAC300
2
PAC
300
1 COC30
PAC3102
PAC310
1
CO
C3
1
PAC
320
1
PAC
320
2 COC32PAC3302 PAC3301COC33
PAC3
402
PAC3
401 COC34
PAC
350
1
PAC
350
2 COC35
PAC3
602
PAC36
01
CO
C3
6
PAC370
2PA
C3701
CO
C3
7
PAC
380
2
PAC3
801
CO
C3
8
PAC3
902
PAC39
01
CO
C3
9
PAC4
002
PAC
400
1COC40
PAC41
01
PAC4
102COC41
PAC42
02
PAC420
1
C
O
C
4
2
PAC4302
PAC430
1CO
C4
3 PAC44
01
PAC4
402
COC44
PAC470
2
PAC4701
CO
C4
7
PAC480
2P
AC480
1 C
OC
48
PAC4
901
PAC
490
2
COC49
PAC5
202
PAC52
01
CO
C5
2
PAC5
302
PAC5
301
CO
C5
3
PAC5
402
PAC5
401
CO
C5
4
PAC550
2PA
C5501C
OC
55
PAC5602
PAC5601
CO
C5
6
PAC5
702
PAC57
01COC57
PAD10
3
PAD102
PAD10
4
PAD101
COD
1PAD20
K PAD20ACOD2 PA
D30A PAD3
0K
CO
D3
PAD4
0A
PAD4
0K
CO
D4
PAD5
0A
PAD5
0KCOD5
PAD6
0A
PAD6
0KCOD6
PAD7
0K
PAD7
0A
CO
D7
PAD8
0K
PAD8
0A
CO
D8
PAD9
0A
PAD9
0K
CO
D9
PAD10
0K
PAD10
0A
CO
D1
0
PAD11
0A
PAD11
0K
CO
D1
1
PAJ10
2
PAJ1
01
COJ
1
PAJ2
02
PAJ2
01
COJ2
PAJ3
02
PAJ3
01
COJ3
PAJ4
02
PAJ4
01
COJ4
PAL102
PAL101
CO
L1
PAL
202
PAL
201
COL
2
PAP1
01
PAP1
02
COP
1
PAP2
02
PAP201
0
PAP2
08
PAP2
04
PAP2
06
PAP2
05
PAP2
03
PAP2
01
PAP2
07
PAP20
9
CO
P2
PAP30
1
PAP3
03
PAP3
02
CO
P3
PAP40
1
PAP40
3
PAP40
2 COP
4
PAP50
4PA
P503
PAP5
02P
AP5
01
CO
P5
PAP60
20
PAP60
17
PAP60
18
PAP601
9
PAP60
16
PAP60
11
PAP6
08
PAP60
9
PAP60
10
PAP6
06
PAP6
05
PAP6
04
PAP6
01
PAP6
02
PAP6
03
PAP6
07
PAP601
4
PAP60
13
PAP60
12
PAP60
15
PAP60
0
CO
P6
PA
Q1
02
PAQ
101
PA
Q1
03
CO
Q1
PA
Q2
02
PA
Q2
01
PAQ2
03
CO
Q2
PA
Q30
2
PA
Q30
1
PA
Q3
03
CO
Q3
PA
Q4
02
PAQ
401
PA
Q40
3
CO
Q4
PAQ502
PAQ501PA
Q503
CO
Q5
PAR
101 PAR1
02
CO
R1
PAR
201
PAR
202 CO
R2
PAR
301
PAR
302 CO
R3
PAR
401
PAR
402
CO
R4
PAR501
PAR502
CO
R5
PAR60
1PA
R602
CO
R6
PAR
702
PAR
701
CO
R7
PAR8
02
PAR801
CO
R8
PAR
901
PAR
902
CO
R9
PAR1
002
PAR1
001COR10
PAR
1101
PAR
1102 COR11
PAR120
2
PAR12
01
CO
R1
2
PAR
1302
PAR
1301COR13
PAR140
2
PAR140
1
CO
R1
4
PAR150
2
PAR150
1C
O
R
15
PAR1602
PAR1601
CO
R1
6
PAR170
2
PAR170
1 C
OR
17
PAR1802
PAR1801
CO
R1
8
PAR1902
PAR1901
CO
R1
9
PAR2002
PAR200
1
CO
R2
0
PAR2102
PAR210
1
CO
R2
1
PAR22
02
PAR
2201 COR22PAR2302 PAR2301 COR23
PAR240
2P
AR240
1
CO
R2
4
PAR2501
PAR250
2
CO
R2
5
PAR2602
PAR260
1
CO
R2
6
PAR270
2PA
R2701C
OR
27
PAR28
02
PAR28
01 CO
R2
8
PAR2902
PAR2901
CO
R2
9
PAR300
2
PAR300
1
CO
R3
0
PAR3102
PAR3101
CO
R3
1
PAR320
2
PAR320
1C
OR
32
PAR330
2
PAR3301
CO
R3
3
PAR3402
PAR340
1CO
R3
4
PAR
3502 PAR35
01COR35
PAR36
02
PAR360
1 COR
36
PAR370
2
PAR370
1 COR
37
PAR38
02
PAR38
01
CO
R3
8
PAR390
2PA
R3901
CO
R3
9
PAR400
2
PAR400
1 COR
40
PARV10
2
PARV10
3
PARV101
CO
RV
1
P
A
U
1
0
1
PA
U1
02
P
A
U
1
0
3
P
A
U
1
0
4
PA
U1
05
P
A
U
1
0
6
PA
U1
07
P
A
U
1
0
8
P
A
U
1
0
9
PA
U1
01
0
P
A
U
1
0
1
1
PA
U1
01
2
P
A
U
1
0
1
3
PA
U1
01
4
PA
U1
01
5
P
A
U
1
0
1
6
PA
U1
01
7
P
A
U
1
0
1
8
PA
U1
01
9
P
A
U
1
0
2
0
PAU1021PAU1022PAU1023PAU1
024PAU1025PAU1026PAU1027P
AU1028PAU1029PAU1030
PAU1031PAU1032PAU1033PAU1
034PAU1035PAU1036PAU1
037PAU1038PAU1039PAU104
0PAU1
0
4
1
PA
U1
04
2
P
A
U
1
0
4
3
PA
U1
04
4
P
A
U
1
0
4
5
PA
U1
04
6
PA
U1
04
7
P
A
U
1
0
4
8
PA
U1
04
9
P
A
U
1
0
5
0
PA
U1
05
1
P
A
U
1
0
5
2
P
A
U
1
0
5
3
PA
U1
05
4
P
A
U
1
0
5
5
PA
U1
05
6
P
A
U
1
0
5
7
P
A
U
1
0
5
8
PA
U1
05
9
P
A
U
1
0
6
0
PAU1061PAU1062PAU1063PAU1064PAU1065PAU1066PAU1067PAU1068PAU1069PAU1070PAU1071PAU1072PAU1073PAU1074PAU1075PAU1076PAU1077PAU1078PAU1079PAU1080
COU
1
PA
U2
01
PA
U2
02
PA
U2
03
PA
U2
04
PA
U2
08
PA
U2
07
PA
U2
06
PA
U2
05
CO
U2
PAU
304
PAU
305
PAU
303PAU3
02
PAU
301CO
U3
PAU401
PAU403
PAU402
PAU404
CO
U4
PAU504
PAU502
PAU503
PAU501
CO
U5
PAU
605
PAU
606
PAU
607
PA
U60
8
PAU
603
PAU
602
PAU
604
PA
U60
1
CO
U6
PAU
701
PAU
704
PAU
702
PAU
703
PAU
708
PAU
707
PAU
706
PAU
705
CO
U7
PAU
805
PAU
806
PAU
807
PAU
808
PAU
803
PAU
802
PAU
804
PAU
801COU8
PAU901
PAU902PA
U903PAU
904
PAU908
PAU907PA
U906PAU
905
CO
U9
PA
U10
07
PA
U1
00
6
PA
U10
05
PA
U1
00
1
PA
U10
02
PA
U1
00
3
PA
U1
00
4
PA
U10
012
PA
U1
00
13
PA
U10
014
PA
U1
00
18
PA
U10
017
PA
U1
00
16
PA
U1
00
15
PA
U1
00
11
PA
U1
00
10
PA
U1
00
8
PA
U1
00
9
CO
U1
0
PAU
110
5
PAU1
106
PAU1
107
PAU
110
8
PAU1
103
PAU1
102
PAU
110
4
PAU
110
1
CO
U1
1
PAU1
205
PAU1
206
PAU1
207
PAU
120
8
PAU1
203
PAU1
202
PAU1
204
PAU
120
1
CO
U1
2
PAU
130
5
PA
U1
30
6
PAU
130
7
PA
U1
30
8
PAU
130
4
PA
U1
30
3
PAU
130
2
PA
U1
30
1
CO
U1
3
PAX101PAX102 C
OX
1
PAX201PAX202
CO
X2
PAC1
201
PAC13
01
PAC14
01
PAC150
1
PAC180
1
PAC190
1
PAC230
1
PAC240
2
PAC280
2
PAC3102
PAC3
801
PAC39
01
PAR801
PAR1
002
PAR120
2
PAR2002 PAR2102
PAU
304
PAU402
PAU502PAU60
7
PA
U60
8
PA
U1
00
18
PAU1
107
PAU
110
8
PAC
400
1
PAC4
102
PAC550
2
PAL
202
PA
Q1
02
PA
Q2
02
PAR2602
PAR270
2
PAR3301
PAU1025
PAC160
1
PAC170
1
PAC2701
PAC
290
2
PAC3
002
PAR22
02
PAR
2301
PAU404PAU
1207
PAU
120
8
PA
U1
30
3
PAC
901
PAC
100
2
PAD3
0K
PAD4
0K
PA
U2
04
PAU
301
PAC2001PAC2101
PAC22
02
PAC
320
2
PAC
330
2
PAC3
402
PAR
901
PAR
1101
PAR
1302
PAR140
1
PAU504
PAU
707
PAU
708
PAU
807
PAU
808
PAU908
PAC501 PAC601PAC702
PAD3
0A
PAD5
0A
PAD11
0A
PAL102 PAR502PAR2501
PAJ2
01
PAR150
1
PAU906
PAJ3
02
PAR1601
PAU907
PA
U1
05
4
PA
U1
00
16
P
A
U
1
0
5
7
PA
U10
012
P
A
U
1
0
5
3
PA
U10
017
PA
U1
04
4
PA
U1
00
13
P
A
U
1
0
4
5
PA
U1
00
15
PA
U1
04
6
PA
U10
014
PAR260
1
PAR2902PAR3002PAR3102
PAU1034
PAR330
2
PAR340
1
PAU1033
PAR
702
PAU1027
PAU
303
PABT102
PAC
101
PAC2
02
PAC
401
PAC502 PAC602PAC701
PAC8
01
PAC
902
PAC1
001
PAC
110
1
PAC
120
2P
AC13
02
PAC140
2PAC1502
PAC180
2
PAC190
2
PAC23
02 PAC240
1
PAC2
502
PAC2
602
PAC28
01
PAC310
1
PAC
350
1
PAC36
01
PAC3701
PAC
380
2
PAC3
902
PAC4
002
PAC41
01
PAC420
1PAC43
01
PAC44
01
PAC4701P
AC480
1 PAC4
901
PAC5
202
PAC5
301
PAC5
401
PAC550
1
PAC57
01
PAD102PAD20A
PAD7
0K
PAD8
0K
PAD9
0K
PAD10
0K
PAJ1
01
PAP20
9
PAP201
0
PA
Q30
2 PAQ502
PAR
301
PAR602
PAR
701
PAR35
01
PAR400
1
PARV10
2
P
A
U
1
0
1
1
PAU1026
PAU1031
PA
U1
05
1
PAU1070
PA
U2
06
PAU3
02
PAU401
PAU501
PAU
605
PA
U1
00
9
PAU
110
5
PAC160
2
PAC170
2
PAC270
2
PAC
290
1
PAC
300
1
PAP40
3
PAR240
2
PAU403
PAU1
205
PAU
130
2
PAC2002PAC2102
PAC22
01
PAC
320
1
PAC
330
1
PAC3
401 PAP3
03
PAR1802
PAR1902
PAU503
PAU
705
PAU
805 PAU905
PAP2
07
PAR
201 PA
U
1
0
9
PAC42
02
PAC4302
PAC4
402
PAC470
2
PAC480
2
PAC
490
2
PAL
201
PAP2
01
PAR1
02
PAU1032
P
A
U
1
0
4
8
PAU1071
PABT101
PAC
802
PAD4
0A
PAD6
0A
PAR
402
PAC3
01
PA
U2
01
PAC
302
PAD20K
PAL101
PA
U2
08
PAC
402
PA
U2
02
PAC1
102 PAU305
PAC25
01
PA
U1
00
8
PAX201
PAC2
601
PA
U10
07
PAX202
PAC
350
2
PAJ10
2
PAR
101
PAR
202
PAC5
302
P
A
U
1
0
5
0
PAX102
PAC5
402
PA
U1
04
9
PAX101
PAC5602 PAQ4
02
PAR320
1
PAD10
3
PAP1
01
PAD10
4
PAP1
02
PAD7
0A PAR360
2
PAD8
0A PAR370
2
PAD9
0A
PAR38
02
PAD10
0A
PAR390
2
PAD11
0K PAR4
002
PAJ2
02
PAR140
2
PAJ3
01
PAR1801
PAJ4
01
PAR170
1
PAJ4
02
PAP30
1
PAR150
2
PAP3
02
PAR1602PAR1702
PAP40
1
PAU
130
7
PAP40
2
PA
U1
30
6
PAP
503
PA
Q1
03
PAP50
4
PAQ2
03
PAR250
2
PARV101
P
A
U
1
0
1
8
P
A
U
1
0
4
P
A
U
1
0
3
PAU1078PAU1077PAU
1076PAU1075PAU1074PAU
1073
PA
U1
01
7
P
A
U
1
0
1
6
PA
U1
01
5
PARV10
3
PA
U1
01
4
P
A
U
1
0
1
3
PAQ
101
PAR300
1
PA
Q2
01
PAR28
02
PA
Q30
1
PAR2901
PA
Q3
03
PAR270
1
PAR28
01
PAQ
401 PAR3101
PAQ501
PAR3402
PAR
902
PAU
602
PAR1
001
PAU
702
PAR
1102
PAU
706
PAU903
PAR12
01
PAU
802
PAR
1301
PAU
806 PAU904
PAR200
1
PA
U10
02
PAU1
106
PAR210
1 PA
U120
2
PAR
2201
PAU1
206
PA
U1
30
1
PAR
2302
PAU1
102
PAR24
01P
AU
13
08
PAR360
1
PAU1062
PAR370
1
PAU1061
PAR38
01
P
A
U
1
0
6
0
PAR3901
PA
U1
05
9
PAU
603
PAU901
PA
U1
00
1
PAU1
203
PAU1
103
PAU
130
4
PAP2
03
P
A
U
1
0
5
2
PAP2
05
PA
U1
04
7
PAR1901
PAU902
PAC5601
PAP5
02
PA
Q40
3
PAR320
2
PAU1030
PAC5
702
PAP
501
PAQ503
PAR
3502
PAU1029
PAR8
02
PA
U1
07
PAU
606
P
A
U
1
0
8
PAU
703
P
A
U
1
0
6
PAU
803
PAP2
08
PAU1064
PAP2
04
PAU1065PAP20
6
PAU1066
PAC52
01
PA
U1
01
2
PAC
102
PAC
201
PAD101
PA
U2
07
PAD5
0K
PAD6
0K
PAP2
02
PAC3
602
PAR501
PAR60
1
P
A
U
1
0
5
8
PAC370
2
PAR
302
PAR
401
PAU1028
E.4 PCB 3D Top Layer 101
E.4 PCB 3D Top Layer
E.5 PCB 3D Bottom Layer 102
E.5 PCB 3D Bottom Layer
Appendix F
Results and Discussion
Supporting Information
Put all the stuff here
F.1 Click Board Schematics 104
F.1 Click Board Schematics
This is the schematics of the click boards used in testing. They can be compared to the
hardware design of the bridge.
RS-485 Click Board (MikroeElektronika 2012b).
Figure F.1: RS-485 Click board schematic
F.1 Click Board Schematics 105
CANSpi Click Board (MikroeElektronika 2012a).
Figure F.2: CANSpi Click board schematic
F.2 Photos 106
F.2 Photos
RS-485 physical layer test image.
Figure F.3: RS-485 testing set-up
F.3 Code Listings 107
F.3 Code Listings
The following code was used in an attempt to diagnose the error with CAN transmission
from the USB-CAN module to the development board with the bridge source code. It was
not successful, however it would be ideal to further explore this as a debugging option.
Listing F.1: CANSPI Error Fetch.
// Code appended to ProjectDevBoard . c
// Intended to grab the error code from the CANSPI ch ip
// And d i s p l a y i t on Port F LEDs o f the development board
Msg Rcvd = 0 ;
Delay us ( 1 0 0 ) ;
CanSpi CS = 0 ;
Delay us ( 1 0 0 ) ;
SPI1 Write (0 b10100000 ;
SPI1 Read ( Msg Rcvd ) ;
LATF = Msg Rcvd ;
CanSpi CS = 1 ;
Delay us ( 2 0 0 ) ;
Msg Rcvd = 0 ;
Appendix G
Datasheets
G.1 PIC18F87K22 109
G.1 PIC18F87K22
 2009-2011 Microchip Technology Inc. DS39960D-page 3
PIC18F87K22 FAMILY
Low-Power Features:
• Power-Managed modes:
- Run: CPU on, peripherals on
- Idle: CPU off, peripherals on
- Sleep: CPU off, peripherals off
• Two-Speed Oscillator Start-up
• Fail-Safe Clock Monitor
• Power-Saving Peripheral Module Disable (PMD)
• Ultra Low-Power Wake-up
• Fast Wake-up, 1 s Typical
• Low-Power WDT, 300 nA Typical
• Ultra Low 50 nA Input Leakage
• Run mode Currents Down to 5.5 A, Typical
• Idle mode Currents Down to 1.7 A Typical
• Sleep mode Currents Down to Very Low 20 nA, 
Typical
• RTCC Current Downs to Very Low 700 nA, 
Typical
Special Microcontroller Features:
• Operating Voltage Range: 1.8V to 5.5V
• On-Chip 3.3V Regulator
• Operating Speed up to 64 MHz
• Up to 128 Kbytes On-Chip Flash Program 
Memory
• Data EEPROM of 1,024 Bytes
• 4K x 8 General Purpose Registers (SRAM)
• 10,000 Erase/Write Cycle Flash Program 
Memory, Minimum
• 1,000,000 Erase/write Cycle Data EEPROM 
Memory, Typical
• Flash Retention: 40 Years, Minimum
• Three Internal Oscillators: LF-INTRC (31 kHz), 
MF-INTOSC (500 kHz) and HF-INTOSC 
(16 MHz)
• Self-Programmable under Software Control
• Priority Levels for Interrupts
• 8 x 8 Single-Cycle Hardware Multiplier
• Extended Watchdog Timer (WDT):
- Programmable period from 4 ms to 4,194s 
(about 70 minutes)
• In-Circuit Serial Programming™ (ICSP™) via 
Two Pins
• In-Circuit Debug via Two Pins
• Programmable:
- BOR
- LVD
Device
Program Memory Data Memory
I/O
12-Bit
A/D 
(ch)
CCP/
ECCP
(PWM)
MSSP
EU
SA
R
T
C
om
pa
ra
to
rs
Ti
m
er
s
8/
16
-B
it
Ex
te
rn
al
 B
us
C
TM
U
R
TC
C
Flash
(bytes)
# Single-Word
Instructions
 SRAM
(bytes)
EEPROM
(bytes) SPI
Master
I2C™
PIC18F65K22 32K 16,383 2K 1K 53 16 5/3 2 Y Y 2 3 4/4 N Y Y
PIC18F66K22 64K 32,768 4K 1K 53 16 7/3 2 Y Y 2 3 6/5 N Y Y
PIC18F67K22 128K 65,536 4K 1K 53 16 7/3 2 Y Y 2 3 6/5 N Y Y
PIC18F85K22 32K 16,383 2K 1K 69 24 5/3 2 Y Y 2 3 4/4 Y Y Y
PIC18F86K22 64K 32,768 4K 1K 69 24 7/3 2 Y Y 2 3 6/5 Y Y Y
PIC18F87K22 128K 65,536 4K 1K 69 24 7/3 2 Y Y 2 3 6/5 Y Y Y
64/80-Pin, High-Performance, 1-Mbit Enhanced Flash MCUs 
with 12-Bit A/D and nanoWatt XLP Technology
G.1 PIC18F87K22 110
PIC18F87K22 FAMILY
DS39960D-page 6  2009-2011 Microchip Technology Inc.
Pin Diagrams – PIC18F8XK22
3
4
5
6
7
8
9
10
11
12
13
14
15
16
48
47
46
45
44
43
42
41
4039
64 63 62 61
21 22 23 24 25 26 27 28 29 30 31 32
R
E
2/
P
2B
/C
C
P
10
(2
) /C
S
/A
D
10
R
E
4/
P
3B
/C
C
P
8(
3)
/A
D
12
R
E
5/
P
1C
/C
C
P
7(
3)
/A
D
13
R
E
6/
P
1B
/C
C
P
6(
3)
/A
D
14
R
E
7/
E
C
C
P
2/
P
2A
/A
D
15
R
D
0/
P
S
P
0/
C
TP
LS
/A
D
0
V
D
D
V
S
S
R
D
1/
T5
C
K
I/T
7G
/P
S
P
1/
A
D
1
R
D
2/
P
S
P
2/
A
D
2
R
D
3/
P
S
P
3/
A
D
3
R
D
4/
S
D
O
2/
P
S
P
4/
A
D
4
R
D
5/
S
D
I2
/S
D
A
2/
P
S
P
5/
A
D
5
R
D
6/
S
C
K
2/
S
C
L2
/P
S
P
6/
A
D
6
R
D
7/
S
S
2/
P
S
P
7/
A
D
7
RE1/P2C/WR/AD9
RE0/P2D/RD/AD8
RG0/ECCP3/P3A
RG1/TX2/CK2/AN19/C3OUT
RG2/RX2/DT2/AN18/C3INA
RG3/CCP4/AN17/P3D/C3INB
MCLR/RG5
RG4/RTCC/T7CKI(2)/T5G/CCP5/AN16/P1D/C3INC
VSS
VDDCORE/VCAP
RF7/AN5/SS1
RB0/INT0/FLT0
RB1/INT1
RB2/INT2/CTED1
RB3/INT3/CTED2/ECCP2(1)/P2A
RB4/KBI0
RB5/KBI1/T3CKI/T1G
RB6/KBI2/PGC
VSS
OSC2/CLKO/RA6
OSC1/CLKI/RA7
VDD
RB7/KBI3/PGD
RC4/SDI1/SDA1
RC3/SCK1/SCL1
RC2/ECCP1/P1A
E
N
V
R
E
G
R
F1
/A
N
6/
C
2O
U
T/
C
TD
IN
AV
D
D
AV
S
S
R
A
3/
A
N
3/
VR
E
F+
R
A
2/
A
N
2/
VR
E
F-
R
A
1/
A
N
1
R
A
0/
A
N
0/
U
LP
W
U
V
S
S
V
D
D
R
A
4/
T0
C
K
I
R
A
5/
A
N
4/
T1
C
K
I/T
3G
/H
LV
D
IN
R
C
1/
S
O
S
C
/E
C
C
P
2/
P
2A
R
C
0/
S
O
S
C
O
/S
C
K
LI
R
C
7/
R
X
1/
D
T1
R
C
6/
TX
1/
C
K
1
RC5/SDO1
R
J0
/A
LE
R
J1
/O
E
R
H
1/
A
N
22
/A
17
R
H
0/
A
N
23
/A
16
1
2
RH2/AN21/A18
RH3/AN20/A19
17
18
RH7/CCP6(3)/P1B/AN15
RH6/CCP7(3)/P1C/AN14/C1INC
R
H
5/
C
C
P
8(
3)
/P
3B
/A
N
13
/C
2I
N
D
R
H
4/
C
C
P
9(
2,
3)
/P
3C
/A
N
12
/C
2I
N
C
R
J5
/C
E
R
J4
/B
A
0
37
RJ7/UB
RJ6/LB
50
49
RJ2/WRL
RJ3/WRH
19
20
33 34 35 36 38
58
57
56
55
54
53
52
51
60
59
68 67 66 6572 71 70 6974 7378 77 76 757980
80-Pin TQFP
RF5/AN10/C1INB
RF4/AN9/C2INA
RF3/AN8/C2INB/CTMUI
RF2/AN7/C1OUT
RF6/AN11/C1INA
PIC18F85K22
PIC18F86K22
PIC18F87K22
Note 1: The ECCP2 pin placement depends on the CCP2MX Configuration bit setting and whether the device is
in Microcontroller or Extended Microcontroller mode.
2: Not available on the PIC18F65K22 and PIC18F85K22 devices.
3: The CC6, CCP7, CCP8 and CCP9 pin placement depends on the setting of the ECCPMX Configuration
bit (CONFIG3H<1>).
R
E
3/
P
3C
/C
C
P
9(
2,
3)
/ R
E
F0
/A
D
11
G.1 PIC18F87K22 111
 2009-2011 Microchip Technology Inc. DS39960D-page 37
PIC18F87K22 FAMILY
2.0 GUIDELINES FOR GETTING 
STARTED WITH PIC18FXXKXX 
MICROCONTROLLERS
2.1 Basic Connection Requirements
Getting started with the PIC18F87K22 family family of
8-bit microcontrollers requires attention to a minimal
set of device pin connections before proceeding with
development. 
The following pins must always be connected:
• All VDD and VSS pins 
(see Section 2.2 “Power Supply Pins”)
• All AVDD and AVSS pins, regardless of whether or 
not the analog device features are used 
(see Section 2.2 “Power Supply Pins”)
• MCLR pin 
(see Section 2.3 “Master Clear (MCLR) Pin”)
• ENVREG (if implemented) and VCAP/VDDCORE pins 
(see Section 2.4 “Voltage Regulator Pins 
(ENVREG and VCAP/VDDCORE)”) 
These pins must also be connected if they are being
used in the end application:
• PGC/PGD pins used for In-Circuit Serial 
Programming™ (ICSP™) and debugging purposes 
(see Section 2.5 “ICSP Pins”)
• OSCI and OSCO pins when an external oscillator 
source is used 
(see Section 2.6 “External Oscillator Pins”)
Additionally, the following pins may be required:
• VREF+/VREF- pins are used when external voltage 
reference for analog modules is implemented
The minimum mandatory connections are shown in
Figure 2-1.
FIGURE 2-1: RECOMMENDED 
MINIMUM CONNECTIONS
Note: The AVDD and AVSS pins must always be
connected, regardless of whether any of
the analog modules are being used.
PIC18FXXKXX
V
D
D
V
S
S
VDD
VSS
VSS
VDD
AV
D
D
AV
S
S
V
D
D
V
S
S
C1
R1
VDD
MCLR
VCAP/VDDCORE
R2
ENVREG
(1)
C7(2)
C2(2)
C3(2)
C4(2)C5(2)
C6(2)
Key (all values are recommendations):
C1 through C6: 0.1 F, 20V ceramic
R1: 10 kΩ
R2: 100Ω to 470Ω
Note 1: See Section 2.4 “Voltage Regulator Pins 
(ENVREG and VCAP/VDDCORE)” for 
explanation of ENVREG pin connections.
2: The example shown is for a PIC18F device 
with five VDD/VSS and AVDD/AVSS pairs. 
Other devices may have more or less pairs; 
adjust the number of decoupling capacitors 
appropriately.
(1)
G.1 PIC18F87K22 112
PIC18F87K22 FAMILY
DS39960D-page 38  2009-2011 Microchip Technology Inc.
2.2 Power Supply Pins
2.2.1 DECOUPLING CAPACITORS
The use of decoupling capacitors on every pair of
power supply pins, such as VDD, VSS, AVDD and
AVSS, is required. 
Consider the following criteria when using decoupling
capacitors:
• Value and type of capacitor: A 0.1 F (100 nF), 
10-20V capacitor is recommended. The capacitor 
should be a low-ESR device, with a resonance 
frequency in the range of 200 MHz and higher. 
Ceramic capacitors are recommended.
• Placement on the printed circuit board: The 
decoupling capacitors should be placed as close 
to the pins as possible. It is recommended to 
place the capacitors on the same side of the 
board as the device. If space is constricted, the 
capacitor can be placed on another layer on the 
PCB using a via; however, ensure that the trace 
length from the pin to the capacitor is no greater 
than 0.25 inch (6 mm).
• Handling high-frequency noise: If the board is 
experiencing high-frequency noise (upward of 
tens of MHz), add a second ceramic type capaci-
tor in parallel to the above described decoupling 
capacitor. The value of the second capacitor can 
be in the range of 0.01 F to 0.001 F. Place this 
second capacitor next to each primary decoupling 
capacitor. In high-speed circuit designs, consider 
implementing a decade pair of capacitances as 
close to the power and ground pins as possible 
(e.g., 0.1 F in parallel with 0.001 F).
• Maximizing performance: On the board layout 
from the power supply circuit, run the power and 
return traces to the decoupling capacitors first, 
and then to the device pins. This ensures that the 
decoupling capacitors are first in the power chain. 
Equally important is to keep the trace length 
between the capacitor and the power pins to a 
minimum, thereby reducing PCB trace 
inductance.
2.2.2 TANK CAPACITORS
On boards with power traces running longer than
six inches in length, it is suggested to use a tank capac-
itor for integrated circuits, including microcontrollers, to
supply a local power source. The value of the tank
capacitor should be determined based on the trace
resistance that connects the power supply source to
the device, and the maximum current drawn by the
device in the application. In other words, select the tank
capacitor so that it meets the acceptable voltage sag at
the device. Typical values range from 4.7 F to 47 F.
2.3 Master Clear (MCLR) Pin
The MCLR pin provides two specific device
functions: Device Reset, and Device Programming
and Debugging. If programming and debugging are
not required in the end application, a direct
connection to VDD may be all that is required. The
addition of other components, to help increase the
application’s resistance to spurious Resets from
voltage sags, may be beneficial. A typical
configuration is shown in Figure 2-1. Other circuit
designs may be implemented, depending on the
application’s requirements.
During programming and debugging, the resistance
and capacitance that can be added to the pin must
be considered. Device programmers and debuggers
drive the MCLR pin. Consequently, specific voltage
levels (VIH and VIL) and fast signal transitions must
not be adversely affected. Therefore, specific values
of R1 and C1 will need to be adjusted based on the
application and PCB requirements. For example, it is
recommended that the capacitor, C1, be isolated
from the MCLR pin during programming and
debugging operations by using a jumper (Figure 2-2).
The jumper is replaced for normal run-time
operations.
Any components associated with the MCLR pin
should be placed within 0.25 inch (6 mm) of the pin.
FIGURE 2-2: EXAMPLE OF MCLR PIN 
CONNECTIONS
Note 1: R1  10 k is recommended. A suggested
starting value is 10 k. Ensure that the
MCLR pin VIH and VIL specifications are met.
2: R2  470 will limit any current flowing into
MCLR from the external capacitor, C, in the
event of MCLR pin breakdown, due to
Electrostatic Discharge (ESD) or Electrical
Overstress (EOS). Ensure that the MCLR pin
VIH and VIL specifications are met.
C1
R2
R1
VDD
MCLR
PIC18FXXKXXJP
G.2 DF04S 113
G.2 DF04S
D
F005S - D
F10S —
 B
ridge R
ectifiers
© 1998 Fairchild Semiconductor Corporation   www.fairchildsemi.com
DF005S - DF10S Rev. 1.5  
May 2015
DF005S - DF10S
Bridge Rectifiers
Features
• Maximum Surge Rating: IFSM = 50 A
                                           I2t = 10 A2Sec
• Optimized VF: Typical 0.94 V at 1.5 A, 25°C
• Glass Passivated Junctions
• Lead Free Compliant to EU RoHS 2002/95/EU Directives
• Green Molding Compound: IEC61249 
• Qualified with IR Reflow and Wave Soldering
• UL Certified, UL #E258596
Ordering Information
Part Number Top Mark Package Packing Method
DF005S DF005S SDIP 4L Tape and Reel
DF01S DF01S SDIP 4L Tape and Reel
DF02S DF02S SDIP 4L Tape and Reel
DF04S DF04S SDIP 4L Tape and Reel
DF06S DF06S SDIP 4L Tape and Reel
DF08S DF08S SDIP 4L Tape and Reel
DF10S DF10S SDIP 4L Tape and Reel
Description
With the ever-pressing need to improve power supply
efficiency, improve surge rating, improve reliability, and
reduce size, the DFxS family sets a standard in perfor-
mance.
The design offers an surge rating of 50 A. This is impor-
tant when improving reliability and increasing efficiency.
High efficiency designs strive to reduce circuit resis-
tance, which, unfortunately can result in increased
inrush surge. As such high surge current ratings can be
required to maintain or improve reliability.
The design also offers better efficiency by achieving a
1.5 A VF of 1.1 V maximum at 25°C. This lower VF also
supports cooler and more efficient operation.
Finally, the DFxS achieves all this in a SDIP surface
mount form factor, reducing board space and volumetric
requirements vs. competitive devices.
+
-~
~
IN
OUT
SDIP
G.2 DF04S 114
D
F005S - D
F10S —
 B
ridge R
ectifiers
© 1998 Fairchild Semiconductor Corporation   www.fairchildsemi.com
DF005S - DF10S Rev. 1.5 2 
Absolute Maximum Ratings
Stresses exceeding the absolute maximum ratings may damage the device. The device may not function or be opera-
ble above the recommended operating conditions and stressing the parts to these levels is not recommended. In addi-
tion, extended exposure to stresses above the recommended operating conditions may affect device reliability. The
absolute maximum ratings are stress ratings only. Values are at TA = 25°C unless otherwise noted. 
Thermal Characteristics
Values are at TA = 25°C unless otherwise noted.
Notes:
1. Device mounted on PCB with 0.5 inch × 0.5 inch (13 mm × 13 mm).
2. The thermal resistances (RθJA & ψJL) are characterized with the device mounted on the following FR4 printed circuit
    boards, as shown in Figure 1 and Figure 2. PCB size: 76.2 x 114.3 mm.
    Heating effect from adjacent dice is considered and only two dices are powered at the same time.
Symbol Parameter
Value
Unit
DF005S DF01S DF02S DF04S DF06S DF08S DF10S
VRRM Maximum Repetitive Reverse Voltage 50 100 200 400 600 800 1000 V
VRMS Maximum RMS Bridge Input Voltage 35 70 140 280 420 560 700 V
VDC DC Reverse Voltage at Rated IR 50 100 200 400 600 800 1000 V
IF(AV)
Average Rectified Forward Current 
at TA = 40°C
1.5 A
IFSM
Non-Repetitive Peak Forward Surge
Current
8.3 ms Single Half-Sine Wave 
50 A
TSTG Storage Temperature Range -55 to +150 °C
TJ Operating Junction Temperature -55 to +150 °C
Symbol Parameter Value Unit
PD Power Dissipation 3.1 W
RθJA
Thermal Resistance, 
Junction-to-Ambient
Single-Die Measurement(1)
(Maximum Land Pattern: 13 x 13 mm) 62
°C/WMulti-Die Measurement
(2)
(Maximum Land Pattern: 13 x 13 mm) 50
Multi-Die Measurement(2)
(Minimum Land Pattern: 1.3 x 1.5 mm) 105
ψJL
Thermal Characterization
Parameter, Junction to Lead
Single-Die Measurement(2)
(Maximum and Minimum Land Pattern) 27 °C/W
Figure 1. Maximum Pads of 2 oz Copper Figure 2. Minimum Pads of 2 oz Copper
F
F
S
S
F
F
S
S
G.3 HCPL-2601.S 115
G.3 HCPL-2601.S
 
©2005 Fairchild Semiconductor Corporation
 
1
 
www.fairchildsemi.com
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611 Dual-Channel: HCPL-2630, HCPL-2631 Rev. 1.0.5
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611 Dual-Channel: HCPL-2630, HCPL-2631  High Speed-10 M
Bit/s Logic Gate Optocouplers
tm
 
July 2006
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611
Dual-Channel: HCPL-2630, HCPL-2631
High Speed-10 MBit/s Logic Gate Optocouplers
 
Features
 
■
 
Very high speed-10 MBit/s 
 
■
 
Superior CMR-10 kV/µs
 
■
 
Double working voltage-480V
 
■
 
Fan-out of 8 over -40°C to +85°C
 
■
 
Logic gate output
 
■
 
Strobable output
 
■
 
Wired OR-open collector
 
■
 
U.L. recognized (File # E90700)
 
Applications
 
■
 
Ground loop elimination 
 
■
 
LSTTL to TTL, LSTTL or 5-volt CMOS
 
■
 
Line receiver, data transmission
 
■
 
Data multiplexing
 
■
 
Switching power supplies
 
■
 
Pulse transformer replacement
 
■
 
Computer-peripheral interface
 
Description
 
The 6N137, HCPL-2601/2611 single-channel and HCPL-2630/
2631 dual-channel optocouplers consist of a 850 nm AlGaAS
LED, optically coupled to a very high speed integrated photo-
detector logic gate with a strobable output. This output features
an open collector, thereby permitting wired OR outputs. The
coupled parameters are guaranteed over the temperature range
of -40°C to +85°C. A maximum input signal of 5 mA will provide
a minimum output sink current of 13mA (fan out of 8).
An internal noise shield provides superior common mode rejec-
tion of typically 10kV/µs. The HCPL- 2601 and HCPL- 2631 has
a minimum CMR of 5 kV/µs. The HCPL-2611 has a minimum
CMR of 10 kV/µs.
 
Package Schematic
Truth Table (Positive Logic)
 
A 0.1µF bypass capacitor must be connected between pins 8 and 5. (See note 1)
8
8
1
8
1
1
1
2
3
4 5
6
7
8N/C
_
VCC
V
E
VO
GND
+
N/C
V
F
1
2
3
4 5
6
7
8+
_
V
F1
VCC
V
01
V
02
GND
V
F2
_
+
HCPL-2630
HCPL-2631
6N137
HCPL-2601
HCPL-2611
 
Input Enable Output 
 
H H L 
L H H 
H L H 
L L H 
H NC L 
L NC H 
G.3 HCPL-2601.S 116
 
2
 
www.fairchildsemi.com
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611 Dual-Channel: HCPL-2630, HCPL-2631 Rev. 1.0.5
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611 Dual-Channel: HCPL-2630, HCPL-2631  High Speed-10 M
Bit/s Logic Gate Optocouplers
 
Absolute Maximum Ratings
 
 (T
 
A
 
 = 25°C unless otherwise specified)
 
Recommended Operating Conditions
 
*6.3mA is a guard banded value which allows for at least 20% CTR degradation. Initial input current threshold value is
5.0 mA or less.
 
Parameter Symbol Value Units
 
Storage Temperature T
 
STG
 
-55 to +125 °C
Operating Temperature T
 
OPR
 
-40 to +85 °C
Lead Solder Temperature T
 
SOL
 
260 for 10 sec °C
 
EMITTER
 
DC/Average Forward Single Channel I
 
F
 
50 mA
Input Current Dual Channel (Each Channel) 30
Enable Input Voltage
Not to exceed V
 
CC
 
 by more than 500 mV
Single Channel V
 
E
 
5.5 V
Reverse Input Voltage Each Channel V
 
R
 
5.0 V
Power Dissipation Single Channel P
 
I
 
100 mW
Dual Channel (Each Channel)
 
45
 
DETECTOR
 
Supply Voltage V
 
CC
 
(1 minute max)
7.0 V
Output Current Single Channel I
 
O
 
50 mA
Dual Channel (Each Channel) 50
Output Voltage Each Channel V
 
O
 
7.0 V
Collector Output Single Channel P
 
O
 
85 mW
Power Dissipation Dual Channel (Each Channel) 60
 
Parameter Symbol Min Max Units
 
Input Current, Low Level I
 
FL
 
0 250 µA
Input Current, High Level I
 
FH
 
*6.3 15 mA
Supply Voltage, Output V
 
CC
 
4.5 5.5 V
Enable Voltage, Low Level V
 
EL
 
0 0.8 V
Enable Voltage, High Level V
 
EH
 
2.0 V
 
CC
 
V
Low Level Supply Current T
 
A
 
-40 +85 °C
Fan Out (TTL load) N 8
G.3 HCPL-2601.S 117
 
3
 
www.fairchildsemi.com
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611 Dual-Channel: HCPL-2630, HCPL-2631 Rev. 1.0.5
 
Single-Channel: 6N137, HCPL-2601, HCPL-2611 Dual-Channel: HCPL-2630, HCPL-2631  High Speed-10 M
Bit/s Logic Gate Optocouplers
 
Electrical Characteristics
 
 (T
 
A
 
 = 0 to 70°C Unless otherwise specified)
 
Individual Component Characteristics
Switching Characteristics
 
 (T
 
A
 
 = -40°C to +85°C, V
 
CC
 
 = 5 V, I
 
F
 
 = 7.5 mA Unless otherwise specified)
 
Parameter Test Conditions Symbol Min Typ** Max Unit
 
EMITTER
 
(I
 
F
 
 = 10mA) V
 
F
 
1.8 V
Input Forward Voltage T
 
A
 
 =  25°C 1.4 1.75
Input Reverse Breakdown Voltage (I
 
R
 
 = 10µA) B
 
VR
 
5.0 V
Input Capacitance (V
 
F
 
 = 0, f = 1 MHz) C
 
IN
 
60 pF
Input Diode Temperature Coefficient (I
 
F
 
 = 10mA)
 
∆
 
V
 
F
 
/
 
∆
 
T
 
A
 
-1.4 mV/°C
 
DETECTOR
 
High Level Supply Current Single Channel (V
 
CC
 
 = 5.5 V, I
 
F
 
 = 0 mA) I
 
CCH
 
7 10 mA
Dual Channel (V
 
E
 
 = 0.5V) 10 15
Low Level Supply Current Single Channel (V
 
CC
 
 = 5.5 V, I
 
F
 
 = 10 mA) I
 
CCL
 
9 13 mA
Dual Channel (V
 
E
 
 = 0.5V) 14 21
Low Level Enable Current (V
 
CC
 
 = 5.5 V, V
 
E
 
 = 0.5V) I
 
EL
 
-0.8 -1.6 mA
High Level Enable Current (V
 
CC
 
 = 5.5 V, V
 
E
 
 = 2.0V) I
 
EH
 
-0.6 -1.6 mA
High Level Enable Voltage (V
 
CC
 
 = 5.5 V, I
 
F
 
 = 10 mA) V
 
EH
 
2.0 V
Low Level Enable Voltage (V
 
CC
 
 = 5.5 V, I
 
F
 
 = 10 mA)(Note 3) V
 
EL
 
0.8 V
 
AC Characteristics Test Conditions Symbol Min Typ** Max Unit
 
Propagation Delay Time
to Output High Level
(Note 4)  (T
 
A
 
 = 25°C) T
 
PLH
 
20 45 75 ns
(R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF) (Fig. 12) 100
Propagation Delay Time
to Output Low Level
(Note 5)  (T
 
A
 
 = 25°C) T
 
PHL
 
25 45 75 ns
(R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF) (Fig. 12) 100
Pulse Width Distortion (R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF) (Fig. 12) |T
 
PHL
 
-
T
 
PLH
 
|
3 35 ns
Output Rise Time 
(10-90%)
(R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF)
(Note 6) (Fig. 12)
t
 
r
 
50 ns
Output Rise Time 
(90-10%)
(R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF)
(Note 7) (Fig. 12)
t
 
f
 
12 ns
Enable Propagation Delay 
Time to Output High Level
(I
 
F
 
 = 7.5 mA, V
 
EH
 
 = 3.5 V)
(R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF) (Note 8) (Fig. 13)
t
 
ELH
 
20 ns
Enable Propagation Delay 
Time to Output Low Level
(I
 
F
 
 = 7.5 mA, V
 
EH
 
 = 3.5 V)
(R
 
L
 
 = 350
 
Ω
 
, C
 
L
 
 = 15 pF) (Note 9) (Fig. 13)
t
 
EHL
 
20 ns
Common Mode Transient 
Immunity (at Output High 
Level)
(T
 
A
 
 = 25°C) |V
 
CM
 
| = 50V, (Peak)
(I
 
F
 
 = 0 mA, V
 
OH
 
 (Min.) = 2.0V)
|CM
 
H
 
| V/µs
6N137, HCPL-2630
HCPL-2601, HCPL-2631
(R
 
L
 
 = 350
 
Ω
 
) (Note 10)
(Fig. 14) 5000
10,000
10,000
HCPL-2611 |V
 
CM
 
| = 400V 10,000 15,000
Common Mode Transient 
Immunity (at Output Low 
Level)
(R
 
L
 
 = 350
 
Ω
 
) (I
 
F
 
 = 7.5 mA, V
 
OL
 
 (Max.) = 0.8V |CM
 
L
 
| 10,000 V/µs
6N137, HCPL-2630 |V
 
CM
 
| = 50V (Peak)
HCPL-2601, HCPL-2631 (T
 
A
 
 = 25°C)(Note 11)(Fig. 14) 5000 10,000
HCPL-2611(TA = 25°C) |VCM| = 400V 10,000 15,000
G.4 LM2671 118
G.4 LM2671
LM2671
www.ti.com SNVS008K –SEPTEMBER 1998–REVISED APRIL 2013
LM2671 SIMPLE SWITCHER® Power Converter High Efficiency 500mA Step-Down Voltage
Regulator with Features
Check for Samples: LM2671
1FEATURES
234• Efficiency up to 96% DESCRIPTION
The LM2671 series of regulators are monolithic• Available in SOIC, 8-pin PDIP and WSON
integrated circuits built with a LMDMOS process.Packages
These regulators provide all the active functions for a
• Computer Design Software LM267X Made
step-down (buck) switching regulator, capable ofSimple (version 6.0) driving a 500mA load current with excellent line and
• Simple and Easy to Design With load regulation. These devices are available in fixed
output voltages of 3.3V, 5.0V, 12V, and an adjustable• Requires Only 5 external Components
output version.
• Uses Readily Available Standard Inductors
Requiring a minimum number of external• 3.3V, 5.0V, 12V, and Adjustable Output
components, these regulators are simple to use andVersions include patented internal frequency compensation
• Adjustable Version Output Voltage Range: (Patent Nos. 5,382,918 and 5,514,947), fixed
1.21V to 37V frequency oscillator, external shutdown, soft-start,
and frequency synchronization.• ±1.5% Max Output Voltage Tolerance Over
Line and Load Conditions The LM2671 series operates at a switching frequency
• Ensured 500mA Output Load Current of 260 kHz, thus allowing smaller sized filter
components than what would be needed with lower• 0.25Ω DMOS Output Switch
frequency switching regulators. Because of its very
• Wide Input Voltage Range: 8V to 40V high efficiency (>90%), the copper traces on the
• 260 kHz Fixed Frequency Internal Oscillator printed circuit board are the only heat sinking needed.
• TTL Shutdown Capability, Low Power Standby A family of standard inductors for use with the
Mode LM2671 are available from several different
manufacturers. This feature greatly simplifies the• Soft-Start and Frequency Synchronization
design of switch-mode power supplies using these
• Thermal Shutdown and Current Limit
advanced ICs. Also included in the datasheet areProtection
selector guides for diodes and capacitors designed to
work in switch-mode power supplies.APPLICATIONS
Other features include a ensured ±1.5% tolerance on
• Simple High Efficiency (>90%) Step-Down output voltage within specified input voltages and(Buck) Regulator output load conditions, and ±10% on the oscillator
• Efficient Pre-Regulator for Linear Regulators frequency. External shutdown is included, featuring
typically 50 μA stand-by current. The output switch
includes current limiting, as well as thermal shutdown
for full protection under fault conditions.
To simplify the LM2671 buck regulator design
procedure, there exists computer design software,
LM267X Made Simple (version 6.0).
1
Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of
Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.
2SIMPLE SWITCHER, WEBENCH are registered trademarks of Texas Instruments.
3Windows is a registered trademark of Microsoft Corporation.
4All other trademarks are the property of their respective owners.
PRODUCTION DATA information is current as of publication date. Copyright © 1998–2013, Texas Instruments IncorporatedProducts conform to specifications per the terms of the Texas
Instruments standard warranty. Production processing does not
necessarily include testing of all parameters.
G.4 LM2671 119
LM2671
SNVS008K –SEPTEMBER 1998–REVISED APRIL 2013 www.ti.com
TEST CIRCUIT AND LAYOUT GUIDELINES
CIN - 22 μF, 50V Tantalum, Sprague “199D Series”
COUT - 47 μF, 25V Tantalum, Sprague “595D Series”
D1 - 3.3A, 50V Schottky Rectifier, IR 30WQ05F
L1 - 68 μH Sumida #RCR110D-680L
CB - 0.01 μF, 50V Ceramic
Figure 22. Standard Test Circuits and Layout Guides
Fixed Output Voltage Versions
CIN - 22 μF, 50V Tantalum, Sprague “199D Series”
COUT - 47 μF, 25V Tantalum, Sprague “595D Series”
D1 - 3.3A, 50V Schottky Rectifier, IR 30WQ05F
L1 - 68 μH Sumida #RCR110D-680L
R1 - 1.5 kΩ, 1%
CB - 0.01 μF, 50V Ceramic
For a 5V output, select R2 to be 4.75 kΩ, 1%
where VREF = 1.21V
Use a 1% resistor for best stability.
Figure 23. Standard Test Circuits and Layout Guides
Adjustable Output Voltage Versions
Application Hints
The LM2671 provides all of the active functions required for a step-down (buck) switching regulator. The internal
power switch is a DMOS power MOSFET to provide power supply designs with high current capability, up to
0.5A, and highly efficient operation.
10 Submit Documentation Feedback Copyright © 1998–2013, Texas Instruments Incorporated
Product Folder Links: LM2671
G.5 MCP2515 120
G.5 MCP2515
 2003-2012 Microchip Technology Inc. DS21801G-page 1
MCP2515
Features:
• Implements CAN V2.0B at 1 Mb/s:
- 0 – 8 byte length in the data field
- Standard and extended data and remote 
frames 
• Receive Buffers, Masks and Filters:
- Two receive buffers with prioritized message 
storage
- Six 29-bit filters
- Two 29-bit masks
• Data Byte Filtering on the First Two Data Bytes 
(applies to standard data frames)
• Three Transmit Buffers with Prioritization and 
Abort Features
• High-Speed SPI Interface (10 MHz):
- SPI modes 0,0 and 1,1
• One-Shot mode Ensures Message Transmission 
is Attempted Only One Time
• Clock Out Pin with Programmable Prescaler:
- Can be used as a clock source for other 
device(s)
• Start-of-Frame (SOF) Signal is Available for 
Monitoring the SOF Signal:
- Can be used for time-slot-based protocols 
and/or bus diagnostics to detect early bus 
degradation
• Interrupt Output Pin with Selectable Enables
• Buffer Full Output Pins Configurable as:
- Interrupt output for each receive buffer
- General purpose output
• Request-to-Send (RTS) Input Pins Individually 
Configurable as:
- Control pins to request transmission for each 
transmit buffer
- General purpose inputs
• Low-Power CMOS Technology:
- Operates from 2.7V – 5.5V
- 5 mA active current (typical)
- 1 µA standby current (typical) (Sleep mode)
• Temperature Ranges Supported:
- Industrial (I): -40°C to +85°C
- Extended (E): -40°C to +125°C
Description
Microchip Technology’s MCP2515 is a stand-alone
Controller Area Network (CAN) controller that
implements the CAN specification, version 2.0B. It is
capable of transmitting and receiving both standard
and extended data and remote frames. The MCP2515
has two acceptance masks and six acceptance filters
that are used to filter out unwanted messages, thereby
reducing the host MCU’s overhead. The MCP2515
interfaces with microcontrollers (MCUs) via an industry
standard Serial Peripheral Interface (SPI).
Package Types
16
5
TXCAN
RXCAN
VDD
RESET
CS
SO
M
C
P2
51
5
1
2
3
4
18
17
16
15
SI
SCK
INT
RX0BF
14
13
12
11
RX1BF10
OSC2
OSC1
CLKOUT/SOF
TX2RTS
5
6
7
8
Vss 9
TX0RTS
TX1RTS
M
C
P2
51
5
TXCAN
RXCAN
TX0RTS
OSC1
CLKOUT/SOF
OSC2
CS
VDD
RESET
SO
SCK
INT
SI
RX0BF
RX1BFVSS
TX1RTS
TX2RTS
NC NC
13
12
1
2
3
4
5
6
7
8
9
20
19
18
17
16
15
14
1110
18-Lead PDIP/SOIC
20-LEAD TSSOP
2
MCP2515
20-Lead 4x4 QFN*
NC
TX2RTS
TX0RTS
SO
SI
O
S
C
2
NC
O
S
C
1
G
N
D
R
X
1B
F
SCK
R
X
C
A
N
TX
C
A
N
V
D
D
R
E
S
E
T
TX1RTS
EP
20
1
19 18 17
3
4
14
13
12
11
6 7 8 9
21
10
15CLKOUT
C
S
INT
R
X
0B
F
* Includes Exposed Thermal
 Pad (EP); see Table 1-1.
Stand-Alone CAN Controller with SPI Interface
G.5 MCP2515 121
 2003-2012 Microchip Technology Inc. DS21801G-page 39
MCP2515
5.0 BIT TIMING
All nodes on a given CAN bus must have the same
nominal bit rate. The CAN protocol uses Non Return to
Zero (NRZ) coding, which does not encode a clock
within the data stream. Therefore, the receive clock
must be recovered by the receiving nodes and
synchronized to the transmitter’s clock.
As oscillators and transmission times may vary from
node to node, the receiver must have some type of
Phase Lock Loop (PLL) synchronized to data
transmission edges to synchronize and maintain the
receiver clock. Since the data is NRZ-coded, it is
necessary to include bit-stuffing to ensure that an edge
occurs at least every six bit times to maintain the Digital
Phase Lock Loop (DPLL) synchronization.
The bit timing of the MCP2515 is implemented using a
DPLL that is configured to synchronize to the incoming
data, as well as provide the nominal timing for the
transmitted data. The DPLL breaks each bit time into
multiple segments made up of minimal periods of time,
called the Time Quanta (TQ).
Bus timing functions executed within the bit time frame
(such as synchronization to the local oscillator, network
transmission delay compensation and sample point
positioning) are defined by the programmable bit timing
logic of the DPLL.
5.1 The CAN Bit TIme
All devices on the CAN bus must use the same bit rate.
However, all devices are not required to have the same
master oscillator clock frequency. For the different
clock frequencies of the individual devices, the bit rate
has to be adjusted by appropriately setting the Baud
Rate Prescaler and number of time quanta in each
segment.
The CAN bit time is made up of non-overlapping
segments. Each of these segments are made up of
integer units called Time Quanta (TQ), explained later
in this data sheet. The Nominal Bit Rate (NBR) is
defined in the CAN specification as the number of bits
per second transmitted by an ideal transmitter with no
resynchronization. It can be described with the
equation:
EQUATION 5-1:
Nominal Bit Time
The Nominal Bit Time (NBT) (tbit) is made up of non-
overlapping segments (Figure 5-1). Therefore, the
NBT is the summation of the following segments:
Associated with the NBT are the sample point,
Synchronization Jump Width (SJW) and Information
Processing Time (IPT), which are explained later.
SYNCHRONIZATION SEGMENT
The Synchronization Segment (SyncSeg) is the first
segment in the NBT and is used to synchronize the
nodes on the bus. Bit edges are expected to occur
within the SyncSeg. This segment is fixed at 1 TQ.
FIGURE 5-1: CAN BIT TIME SEGMENTS
NBR fbit
1
tbit
------= =
tbit tSyncSeg tPropSeg tPS1 tPS2+ + +=
Nominal Bit Time (NBT), tbit
Sample
Point
SyncSeg PropSeg PhaseSeg1 (PS1) PhaseSeg2 (PS2)
G.5 MCP2515 122
MCP2515
DS21801G-page 40  2003-2012 Microchip Technology Inc.
PROPAGATION SEGMENT
The Propagation Segment (PropSeg) exists to
compensate for physical delays between nodes. The
propagation delay is defined as twice the sum of the
signal’s propagation time on the bus line, including the
delays associated with the bus driver. The PropSeg is
programmable from 1-8 TQ.
PHASE SEGMENT 1 (PS1) AND PHASE 
SEGMENT 2 (PS2)
The two phase segments, PS1 and PS2, are used to
compensate for edge phase errors on the bus. PS1 can
be lengthened (or PS2 shortened) by resyncronization.
PS1 is programmable from 1-8 TQ and PS2 is
programmable from 2-8 TQ.
SAMPLE POINT
The sample point is the point in the bit time at which the
logic level is read and interpreted. The sample point is
located at the end of PS1. The exception to this rule is
if the sample mode is configured to sample three times
per bit. In this case, while the bit is still sampled at the
end of PS1, two additional samples are taken at one-
half TQ intervals prior to the end of PS1, with the value
of the bit being determined by a majority decision.
INFORMATION PROCESSING TIME
The Information Processing Time (IPT) is the time
required for the logic to determine the bit level of a
sampled bit. The IPT begins at the sample point, is
measured in TQ and is fixed at 2 TQ for the Microchip
CAN module. Since PS2 also begins at the sample
point and is the last segment in the bit time, it is
required that the PS2 minimum is not less than the IPT.
Therefore:
SYNCHRONIZATION JUMP WIDTH
The Synchronization Jump Width (SJW) adjusts the bit
clock as necessary by 1-4 TQ (as configured) to
maintain synchronization with the transmitted
message. Synchronization is covered in more detail
later in this data sheet.
Time Quantum
Each of the segments that make up a bit time are made
up of integer units called Time Quanta (TQ). The length
of each Time Quantum is based on the oscillator period
(tOSC). The base TQ equals twice the oscillator period.
Figure 5-2 shows how the bit period is derived from
TOSC and TQ. The TQ length equals one TQ clock
period (tBRPCLK), which is programmable using a
programmable prescaler, called the Baud Rate
Prescaler (BRP). This is illustrated in the following
equation:
EQUATION 5-2:
FIGURE 5-2: TQ AND THE BIT PERIOD
PS2min IPT 2TQ= =
TQ 2 BRP TOSC 
2 BRP
FOSC
------------------= =
Where: BRP equals the configuration as shown in
Register 5-1.
tOSC
TBRPCLK
tBIT
Sync
(fixed)
PropSeg
(Programmable)
PS2
(Programmable)
PS1
(Programmable)
TQ
(tTQ)
CAN Bit Time
G.5 MCP2515 123
 2003-2012 Microchip Technology Inc. DS21801G-page 43
MCP2515
5.3 Programming Time Segments
Some requirements for programming of the time
segments:
• PropSeg + PS1 >= PS2
• PropSeg + PS1 >= TDELAY
• PS2 > SJW
For example, assuming that a 125 kHz CAN baud rate
with FOSC = 20 MHz is desired:
TOSC = 50 ns, choose BRP<5:0> = 04h, then
TQ = 500 ns. To obtain 125 kHz, the bit time must be 16
TQ.
Typically, the sampling of the bit should take place at
about 60-70% of the bit time, depending on the system
parameters. Also, typically, the TDELAY is 1-2 TQ.
SyncSeg = 1 TQ and PropSeg = 2 TQ. So setting
PS1 = 7 TQ would place the sample at 10 TQ after the
transition. This would leave 6 TQ for PS2.
Since PS2 is 6, according to the rules, SJW could be a
maximum of 4 TQ. However, a large SJW is typically
only necessary when the clock generation of the differ-
ent nodes is inaccurate or unstable, such as using
ceramic resonators. So a SJW of 1 is usually enough.
5.4 Oscillator Tolerance
The bit timing requirements allow ceramic resonators
to be used in applications with transmission rates of up
to 125 kbit/sec as a rule of thumb. For the full bus
speed range of the CAN protocol, a quartz oscillator is
required. A maximum node-to-node oscillator variation
of 1.7% is allowed.
5.5 Bit Timing Configuration 
Registers
The configuration registers (CNF1, CNF2, CNF3)
control the bit timing for the CAN bus interface. These
registers can only be modified when the MCP2515 is in
Configuration mode (see Section 10.0 “Modes of
Operation”).
5.5.1 CNF1
The BRP<5:0> bits control the Baud Rate Prescaler.
These bits set the length of TQ relative to the OSC1
input frequency, with the minimum TQ length being
2 TOSC (when BRP<5:0> = ‘b000000’). The
SJW<1:0> bits select the SJW in terms of number of
TQs.
5.5.2 CNF2
The PRSEG<2:0> bits set the length (in TQ’s) of the
propagation segment. The PHSEG1<2:0> bits set the
length (in TQ’s) of PS1.
The SAM bit controls how many times the RXCAN pin
is sampled. Setting this bit to a ‘1’ causes the bus to be
sampled three times: twice at TQ/2 before the sample
point and once at the normal sample point (which is at
the end of PS1). The value of the bus is determined to
be the majority sampled. If the SAM bit is set to a ‘0’,
the RXCAN pin is sampled only once at the sample
point.
The BTLMODE bit controls how the length of PS2 is
determined. If this bit is set to a ‘1’, the length of PS2 is
determined by the PHSEG2<2:0> bits of CNF3 (see
Section 5.5.3 “CNF3”). If the BTLMODE bit is set to a
‘0’, the length of PS2 is greater than that of PS1 and the
information processing time (which is fixed at 2 TQ for
the MCP2515).
5.5.3 CNF3
The PHSEG2<2:0> bits set the length (in TQ’s) of PS2,
if the CNF2.BTLMODE bit is set to a ‘1’. If the
BTLMODE bit is set to a ‘0’, the PHSEG2<2:0> bits
have no effect.
G.5 MCP2515 124
 2003-2012 Microchip Technology Inc. DS21801G-page 65
MCP2515
12.0 SPI INTERFACE
12.1 Overview
The MCP2515 is designed to interface directly with the
Serial Peripheral Interface (SPI) port available on many
microcontrollers and supports Mode 0,0 and Mode 1,1.
Commands and data are sent to the device via the SI
pin, with data being clocked in on the rising edge of
SCK. Data is driven out by the MCP2515 (on the SO
line) on the falling edge of SCK. The CS pin must be
held low while any operation is performed. Table 12-1
shows the instruction bytes for all operations. Refer to
Figure 12-10 and Figure 12-11 for detailed input and
output timing diagrams for both Mode 0,0 and Mode
1,1 operation.
12.2 RESET Instruction
The RESET instruction can be used to re-initialize the
internal registers of the MCP2515 and set Configuration
mode. This command provides the same functionality,
via the SPI interface, as the RESET pin.
The RESET instruction is a single-byte instruction that
requires selecting the device by pulling CS low,
sending the instruction byte and then raising CS. It is
highly recommended that the Reset command be sent
(or the RESET pin be lowered) as part of the power-on
initialization sequence.
12.3 READ Instruction
The READ instruction is started by lowering the CS pin.
The READ instruction is then sent to the MCP2515
followed by the 8-bit address (A7 through A0). Next, the
data stored in the register at the selected address will
be shifted out on the SO pin.
The internal Address Pointer is automatically
incremented to the next address once each byte of
data is shifted out. Therefore, it is possible to read the
next consecutive register address by continuing to pro-
vide clock pulses. Any number of consecutive register
locations can be read sequentially using this method.
The read operation is terminated by raising the CS pin
(Figure 12-2).
12.4 READ RX BUFFER Instruction
The READ RX BUFFER instruction (Figure 12-3) pro-
vides a means to quickly address a receive buffer for
reading. This instruction reduces the SPI overhead by
one byte, the address byte. The command byte actually
has four possible values that determine the Address
Pointer location. Once the command byte is sent, the
controller clocks out the data at the address location
the same as the READ instruction (i.e., sequential reads
are possible). This instruction further reduces the SPI
overhead by automatically clearing the associated
receive flag (CANINTF.RXnIF) when CS is raised at the
end of the command.
12.5 WRITE Instruction
The WRITE instruction is started by lowering the CS
pin. The WRITE instruction is then sent to the MCP2515
followed by the address and at least one byte of data.
It is possible to write to sequential registers by
continuing to clock in data bytes, as long as CS is held
low. Data will actually be written to the register on the
rising edge of the SCK line for the D0 bit. If the CS line
is brought high before eight bits are loaded, the write
will be aborted for that data byte and previous bytes in
the command will have been written. Refer to the timing
diagram in Figure 12-4 for a more detailed illustration of
the byte write sequence.
12.6 LOAD TX BUFFER Instruction
The LOAD TX BUFFER instruction (Figure 12-5) elimi-
nates the eight-bit address required by a normal Write
command. The eight-bit instruction sets the Address
Pointer to one of six addresses to quickly write to a
transmit buffer that points to the “ID” or “data” address
of any of the three transmit buffers.
12.7 REQUEST-TO-SEND (RTS) 
Instruction
The RTS command can be used to initiate message
transmission for one or more of the transmit buffers. 
The MCP2515 is selected by lowering the CS pin. The
RTS command byte is then sent. Shown in Figure 12-6,
the last 3 bits of this command indicate which transmit
buffer(s) are enabled to send.
This command will set the TxBnCTRL.TXREQ bit for
the respective buffer(s). Any or all of the last three bits
can be set in a single command. If the RTS command
is sent with nnn = 000, the command will be ignored.
12.8 READ STATUS Instruction
The READ STATUS instruction allows single instruction
access to some of the often used status bits for
message reception and transmission.
The MCP2515 is selected by lowering the CS pin and
the Read Status command byte, shown in Figure 12-8,
is sent to the MCP2515. Once the command byte is
sent, the MCP2515 will return eight bits of data that
contain the status.
If additional clocks are sent after the first eight bits are
transmitted, the MCP2515 will continue to output the
status bits as long as the CS pin is held low and clocks
are provided on SCK.
Note: The MCP2515 expects the first byte after
lowering CS to be the instruction/
command byte. This implies that CS must
be raised and then lowered again to
invoke another command.
G.5 MCP2515 125
MCP2515
DS21801G-page 66  2003-2012 Microchip Technology Inc.
Each status bit returned in this command may also be
read by using the standard Read command with the
appropriate register address.
12.9 RX STATUS Instruction
The RX STATUS instruction (Figure 12-9) is used to
quickly determine which filter matched the message
and message type (standard, extended, remote). After
the command byte is sent, the controller will return
8 bits of data that contain the status data. If more clocks
are sent after the eight bits are transmitted, the
controller will continue to output the same status bits as
long as the CS pin stays low and clocks are provided.
12.10 BIT MODIFY Instruction
The BIT MODIFY instruction provides a means for set-
ting or clearing individual bits in specific status and con-
trol registers. This command is not available for all
registers. See Section 11.0 “Register Map” to
determine which registers allow the use of this
command.
The part is selected by lowering the CS pin and the Bit
Modify command byte is then sent to the MCP2515.
The command is followed by the address of the
register, the mask byte and finally the data byte.
The mask byte determines which bits in the register will
be allowed to change. A ‘1’ in the mask byte will allow
a bit in the register to change, while a ‘0’ will not.
The data byte determines what value the modified bits
in the register will be changed to. A ‘1’ in the data byte
will set the bit and a ‘0’ will clear the bit, provided that
the mask for that bit is set to a ‘1’ (see Figure 12-7).
FIGURE 12-1: BIT MODIFY
TABLE 12-1: SPI INSTRUCTION SET
Note: Executing the Bit Modify command on
registers that are not bit-modifiable will
force the mask to FFh. This will allow byte-
writes to the registers, not bit modify.
Mask byte
Data byte
Previous
Register
Contents
Resulting
Register
Contents
0 0 1 11 10 0
X X 1 10 0X X
0 1 0 11 00 0
0 1 1 10 00 0
Instruction Name Instruction Format Description
RESET 1100 0000 Resets internal registers to default state, set Configuration mode.
READ 0000 0011 Read data from register beginning at selected address.
READ RX BUFFER 1001 0nm0 When reading a receive buffer, reduces the overhead of a normal 
Read command by placing the Address Pointer at one of four 
locations, as indicated by ‘n,m’. Note: The associated RX flag bit 
(CANINTF.RXnIF) will be cleared after bringing CS high.
WRITE 0000 0010 Write data to register beginning at selected address.
LOAD TX BUFFER 0100 0abc When loading a transmit buffer, reduces the overhead of a normal 
Write command by placing the Address Pointer at one of six 
locations as indicated by ‘a,b,c’.
RTS 
(Message 
Request-To-Send)
1000 0nnn Instructs controller to begin message transmission sequence for 
any of the transmit buffers. 
READ STATUS 1010 0000 Quick polling command that reads several status bits for transmit 
and receive functions.
RX STATUS 1011 0000 Quick polling command that indicates filter match and message 
type (standard, extended and/or remote) of received message.
BIT MODIFY 0000 0101 Allows the user to set or clear individual bits in a particular 
register. Note: Not all registers can be bit-modified with this 
command. Executing this command on registers that are not bit-
modifiable will force the mask to FFh. See the register map in 
Section 11.0 “Register Map” for a list of the registers that apply.
1000 0nnn
Request-to-send for TXBO
Request-to-send for TXB1
Request-to-send for TXB2
G.6 MCP2551 126
G.6 MCP2551
© 2010 Microchip Technology Inc. DS21667F-page 1
MCP2551
Features 
• Supports 1 Mb/s operation
• Implements ISO-11898 standard physical layer 
requirements
• Suitable for 12V and 24V systems
• Externally-controlled slope for reduced RFI        
emissions
• Detection of ground fault (permanent Dominant) 
on TXD input
• Power-on Reset and voltage brown-out protection
• An unpowered node or brown-out event will not   
disturb the CAN bus
• Low current standby operation
• Protection against damage due to short-circuit    
conditions (positive or negative battery voltage)
• Protection against high-voltage transients
• Automatic thermal shutdown protection
• Up to 112 nodes can be connected
• High-noise immunity due to differential bus        
implementation
• Temperature ranges:
- Industrial (I): -40°C to +85°C
- Extended (E): -40°C to +125°C
Package Types
Block Diagram
RS
CANH
CANL
VREF
TXD
VSS
VDD
RXD
1
2
3
4
8
7
6
5
PDIP/SOIC
M
C
P2
55
1
Thermal
Shutdown
VDD
VSS
CANH
CANL
TXD
RS
RXD
VREF
VDD
Slope 
Control
Power-On
Reset
Reference
Voltage
Receiver
GND
0.5 VDD
TXD
Dominant
Detect
Driver
Control
High-Speed CAN Transceiver
G.7 ROE0505S 127
G.7 ROE0505S
Input Voltage Range ±10% max.
Output Voltage Accuracy -2% typ., ±5% max.
Line Voltage Regulation (low line to high line at max. load) 1.2% typ.
20% to 100% load (5V output) 10% max.
Output Ripple and Noise (20MHz BW limited) 52mVp-p typ. / 100mVp-p max.
Operating Frequency (Vin=nominal input) 50kHz min. / 82kHz typ. / 105kHz max.
Efficiency 75% typ. / 70% min.
Isolation Test Voltage                                  1000 VDC min.
(tested for 1 second)
Isolation Capacitance 75pF max.
Isolation Resistance (Viso=500V) 1GΩ min.
Short-Circuit Protection 1 sec.
Operating Temperature Range -40°C to +85°C
Storage Temperature -55°C to +125°C
Relative Humidity 95% RH
Package Weight 1.4g          
MTBF (+25°C) using MIL-HDBK 217F 2400 x 10³ hours
MTBF (+85°C) using MIL-HDBK 217F 650 x 10³ hours}
Detailed Information see 
Application Notes chapter "MTBF"
Typical Characteristics
Derating-Graph
(Ambient Temperature)
Tolerance Envelope
1 www.recom-electronic.comREV: 0/2012
RoHS
2002/95/EC
6/6
Selection Guide
Part Input Output Output
Number Voltage Voltage Current Efficiency
SMD           (VDC) (VDC) (mA) (typ.) 
ROE-0505S 5 5 200 75%
Specifications (measured at TA = 25°C, nominal input voltage, full load and after warm-up)
1 Watt SIP4
Single Output
● 1:1 Input Range
● Low Cost 1W Converter
● Efficiency to 75%
● -40°C to +85°C Operating Temperature Range
Features
Unregulated
Converters
ROE
ECONOLINE
DC/DC-Converter




	








 







 

!


"
"
#$%
"
&
  



#
'



"#(#)(

&
*+')()

Appendix H
Documentation and Manuals
H.1 Overview 129
H.1 Overview
There are limitations of producing commercial use documentation with an incomplete
product. Given the software and hardware of the bridge are going to undergo significant
change before these documents are complete, full documentation will not be produced.
Below is an outline of what would be included in each of the required documents.
Technical Manual
Operators Manual
Software Manual
H.2 Technical Manual
This document will include the following information.
Mounting instructions - The bridge is to be placed inside a plastic container and sealed
to obtain an IP rating. This enclosure will likely be intended for a wall mount so will
include screw holes. The manual should include instructions.
Power supply - Include connections diagrams and suitable supply voltages. For the bridge
this is currently 12V - 24V AC or DC.
Communications connections - Include the connection instructions for both communica-
tions interfaces. Will demonstrate the correct wiring for each bus as well as the use of
the ground connections.
Any other information regarding installation or hardware diagnostics. This might include
information about test points.
H.3 Operators Manual 130
H.3 Operators Manual
This document will focus on how to use the bridge. It will be a simple document since
the bridge is intended to be configured and left alone.
Bridge Setup - Section will include information about the default configuration of the
bridge. Will refer you to the software manual if you wish to make configuration changes
to the bridge.
CAN Setup - Will give instructions on how to configure the BMS CAN node for successful
interaction with the bridge - how to access the Modbus slave from the CAN node.
Diagnostics - This section will give a troubleshooting guide to the bridge. Will include
information about the fault (ERR) LED and the meaning of different frequency flashes.
Software changes - refer software manual
H.4 Software Manual
This document will outline how to make software configuration changes to the bridge.
The types of changes the user can expect include:
CAN baud rate
CAN addressing mode (STD or XTD)
CAN flags, filters and masks
Modbus baud rate
Modbus parity (none, even, odd)
Modbus mode (ASCII or RTU)
Error reporting to BMS CAN node
Power outage response
GLCD display information
The menu operations via the GLCD and touch panel were not included in the scope of
the project so implementation of these features are not possible.
Appendix I
Preliminary Report
Documentation
I.1 Overview 132
I.1 Overview
This section is a selected extract from the preliminary report containing non-technical
aspects of the project. This includes consideration for sustainability and the environment,
a risk assessment, ethical considerations, the initial design concept and methodology,
resource requirements and a proposed time-line.
These were originally submissions as part of the preliminary report submitted in June
2015.
I.1 Overview 133
ENG4111 – Research Project Part 1  CAN to Modbus Network Bridge 
Preliminary Report  Matthew Quinton 0061024766 
 
  Page 16 of 30 
4. Consequential Effects 
4.1 Sustainability and Environment 
The Institute of Engineers (1997) published a document with guidelines for engineers when dealing 
with issues of sustainability. The key considerations for this project are considered below. Wherever 
possible, these factors will be considered in decisions regarding this project. 
4.1.1 E-waste and finite resources 
E-waste and finite resource use are issues that confront any involved in the manufacturing of 
electronic devices. Silicon is the major resource for integrated circuits and fortunately, the Earth is 
abundant with this resource. However, the processes involved in the manufacture have negative 
environmental effects. These include the use of cleaning agents, solders (especially lead based), 
plastics in packaging, and disposal of waste products (ELE1502 Electronic Circuits: Study Book 2012). 
These issues present a challenge to this project. Ultimately, there is little that can be done on this 
project as these practices are well ingrained in the industry and there is less flexibility in a sponsored 
project. When the opportunity to take a sustainable option arises throughout the project, it is 
important that it is taken. 
4.1.2Eradication of poverty 
It is important to consider whether engineering projects actively contribute to the increase or 
decrease of poverty. For there to be true sustainability there needs to be equality for all genders, 
ages and races regarding living standards and employment participation (Institute of Engineers 
1997). This project has little consequence on these issues directly but is part of larger systems that 
may have had significant impact historically. 
Electronics in general contribute to this issue as a lot of manufacturing is done in countries with 
lower labour costs (ELE1502 Electronic Circuits: Study Book 2012). This raises the issue of 
exploitation of the works in these countries. The counter argument is that it may not be feasible to 
produce electronic products at the same prices if labour costs are higher. 
Building management systems and their autonomous nature may have contributed to the loss of 
employment for some demographics; however this is a complex issue involving many factors and the 
discussion is well beyond the scope of this project. The network bridge itself performs a function 
that a human could not.  
It is important to recognise the effect such systems have on the population wherever they are used 
but is not something considered further here. 
  
I.1 Overview 134
ENG4111 – Research Project Part 1  CAN to Modbus Network Bridge 
Preliminary Report  Matthew Quinton 0061024766 
 
  Page 17 of 30 
4.2 Risk Assessment 
The network bridge is a small, low power electronic device. It presents little innate safety risk due to 
these traits but is not immune to hazards. Table 2 considers risks appropriate to this type of device 
during design and production and Table 3 considers risk during the installing, operation and 
maintenance of the network bridge (ENG4111 Research project part 1: Project reference book 
2011). 
Table 2: Project risk assessment – Safety during development 
Hazard Likelihood Exposure Consequence Control 
Electrical shock – 
low voltage  
Slight Frequently Critical damage 
to equipment 
Ensure powering of circuits 
only occurs after rigorous 
checking for short circuits 
Soldering iron  Slight Frequently Minor burns Clear working space – when 
soldering taking place it 
should be the only active task 
 
Table 3: Project risk assessment - Operation 
Hazard Likelihood Exposure Consequence Control 
Network bridge 
failure  
Significant Continuous BMS receives 
incorrect 
information – 
could be severe 
dependant on 
environment 
The network bridge must have 
in-built features that see it  fail 
safe – when failure occurs it 
should be immediately 
reported to the BMS 
Electric shock  Extremely 
slight 
Occasionally Electric shock – 
possible injury 
or death 
Installations to be performed 
by trained operators – due 
care taken when connecting 
power to device as required 
for any electronic installation 
 
  
I.1 Overview 135
ENG4111 – Research Project Part 1  CAN to Modbus Network Bridge 
Preliminary Report  Matthew Quinton 0061024766 
 
  Page 18 of 30 
The other type of risk to be managed is project completion risk. That is, what obstacles might be 
present during the project and what effect might they have upon a successful completion. These 
risks are considered in Table 4. 
Table 4: Project risk assessment - Project Completion 
Hazard Likelihood Exposure Consequence Control 
Components take 
longer to receive 
than planned 
Significant Occasional Latter project 
stages are 
delayed or not 
able to be 
completed 
Complete these activities at 
the earliest possible stage to 
give a buffer to unplanned 
delays 
Network bridge 
or individual 
aspects do not 
work  
Significant Continuous Project may not 
be completed 
during time 
allotted 
Planning of all aspects so that 
the flow on effects of current 
work is known. Identify extra 
time in which to allocate to 
the project if needed (ie 
weekends) 
4.3 Ethical 
The main ethical issue in consideration for this project is that of intellectual property. Since it is a 
sponsored project, the work and any outcomes are property of GDA. At various stages of the project 
there will be requirements to interact with third parties. As such, consideration must be paid to 
what information can be shared during these interactions. Further to this, it is important to abide by 
Engineers Australia’s Code of Ethics throughout the project.  
I.1 Overview 136
ENG4111 – Research Project Part 1  CAN to Modbus Network Bridge 
Preliminary Report  Matthew Quinton 0061024766 
 
  Page 19 of 30 
Initial design concept 
At this stage design is in its infancy but Figure 5 demonstrates the intended logical functionality of 
the network bridge. There is clear logical distinction between the CAN and Modbus nodes even 
though they will both be housed in the same physical device. This figure is not meant to be a 
complete design, but is a useful diagram for visualising how the project will be approached. This 
approach is discussed further in the methodology below. 
 
Figure 5: Initial design concept 
  
I.1 Overview 137
ENG4111 – Research Project Part 1  CAN to Modbus Network Bridge 
Preliminary Report  Matthew Quinton 0061024766 
 
  Page 20 of 30 
5. Methodology 
5.1 The method 
The network bridge has two major components; hardware and software. While they are interlinked, 
it is convenient to develop them separately and then combine them after proving concepts 
individually. The other key methodology for the project is the testing procedures for the hardware, 
software and the completed network bridge. Conceptually, there are three separate components to 
the bridge; the CAN node, the Modbus node and the intelligence that connects them. Figure 5 
demonstrates this logical separation. 
Hardware development will involve designing circuitry to provide the physical interface used to 
implement the protocols. It will be necessary to use a microprocessor to implement the protocols 
and to provide the logical interface between them. The microprocessor selection is the first step in 
the hardware design. It will influence what other hardware can and will be used. There will likely be 
sundry electronics required to operate the microprocessor in the manner desired. After the selection 
of a microprocessor is the selection of hardware components for the CAN bus and Modbus 
interfaces. It is likely the Modbus interface will be directly implementable from the microprocessor 
with few extra components due to many devices supporting serial communications. The CAN bus 
interface will require further consideration as it is not supported completely in most 
microprocessors. Even though many parts may have an integrated CAN controller, which is not the 
only circuitry required. As a result, full circuitry to enable a CAN interface is required and will be 
specified. 
The software development procedure is based around the conceptual view of the network bridge. 
Each of the two protocol interfaces will be developed first. It does not matter in which order this is 
done. Where possible, existing code libraries within the compiler for development of CAN, Modbus 
and serial communications will be utilised to prove concepts. Once each interface has been 
implemented using existing code libraries, they will be rewritten using techniques consistent with 
GDA practices. Once the CAN bus interface and Modbus interface are developed, the next state is to 
connect the two logically. This will involve the development of a real time operating system with 
buffers to handle messages from each interface. It will be necessary to calculate and then verify data 
timing and data throughput requirements to determine how best information transfer is handled. 
This may have an effect on the hardware specifications and this will be adjusted if necessary. 
GDA has preferences to certain manufacturers and suppliers due to existing development platforms 
and business relationships. As a result, the selection of hardware and development tools are more 
limited than might otherwise be the case. A PIC branded microprocessor will be chosen for the task.  
The compiler and development software to be used is MicroC Pro for PIC version 6.60. The EasyPIC 
Pro v7 development board will be used for software development prior to the completion of 
hardware design and testing. 
Testing for the correct operation is required for the network bridge. As discussed, testing of each 
protocol interface will be conducted individually at first. This will involve setting up another node, or 
simulating a node, using that protocol and connecting it to the network bridge. Known data and 
instructions can then be passed to and from the network bridge to verify that it can correctly 
transmit using each protocol. To test the full functionality of the network bridge a combination of 
I.1 Overview 138
ENG4111 – Research Project Part 1  CAN to Modbus Network Bridge 
Preliminary Report  Matthew Quinton 0061024766 
 
  Page 21 of 30 
the above testing procedure will be required. Simulated or real nodes for both CAN and Modbus will 
be required. Placing the network bridge in between will allow testing of data transmission and 
requests between the two nodes. 
5.2 Resources 
This project is sponsored by GDA and as such all resourcing is done through this channel. Below is a 
list of requirements for the project: 
 Microprocessors for both development and final products 
 Printed circuit board (PCB) and electronic components 
 PIC development board 
 C language compiler for PIC 
 Testing equipment (devices to simulate Modbus or CAN bus nodes, oscilloscopes etc.) 
 Electronics manufacturing and prototyping equipment (soldering etc.) 
All of the above will be acquired through GDA. We they already have possession of such equipment 
and resources it will be used. Any extra requirements will need to be justified to and requested 
through GDA’s purchasing channels. Vendors will be likely chosen from existing suppliers or by those 
approved by GDA. All costing decisions are made by GDA and justification may need to be made if 
desirable products are more expensive than alternatives. It is acceptable to locate other sources for 
resources if required but they must be approved by GDA before purchasing will occur. 
The most critical resources to this project are the software development tools and the PCBs. GDA 
has possession of multiple development tools suitable for the task which should mitigate risk 
associated with this resource. The greater risk is with PCB production. As the manufacturing of any 
designed PCBs will likely take place internationally, there may significant timing issues with their 
acquisition. To help reduce the risks of this, hardware design will be a priority early in the project 
development to allow as much time as possible. If it is becomes clear that procurement of PCBs will 
not happen within acceptable time frames it may be possible to use breadboards or prototyping 
boards to complete the hardware construction.  
  
I.1 Overview 139
 
 
P
ag
e 
0
 o
f 
3
0
 
5
.3
 T
im
e
li
n
e
s 
– 
G
a
n
tt
 c
h
a
rt
 
Th
e 
fo
llo
w
in
g 
G
an
tt
 c
h
ar
t 
d
em
o
n
st
ra
te
s 
th
e 
ex
p
ec
te
d
 t
im
in
g 
o
f 
p
ro
je
ct
 s
ta
ge
s 
an
d
 t
h
ei
r 
e
ff
ec
t 
o
n
 m
ile
st
o
n
es
 f
o
r 
th
e 
p
ro
je
ct
. 
 
Th
is
 c
h
ar
t 
d
em
o
n
st
ra
te
s 
th
at
 m
an
y 
as
p
ec
ts
 o
f 
th
e 
p
ro
je
ct
 c
an
 b
e 
w
o
rk
e
d
 u
p
o
n
 in
d
ep
en
d
en
tl
y 
an
d
 m
u
st
 b
e 
d
o
n
e 
co
n
cu
rr
en
tl
y 
to
 a
llo
w
 f
o
r 
co
m
p
le
ti
o
n
 o
f 
th
e 
p
ro
je
ct
 w
it
h
in
 t
h
e 
d
ef
in
ed
 t
im
el
in
es
. I
t 
is
 im
p
o
rt
an
t 
th
at
 s
ta
ge
s 
th
at
 r
el
y 
o
n
 e
ar
lie
r 
ta
sk
s 
b
e 
co
m
p
le
te
d
 a
s 
id
en
ti
fi
ed
 o
r 
w
it
h
in
 r
ea
so
n
ab
le
 v
ar
ia
ti
o
n
s.
 
Ta
sk
La
b
e
l
P
re
d
e
ce
ss
o
rs
Ex
p
e
ct
e
d
 
D
u
ra
ti
o
n
 (
w
e
e
ks
)
22
/0
6
29
/0
6
6/
07
13
/0
7
20
/0
7
27
/0
7
3/
08
10
/0
8
17
/0
8
24
/0
8
31
/0
8
7/
09
14
/0
9
21
/0
9
28
/0
9
5/
10
12
/1
0
19
/1
0
26
/1
0
H
ar
d
w
ar
e
 d
e
si
gn
A
1
H
ar
d
w
ar
e
 p
ro
to
ty
p
in
g
B
A
2
H
ar
d
w
ar
e
 p
ro
to
ty
p
in
g 
- 
te
st
in
g
C
B
1
H
ar
d
w
ar
e
 P
C
B
 la
yo
u
t
D
C
1
H
ar
d
w
ar
e
 P
C
B
 d
e
li
ve
ry
E
D
3
H
ar
d
w
ar
e
 P
C
B
 t
e
st
in
g
F
E
1
So
ft
w
ar
e
 d
e
si
gn
 -
 M
o
d
b
u
s
G
2
So
ft
w
ar
e
 d
e
si
gn
 -
 C
A
N
H
2
So
ft
w
ar
e
 d
e
si
gn
 -
 B
ri
d
ge
I
G
, H
4
So
ft
w
ar
e
 t
e
st
in
g 
- 
M
o
d
b
u
s
J
G
1
So
ft
w
ar
e
 t
e
st
in
g 
- 
C
A
N
K
H
1
So
ft
w
ar
e
 t
e
st
in
g 
- 
B
ri
d
ge
L
J,
 K
4
N
e
tw
o
rk
 b
ri
d
ge
 h
ar
d
w
ar
e
/s
o
ft
w
ar
e
 c
o
m
b
in
at
io
n
M
F,
 L
3
N
e
tw
o
rk
 b
ri
d
ge
 h
ar
d
w
ar
e
/s
o
ft
w
ar
e
 c
o
m
b
in
at
io
n
 -
 t
e
st
in
g
N
M
2
D
o
cu
m
e
n
ta
ti
o
n
O
N
2
D
is
se
rt
at
io
n
 -
 in
cr
e
m
e
n
ta
l
P
15
D
is
se
rt
at
io
n
 -
 c
o
m
p
le
ti
o
n
Q
N
, O
, P
2
D
at
e
 (
w
e
e
ks
 a
p
ar
t 
- 
st
ar
ti
n
g 
Ju
n
e
 2
2,
 2
01
5)
