# **MOBA3 Control System**

Model Railway Control System
System Design Specification and Documentation
Revision A

Andreas Wälchli

October 9, 2021

# **Contents**

| 1 | Intr | oductio | on                             |         | 4 |
|---|------|---------|--------------------------------|---------|---|
|   | 1.1  | Histor  | rical Context                  |         | 4 |
|   |      | 1.1.1   | MOBA1                          |         | 4 |
|   |      | 1.1.2   | MOBA2                          |         | 5 |
|   | 1.2  | MOB     | BA3                            |         | 6 |
|   |      | 1.2.1   | Design Goals                   |         | 6 |
| 2 | Des  |         | ecification                    |         | 8 |
|   | 2.1  | Comm    | mon Hardware                   |         | 8 |
|   |      | 2.1.1   | Microcontroller                |         | 8 |
|   |      | 2.1.2   | Bus Transceivers               |         | 8 |
|   |      | 2.1.3   | Multi-Pin Input and Output     |         | 9 |
|   | 2.2  | Data 1  | Bus Specification              |         | 9 |
|   |      | 2.2.1   | Local Bus Specification        | <br>. 1 | 0 |
|   |      | 2.2.2   | Remote Bus Specification       |         | 0 |
|   | 2.3  | Data '  | Transmission Format            | <br>. 1 | 1 |
|   |      | 2.3.1   | Binary Encoding and Endianness |         |   |
|   |      | 2.3.2   | Display Command                | <br>. 1 | 2 |
|   |      | 2.3.3   | Decoder Command                | <br>. 1 | 2 |
|   |      | 2.3.4   | Button Event                   | <br>. 1 | 3 |
| 3 | Har  | dware S | Support                        | 1       | 4 |
|   | 3.1  | Switch  | ches                           | <br>. 1 | 4 |
|   | 3.2  | Signal  | ds                             | <br>. 1 | 4 |
|   | 3.3  | Lighti  | ing                            | <br>. 1 | 5 |
| 4 | Circ | uit Boa | pards                          | 1       | 6 |
|   | 4.1  | Contro  | roller Board                   | <br>. 1 | 6 |
|   | 4.2  | I/O Ir  | Interface Board                | <br>. 1 | 7 |
|   |      | 4.2.1   | Input Connectors               | <br>. 1 | 7 |
|   |      | 4.2.2   | Output Connectors              | <br>. 1 | 8 |
|   | 4.3  | Decod   | der Boards                     | <br>. 1 | 9 |
|   |      | 4.3.1   | General Purpose Decoder        | <br>. 2 | 0 |
|   |      | 122     | Switch Decoder                 | 2       | 1 |

| 5 | Dec | ecoder Type Specifications |  |  |  |  |  |  |  |  |
|---|-----|----------------------------|--|--|--|--|--|--|--|--|
|   | 5.1 | Switch Decoder             |  |  |  |  |  |  |  |  |
|   |     | 5.1.1 Pinout               |  |  |  |  |  |  |  |  |
|   |     | 5.1.2 Command Structure    |  |  |  |  |  |  |  |  |
|   | 5.2 | Exit Signal Decoder        |  |  |  |  |  |  |  |  |
|   |     | 5.2.1 Pinout               |  |  |  |  |  |  |  |  |
|   |     | 5.2.2 Command Structure    |  |  |  |  |  |  |  |  |
|   | 5.3 | Entry Signal Commands      |  |  |  |  |  |  |  |  |
|   |     | 5.3.1 Pinout               |  |  |  |  |  |  |  |  |
|   |     | 5.3.2 Command Structure    |  |  |  |  |  |  |  |  |
|   | 5.4 | Light Decoder              |  |  |  |  |  |  |  |  |
|   |     | 5.4.1 u - Update Ouput     |  |  |  |  |  |  |  |  |
|   |     | 5.4.2 c - Clear with Mask  |  |  |  |  |  |  |  |  |
|   |     | 5.4.3 s - Set with Mask    |  |  |  |  |  |  |  |  |
|   |     | 5.4.4 r - Disable Output   |  |  |  |  |  |  |  |  |
|   |     | 5.4.5 o - Enable Output    |  |  |  |  |  |  |  |  |

## 1 Introduction

The Moba3 control system is designed as a replacement for previous control systems. This upgrade is a complete rework and removes all legacy components from previous versions. Such a step is obviously not taken without careful consideration.

This document outlines the history of the Moba control systems and presents the rationale behind the move to a completely new system. It also presents the design goals for the new Moba system. Finally it serves as a full specification and documentation of both the hardware and software.

The documentation does not provide detailed information about the software implementation. It only aims to specify the communications interfaces. Details about software internals and precise decoder operation are deliberately excluded.

### 1.1 Historical Context

During the construction of the current model railway the decision was made to use traditional analog control for the trains. Many models were not yet equipped with digital decoders and a retrofit would have been exceedingly expensive. Since no industry standard digital solution was used for the train control, the decision was made to design and construct a custom digital control solution for all other components of the railway. This solution would provide push button based control from a schematic control board to control all switches, signals and all lighting.

#### 1.1.1 MOBA1

A first design used custom control and decoder boards based on the PIC16F527 microcontroller. The entire railway was divided into 5 sectors:

Shadow station, left entry to main station, right entry to main station, track switches and lighting.

Each sector had a *master* board embedded in the control board that controlled up to 16 push buttons, 16 LEDs on the control board and continuously transmitted a single 8-bit data packet to the decoders in the railway. This packet did not encode commands but rather a fixed *desired state*. Each decoder would receive the current state data and check what modifications to its own outputs had to be done to conform to that state.

As a consequence each decoder required bespoke decoding logic. The data also had to be encoded very efficiently to fit the fixed-length packet. The sector *right entry to main station* for example controlled 6 switches, 2 entry signals, 4 exit signals and could drive up to 2 independent paths at once.

Each packet contained a single *even parity bit* was packed between start and end marker bits:

Table 1.1: Packet structure

Transmission was done over a custom unshielded single-ended single-wire data bus with a relatively low baudrate and every bit of data was transmitted over 3 bus clock cycles.

| encoded bit | transmitted sequence |
|-------------|----------------------|
| START       | 000                  |
| 0           | 100                  |
| 1           | 110                  |
| END         | 111                  |

Table 1.2: bit encoding

#### 1.1.2 MOBA2

During construction and testing of the first system it became clear that this was highly limited: Each sector had its own *master* board and these were not able to exchange any data. Additionally programs for the PIC16F527 microcontroller needed to be written in MIPS Assembly, which made high-level software design difficult.

It was therefore decided to move the high-level control logic onto a RaspberryPi 3 (RPi) single-board computer. This allowed for programming of the control logic in high-level languages (Java was used).

The master boards for each sector now no longer managed the entire control logic. It simply transmitted the button states to the RPi and received both the states of the control board LEDs and the sector status packet from the RPi. Communication between the RPi and the master boards was done using SPI in mode (0,0).

The decoders in the railway and the previously described transmission scheme remained in place. Over time this system showed its weaknesses: A model railway is inherently a high-EMI environment. Relay-based switch drivers and brushed motors, for example, produce significant interference. But the transmission scheme was not designed with EMI resistance in mind: An unshielded single-ended serial bus is obviously not suited for

such environments. As a consequence we observed many transmission errors. To solve this, very extensive error detection was required which slowed the data busses down significantly. Additional problems manifested themselves as soon as microcontrollers from another batch were introduced: The microcontrollers all used internal 4MHz RC oscillators. But the bus required relatively tight timings to avoid reception errors. This could be partially solved by calibrating each decoder controller to the frequency of its master board. In the end we were forced to introduce a self-calibration routine that would calibrate each microcontroller based on the incoming serial data signal. This routine would run at every startup and whenever the decoder had too many transmission errors. The issues of transmission errors could however never be completely solved.

### 1.2 MOBA3

The issues outlined above eventually lead to the decision to introduce a full redesign before the model railway was completed. This new solution would be designed with EMI-resistance in mind from the beginning. It would make away with the sector concept and the state transmissions. A single controller board would control the entire railway and the decoders would use unified software.

### 1.2.1 Design Goals

The full redesign of the control system allowed for the definition of clear design goals. These are outlined in the following sections.

### Stability and Standardisation

The first iterations used a lot of custom concepts and hardware solutions. For the redesign we specifically chose to replace many of the custom design elements with industry standard solutions where applicable. Where industry solutions are not directly transferrable, they should at least be adapted to our needs. The design would also account for the interference issues observed with previous iteration wherever possible.

#### Improved Commonality

The entire system shall use common hardware design as far as feasible: All boards should use the same microcontroller type and common areas of the PCBs should use identical routing, component and mounting hole positions. Different decoder types should also share as much hardware as possible. Care must be taken that this not lead to an overly unified PCB design that tries to cover all possible use cases. But where external connectivity requirements are shared between multiple decoder types it shall be attempted to use common hardware. Behavioural distinctiveness should – where possible – be provided through software only.

### **Ease of Develoment**

The microcontroller type chosen should allow for easy software development in C/C++. It should also facilitate debugging and prototyping. Each board should have a clearly defined set of responsibilities as this complicates both development and testing. E.g. a switch decoder should only be responsible for receive switching commands and for driving the switch motors.

The PCBs should also support in-circuit reprogramming. Previous iterations required extraction of the microcontrollers for reprogramming. This made development and testing more tedious and increased the risk for premature wear on the boards and damage to the microcontrollers.

### **Scalabilty**

The entire system should be easily scalable through the addition of additional decoders or decoder types. Where sensible address spaces shall be defined large enough for substantial increase of the number of decoders. The entire system shall support at least 50% more decoders per type as is required on introduction.

# 2 Design Specification

The Moba3 control system consists of a central controller board (CTRB), an I/O interface board (IIB) and several decoder boards (decoder). The I/O interface board handles button presses, forwards them to the controller board and drives the control panel LEDs based on commands received from the controller board. The controller board processes button presses and issues corresponding commands to the I/O interface board and the decoders. The decoders are not as smart as with previous system iterations and do not require bespoke software. Moba3 supports numerous decoder types, each designed for a specific purpose. At the moment there are decoders for switches, station entry signals, station exit signals and lighting.

### 2.1 Common Hardware

To facilitate design and scalability we defined a set of common hardware to be used for all board types. This defines common set of components that should be used if required. Additional components can be introduced on specific boards if needed.

#### 2.1.1 Microcontroller

Each board uses a single central microcontroller. The model used is an ATmega328p. This is the exact same microcontroller as is used on *Arduino Uno* and *Arduino Nano* boards. This allows for easy prototyping and debugging using that board. The microcontroller is provided with an external clock signal from a 16Mhz crystal oscillator. All configuration fuses are set identically to microcontrollers on Arduino boards. This commonality in configuration between Arduino boards and our Moba3 boards also facilitate testing and development.

#### 2.1.2 Bus Transceivers

The data busses (specified below) require RS422/RS485 transceiver chips. All transceivers should be from the MAX481 transceiver family or compatible hardware. The MAX481 family consists of multiple different transceivers in different configurations (simplex, half-duplex, full-duplex, etc.). Any component of this family can be used and for each board the best suited one can be selected.

### 2.1.3 Multi-Pin Input and Output

For multi-pin I/O the individual pins should not be connected directly to the micro-controller. PISO and POSI circuits should be used instead. Standard ICs used for Arduino-based applications are the CD4021 and 74HC595 ICs for input and output respectively. These are buffered shift registers that can be daisy chained.

The CD4021 is an 8-bit shift register with parallel load functionality. This makes it useful for parallel-to-serial data input.

The 74HC595 is an 8-bit shift register with a tri-state buffered parallel output. This makes it useful for serial-to-parallel data output.

Both shift registers can be read and written using SPI hardware in mode (0,0).

### 2.2 Data Bus Specification

The Moba3 control system is based on a UART serial bus with a baudrate of  $9600.^1$  The data is transmitted over differential pairs on an RS422/RS485 derived serial bus. The differential pairs are driven using MAX481 compatible transceivers operating at 5V. Physically the data bus uses 8P8C (RJ45) connections for both power (5V only) and data. There are 2 busses: The local bus and the remote bus. To improve EMI resistance shielded CAT6a cabling<sup>2</sup> is used. Low power decoders can be powered directly by the bus, higher power decoders do require external power delivery. Some decoders may require additional voltages. These should always use external power delivery. Any externally powered decoder also provides power to the bus. The current draw on a single connection in the bus is limited to 600mA. Care must be taken to ensure that no bus segment exceeds this limit. This can be solved either by introducing additional external power connections where required or by simply connecting decoders strategically -e.g. alternating high-current decoders and low current decoders. In a scenario where a single bus powered decoder is connected between 2 externally powered decoders that bus powered decoder could theoretically pull up to 1.2A assuming equal cable lengths.<sup>3</sup>

#### **Bus Loading and Biasing**

In a deviation from the RS422 specification the bus does not need to be terminated. Each decoder loads the differential pair with a  $10k\Omega$  resistor. This loading introduces a theoretical limit on the number of supported decoders to around 150. But this is very

<sup>&</sup>lt;sup>1</sup>higher baudrates up to 2 Mbaud are theoretically possible

<sup>&</sup>lt;sup>2</sup>S/FTP with a grounded shield

<sup>&</sup>lt;sup>3</sup>The resistance of each cable depends on the cable length. When mismatched cable lengths are used it must be ensured that no single cable exceeds the 600mA limit. If e.g. one cable is 1m long and the other one 2m long, 2/3 of the current will flow through the 1m long cable. In that scenario the entire structure would be limited to 900mA. In general if the cable lengths differ by a factor n, the current limit would be (n+1)/n \* 600mA.

obviously only a theoretical limit and does not need to be considered further. In case the system should be used for an application with more than around 100 decoders we suggest the introduction active repeaters.

The differential pair is also not biased. The loading resistor equalises the voltage potential in the differential pair on disconnected decoders. The MAX481 transceiver will always read equal voltages as a logical 0. The transmitters are always powered. For situations where the busses are correctly connected biasing becomes irrelevant as the transmitters will always drive the differential pair.

### 2.2.1 Local Bus Specification

The *local bus* is a full-duplex bus used for communication between the central CTRB and the IOIB that manages I/O on the control panel. 2 differential pairs are used for bidirectional data transmission, the remaining 2 are used for power.

| pin | colour | function | description                               |
|-----|--------|----------|-------------------------------------------|
| 1   | G/     | MOSI_B   | CTRB transmission, negative channel       |
| 2   | G      | MOSI_A   | CTRB transmission, positive channel       |
| 3   | O/     | MISO_B   | IOIB transmission, negative channel       |
| 4   | В      | GND      | ground wire                               |
| 5   | В/     | GND      | ground wire                               |
| 6   | O      | MISO_A   | IOIB board transmission, positive channel |
| 7   | Br/    | VCC      | 5V power                                  |
| 8   | Br     | VCC      | 5V power                                  |

Table 2.1: local bus RJ45 pinout

The *local bus* is a a direct connection bus between the CTRB and the IOIB and must connect exactly one of each of these devices.

#### 2.2.2 Remote Bus Specification

The remote bus is a simplex bus used for communication between the CTRB and the decoders. The decoders are connected using daisy chaining. It only carries data from the CTRB to the decoders. The differential pair used for IOIB transmissions on the local bus is used for connection sensing on the remote bus: Each decoder feeds back power through this pair to the previous board in the chain. This allows for easy identification of a break in the chain. It also ensures that in case a decoder is connected to the local port the CTRB is presented with a permanently idle IOIB transmission channel.

Please note that it is not required for the controller transmission channels for the 2 busses are separated. The controller is allowed to transmit all data on both channels. It is however recommended that each channel is driven by a separate transceiver. The

| pin | colour | function | description                         |
|-----|--------|----------|-------------------------------------|
| 1   | G/     | MOSI_B   | CTRB transmission, negative channel |
| 2   | G      | MOSI_A   | CTRB transmission, positive channel |
| 3   | O/     | STATUS-  | sensing feedback ground connection  |
| 4   | В      | GND      | ground wire                         |
| 5   | В/     | GND      | ground wire                         |
| 6   | O      | STATUS+  | sensing feedback 5V                 |
| 7   | Br/    | VCC      | 5V power                            |
| 8   | Br     | VCC      | 5V power                            |

Table 2.2: remote bus RJ45 pinout

decoders can simply pass through the differential pair and use stub connections to their local receivers. If required it is also possible to add repeating transceivers to the chain. This should however not be necessary as the specified design should tolerate distances of more than 100m.

### 2.3 Data Transmission Format

Unlike the previous systems Moba3 transmits commands, not states. All commands follow a common structure, but each decoder type defines its own payload semantics. It is however generally required that all commands are human readable and restricted to the printable ASCII character set. Each command is transmitted as a line terminated by a line break (n) character.

There are 3 line formats: display command and decoder command lines are transmitted by the CTRB. button event lines are transmitted by the IOIB.

### 2.3.1 Binary Encoding and Endianness

Since we are restricted to the printable ASCII character set we need to use an alphanumeric encoding for binary data. A hexadecimal encoding is used, where for each byte the high nibble is transmitted before the log nibble. For example, the number 0x2f would be transmitted as the sequence 2f. Hexadecimal values are always transmitted in lowercase letters.

Multi-byte values also use a hexadecimal encoding. The bytes are ordered in *big-endian*: The least significant byte is transmitted first and the most significant byte is transmitted last. For example, the 16-bit number 0xba42 is transmitted as the sequence 42ba. This holds true for values of any size.

### 2.3.2 Display Command

Display commands begin with a constant character prefix D. This is followed by a 12 character hexadecimal encoding of the 48-bit display data. Each bit of the display data directly corresponds to a single LED on the control board. The display data (data) is treated as a single 6 bytes long unsigned integer.

Table 2.3: display command structure

Example: D012436fdea12n Regex: D[0-9a-f]{12}n

### 2.3.3 Decoder Command

Decoder commands start with a type selector (type) and a decoder address (addr). After this common prefix a decoder specific payload of arbitrary length (pld) can follow. The command is terminated – as always – with a line break. While theoretically arbitrary, the payload length should not exceed 12 characters.

| 0    | 1                      | 2#pld + 2 | #pld + 3 |
|------|------------------------|-----------|----------|
| type | HEX(addr) <sub>0</sub> | pld       | \n       |

Table 2.4: decoder command structure

### Type Selector

The type selector indicates the decoder type the command is relevant for. Each decoder type has a unique type selector associated with it. Type selectors are always capital letters.

| type | decoder type                        |
|------|-------------------------------------|
| A    | station exit signals                |
| D    | reserved: used for display commands |
| Е    | station entry signals               |
| L    | lighting                            |
| W    | railway switches                    |

Table 2.5: assigned type selectors

#### **Decoder Address**

The second byte encodes the decoder address. The address is a hex-encoded 4-bit number. This is a special case where hexadecimal numbers do not use an even number of characters. At the moment all addresses must lie in the range 1..9, but it is possible to relax this to the entire 0..f range in a future revision. In addition to a specific address there is also a *broadcast address* that is accepted by all decoders of a specific type. This address is the character "+".

### **Command Payload**

The payload pld is an arbitrary character sequence with a minimum length of 1 and a maximum length of 12. The payload must match the regular expression [a-z0-9!]{1,12}. This limitation is primarily introduced to ensure that no command payload contains uppercase letters. These could be incorrectly interpreted by a decoder as the start of a command line. The list of allowed characters may be expanded in future revisions.

Regex:  $[AELW][0-9+][a-z0-9!]{1,12}\n$ 

#### 2.3.4 Button Event

The IOIB continuously monitors the states of all push buttons on the control panel. Whenever a change in a button state is detected, a corresponding *button event* is sent from the IOIB to the CTRB.

Each button has a 1 byte button address (addr). As the third character, a direction identifier (dir) is sent. When a new button is pressed, a key-down event is sent, when a button is released, a key-up event is sent.

| 01        | 2   | 3  |
|-----------|-----|----|
| HEX(addr) | dir | \n |

Table 2.6: button event data structure

| event type     | dir |
|----------------|-----|
| key-down event | +   |
| key-up event   | -   |

Table 2.7: button event direction identifiers

Examples:  $23+\n$ ,  $1a-\n$ Regex:  $[1-4][0-9a-f][+-]\n$ 

# 3 Hardware Support

### 3.1 Switches

MOBA3 supports magnetic switch motors including *Märklin* articles 74491 and 75491 and *ROCO* article 10030. Older *Märklin* K switches with integrated motors are also supported.

MOBA3 limits the active time for all motors. Therefore there is no need for limit switches in any switch motors. They can be used but if there are issues with the driving power it is recommended to disable limit switches in the switch motors.

### 3.2 Signals

MOBA3 supports swiss type L home signals and distance signals with up to 4 lights. The lights for the main signals are labelled top-down as G, R, O and G'. The lights for the distance signals are labelled clockwise starting in the top left corner as o', o'', g' and g''. The supported signal aspects are the following:<sup>4</sup>



Table 3.1: supported type L signal aspects

 $<sup>^{4}</sup>$ FDV R300.2 A2020 d – sections 5.2.2 - 5.2.7

# 3.3 Lighting

MOBA3 does not place any restrictions on the type of lighting that can be used: The light decoders provide simple digital outputs. These do not carry a lot of power and should not be used to power lighting elements directly.

The recommended way to power external lighting is to use an NMOS transistor that switches the load to ground.



Figure 3.1: example driving circuit for lighting

# 4 Circuit Boards

At the moment there are 4 board designs in use: The controller board (CTRB), the I/O Interface Board (IOIB), a general purpose decoder board and the switch decoder board. The general purpose decoder board is used for all signal decoders and for light decoders. All boards have many similarities in component selection, circuitry and routing.

All boards use a 3 pin power connector. Usually only pins 1 and 2 are used for ground and 5V respectively. Pin 3 can be used to provide an additional voltage to the board.

### 4.1 Controller Board



Figure 4.1: controller board (CTRB)

The controller board (CTRB) is the simplest of the PCB designs currently in use. It only contains a power connector (POWER1), a microcontroller with the associated circuitry and 2 RJ45 connectors with their corresponding transceiver chips. J2 is a mirrored AVR-ICP-6<sup>5</sup> connector: The pinout nearly matches a standard AVR-ICP-6 interface, but the top and bottom rows are swapped.

Each RJ45 connector is used for one of the two busses: J4 provides a connection to the *local bus*. J5 is used for the *remote bus*. It is recommended that this board is always externally powered to provide a power injection point for both busses.

<sup>&</sup>lt;sup>5</sup>in-circuit programming connector used for AVR microprocessors

### 4.2 I/O Interface Board



Figure 4.2: I/O interface board (IOIB)

The I/O interface board (IOIB) monitors the push-buttons and drives the LEDs of the control panel.

The POWER1 and J2 connector are identical to those on the CTRB. The singular RJ45 connector J4 connects to the *local bus*. The remaining connectors handle *input* and *output*.

### 4.2.1 Input Connectors

The control panel buttons are divided into 4 sectors of up to 16 buttons each. The IOIB regularly scans all 4 sectors individually.

The buttons need to be wired in a very specific way: Each sector has a common feed pin. One terminal of all buttons in one sector needs to be tied to this feed pin. The second terminal is connected to one of the 16 sense pins through a series diode. This diode needs to be oriented with the anode connected to the button and the cathode to the sense pin. This arrangement leads to a button matrix where for every combination of feed pin sense pin there is exactly one button between these two. That way when powering the feed pin of one sector the sense pins of all currently pressed buttons of that sector are powered.

The 4-pin connector J1 exposes the 4 feed pins for the 4 sectors. The 16-pin connector J3 exposes the 16 sense pins. All pins of J3 require an external pull-down resistor: The sense pins do posses some stray capacitance. Due to the diode arrangement residual charges may not dissipate sufficiently quickly through leakage currents alone. A relatively high resistance<sup>6</sup> should be used to not overload the button diodes.

The figure below shows a possible wiring solution. The horizontal rows 1 and 2 are *feed pins*. The vertical rows A and B are *sense pins*. It is irrelevant on which side of the button the diode is attached as long as it retains its orientation.



Figure 4.3: button matrix schemtic

### **Button Addressing**

The following simple formula provides a simple way to calculate the button address from a combination of a feed pin and a sense pin:

$$addr = 16 * (feed - 1) + sense - 1$$

Example: Button 4 of sector 2 would have the button id 0x13.<sup>7</sup>

### 4.2.2 Output Connectors

The remaining connectors (J5, J6 and J7) handle *output - i.e.* the control panel LEDs. Each connector provides signals for 16 LEDs. These pins are directly connected to the 74HC595 shift registers. While low-power devices could be directly connected to these digital pins it is recommended to use these pins only to drive the gates on external NMOS

 $<sup>^6{\</sup>rm about}~10{\rm k}\Omega$  should work fine

<sup>&</sup>lt;sup>7</sup>pin numbers are 1-indexed

transistors. In that configuration the NMOS does not require a pull-down resistor on the gate pin as the IOIB pins are always actively driven.

The 3 connectors are arranged in software as 6 bytes of data. J5 exposes the 2 least significant bytes while J7 exposes the 2 most significant bytes. On each connector pin 1 is the least significant bit of the less significant byte.

|                                     | J5 |                                     | J6 | J7                                  |           |  |
|-------------------------------------|----|-------------------------------------|----|-------------------------------------|-----------|--|
| pins 1-8   pins 9-16                |    | pins 1-8   pins 9-16                |    | pins 1-8                            | pins 9-16 |  |
| data <sub>0</sub> data <sub>1</sub> |    | data <sub>2</sub> data <sub>3</sub> |    | data <sub>4</sub> data <sub>5</sub> |           |  |

Table 4.1: output pin assignments

### 4.3 Decoder Boards

The decoder boards share much of the basic hardware. Specifically the power connector, the programming header and the 2 RJ45 connectors are all arranged identically on all decoders. Also the microprocessor and all basic support components share common placement and trace routing.



Figure 4.4: common area of decoder PCBs

On the decoder boards the 2 RJ45 connectors are used for daisy chaining the remote bus. The connector J4 is used as the input - i.e. the connection to the CTRB or a previous board. The second connector - J5 - is the output. This connector is used to connect to the next board in the chain. At the last board in the chain this connector can simply be left disconnected and no bus termination is required.

The power connector (POWER1) can be used to externally power the decoder and to provide power to the bus. On low-power boards it can be left unpopulated or disconnected.

The 6-channel DIP-switch SW1 can be used to provide configuration data to the microprocessor. This could – for example – be used to configure the decoder type and address. The header is provided on all decoders but is not required to be populated if not needed by a decoder.

Please note that the mounting holes are plated and the plating is connected to the ground plane of the board. To ensure balanced currents on the bus power wires it is recommended to ensure that the mounting screws – and thereby the mounting holes – remain electrically isolated from any external ground connection on boards that are bus powered. On externally powered boards this isolation is not required.

### 4.3.1 General Purpose Decoder



Figure 4.5: general purpose decoder board

Many functions of the control system require simple digital – or low-power – pins. The general purpose decoder provides a generic hardware platform for all these uses. It is the simplest of the decoder boards and is used for all signal decoders and for lighting. This board exposes up to 16 pins that are directly wired to the parallel output of two 74HC595 shift registers. The pins do have tri-state support. This feature can of course be controlled by the individual decoder software.

The connectors J1 and J3 expose the 16 output pins. J1 holds the first 8 pins, J3 the rest. In a situation where less than 9 pins are used the header J3 and the shift register U10 can remain unpopulated. When using the output pins to directly power external components it must be ensured that each pin does not exceed the maximum pin current and each connector does not exceed the maximum port current for the specific shift register used. Power usage should probably be kept below 10mA per pin.

In some situation the output pins may be used as open collectors to power low power devices (e.g. LEDs). These do require a power supply. If the board is bus-powered the power supply to the external devices should also be taken from the board to keep the

currents through the power cables on the bus balanced. The power may either be taken from the POWER1 connector or from the auxiliary pin J6 which is also connected to the 5V rail of the board.

#### 4.3.2 Switch Decoder



Figure 4.6: switch decoder board

Currently the only decoder type with bespoke hardware is the switch decoder. Each switch decoder allows control of up to 6 switches.

J1 and J3 provide open collector connections for 3 switches each. The first pin of each switch should always be connected to the motor pole that pulls the switch into the *straight-through* position.

Each pin is switched to ground through an NMOS transistor with a MOSFET driver IC to minimise switching times. In addition each pin is also connected to a flyback diode. Switch motors are usually inductive loads and when switching of a motor pole a voltage spike may occur that could be destructive to the switching transistor. The on-board high-current schottky diodes protect the transistors from any such voltage spikes.

A connection to the power supply voltage of the switches is required for the flyback diodes to work properly. The generally unused third pin of the power connector (POWER1) is connected to the cathode of all flyback diodes. It should be connected to the 24V power rail powering the switches. Failure to connect the 24V rail could lead to destructive failure of the NMOS transistors due to the drain-source voltage exceeding its limit. For this reason it is recommended to verify a stable connection upon installation. A voltage measurement between the cathode of any flyback diode and an exposed mounting hole plating can be used for this purpose.

# 5 Decoder Type Specifications

Each decoder type has its own behaviour and command structure. The decoder command structures in essence define an *instruction set* of instructions sent from the CTRB to the decoders to control the model railway. The following sections provide detailed specifications for all currently supported decoder types and their individual commands.

### 5.1 Switch Decoder

Each switch decoder controls up to 6 switches at once. The switches have a limited drive time (2000ms) after which the switch motor is disabled. The switching time limits are handled for each switch individually. While the relatively long switching time should allow switches to fully transition during a switching action.

It is possible that simultaneous switching actions drop the supply voltage. To avoid this issue it is recommended to send switch commands sequentially over some time. That way each switch can profit from the full power of the power supply capacitors and between the switching actions the power supply can recover.

#### **5.1.1** Pinout

| J1          |   |   |   |    | J3  |    |     |    |     |    |     |
|-------------|---|---|---|----|-----|----|-----|----|-----|----|-----|
| 1 2 3 4 5 6 |   |   |   |    | 1   | 2  | 3   | 4  | 5   | 6  |     |
| a           | b | a | b | a  | b   | a  | b   | a  | b   | a  | b   |
| Sw          |   |   |   | Sv | 7 3 | Sw | v 4 | Sw | 7 5 | Sv | v 6 |

Table 5.1: switch decoder pinout

### 5.1.2 Command Structure

The switch decoders can receive commands for any number of switches at once.

Table 5.2: switch command structure

Each  $(sid_i, cmd_i)$  pair is treated as a single command for one switch.  $sid_i$  is the switch id (1-6) for which  $cmd_i$  should be executed. It is not allowed to send two commands for one switch within a single packet. If multiple commands are sent for a single switch the decoder behaviour is not defined. Currently there are 3 supported commands:

| cmdi | command                        |
|------|--------------------------------|
| a    | move switch to straight track  |
| b    | move switch to diverging track |
| !    | reapply previous command       |

Table 5.3: supported switch commands

Switches are moved by the commands a and b. Generally a decoder will drive a switch motor if it believes a switch to already be in the desired position -i.e. repeated commands are ignored. There are however situations where a switch is in a different position than the decoder has driven it to: A switch could have been moved manually or the switch power supply may have been unpowered when the decoder last drove the switch motor. For these situations the command! was introduced. It repeates the previous command for the switch.

Example: W21a2b3!4a5b6!\n

Regex:  $W[1-9+]([1-6][ab!]){1,6}\n$ 

### 5.2 Exit Signal Decoder

Each exit signal decoder can control up to 4 exit signals with up to 4 signal LEDs each. While full 4-LED signals are supported signals with reduced capabilities can also be connected and the pins for unsupported LEDs can simply remain disconnected. Such a "degraded" signal would simply be incapable of showing some aspects -e.g. a 3-LED signal without G' would be incapable of displaying aspect  $\bf 3$  and would simply show aspect  $\bf 1$  instead. A signal with only 2 LEDs -G and R — would only be able to show aspects  $\bf 0$  and  $\bf 1$ . Any other aspects would be displayed as aspect  $\bf 1$ .

The power-on idle state for all signals is aspect  $\mathbf{0}$ .

|             | signal aspect |   |   |   |  |  |
|-------------|---------------|---|---|---|--|--|
| signal type | 0             | 1 | 2 | 3 |  |  |
| 2 LEDs      | X             | X |   |   |  |  |
| 3 LEDs      | X             | X | X |   |  |  |
| 4 LEDs      | X             | X | X | X |  |  |

Table 5.4: aspects supported by different signals

### **5.2.1** Pinout

The decoder drives the signal LEDs directly similarly to an open-collector setup. The LEDs need to be powered with 5V – just like the decoder itself. The pins are not using tristate control. The pins for LEDs that should be disabled are pulled high and pins for active LEDs are pulled to ground.

The pins are mapped as follows:

| J1               |                |                |                |                 |                |                | Ј3             |                 |                |                |       |                 |                |                |                |
|------------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|-----------------|----------------|----------------|-------|-----------------|----------------|----------------|----------------|
| 1                | 2              | 3              | 4              | 5               | 6              | 7              | 8              | 1               | 2              | 3              | 4     | 5               | 6              | 7              | 8              |
| G <sub>1</sub> ' | O <sub>1</sub> | R <sub>1</sub> | G <sub>1</sub> | G' <sub>2</sub> | O <sub>2</sub> | R <sub>2</sub> | G <sub>2</sub> | G' <sub>3</sub> | O <sub>3</sub> | R <sub>3</sub> | $G_3$ | G' <sub>4</sub> | O <sub>4</sub> | R <sub>4</sub> | G <sub>4</sub> |
| Signal 1         |                |                | Sign           | al 2            |                |                | Sign           | al 3            |                |                | Sign  | al 4            |                |                |                |

Table 5.5: exit signal decoder pinout

### 5.2.2 Command Structure

Similar to switch commands the exit signal commands can carry up to 4 individual signal commands.

Table 5.6: exit signal command structure

Each  $(sid_i, cmd_i)$  pair is treated as a single command for one exit signal.  $sid_i$  is the signal id. For this id the signals 1-4 are labelled as a-d. The command  $cmd_i$  sets the signal aspect for the signal. These are transmitted as their aspect number. It is illegal to send multiple commands targeting a single signal. In this case the behaviour is undefined.

Example: A1a0b1c2c3\n

Regex:  $A[1-9+]([a-d][0-3])\{1,4\}\n$ 

### 5.3 Entry Signal Commands

The entry signal decoders support up to 2 entry signals. Entry signals are combined home and distance signals. The home signal displays the signal aspect for the entry while the distance signal announces the aspect of the exit signal at the end of the station track the train is directed to. The distance signals always require all 4 LEDs but the home signals can use less if the unsupported aspects are not needed.

The power-on idle state for all home signals is aspect  $\mathbf{0}$  while the distance signals are disabled. The distance signals are always disabled while the corresponding home signal displays aspect  $\mathbf{0}$ .

#### **5.3.1** Pinout

The decoder drives the LEDs directly. Just like with the exit signals the signals need to be powered with 5V.

The pins are mapped as follows:

|         | J1                          |     |                  |                  |                             |                |                |                  |        |      | J3               |                  |                |                |                |
|---------|-----------------------------|-----|------------------|------------------|-----------------------------|----------------|----------------|------------------|--------|------|------------------|------------------|----------------|----------------|----------------|
| 1       | 2                           | 3   | 4                | 5                | 6                           | 7              | 8              | 1                | 2      | 3    | 4                | 5                | 6              | 7              | 8              |
| $g_1''$ | $g_1'$                      | o'' | o <sub>1</sub> ′ | G <sub>1</sub> ' | O <sub>1</sub>              | R <sub>1</sub> | G <sub>1</sub> | g <sub>2</sub> " | $g_2'$ | o″   | o <sub>2</sub> ' | G <sub>2</sub> ' | O <sub>2</sub> | R <sub>2</sub> | G <sub>2</sub> |
| dis     | distance signal home signal |     |                  |                  | distance signal home signal |                |                |                  |        | ıl   |                  |                  |                |                |                |
|         | Signal 1                    |     |                  |                  |                             |                |                |                  |        | Sign | nal 2            |                  |                |                |                |

Table 5.7: entry signal decoder pinout

### 5.3.2 Command Structure

Each command can carry up to 2 individual commands for the different signals.

| 0 | 1    | 3i - 1 | 3i    | 3i+1              | 3n+2 |  |
|---|------|--------|-------|-------------------|------|--|
| Е | addr | sidi   | homei | dist <sub>i</sub> | \n   |  |

Table 5.8: entry signal command structure

Each 3 character sequence  $(sid_i, home_i, dist_i)$  encodes the command for one signal. The signal id  $sid_i$  is either a or b. This identifies signals 1 and 2 respectively. Both  $home_i$  and  $dist_i$  encode a signal aspect. The home signal aspect is encoded by  $home_i$  while the distance signal is encoded by  $dist_i$ . When  $home_i$  is 0 the value of  $dist_i$  is ignored. This information is irrelevant since the distance signal is turned off whenever the home signal shows aspect  $\mathbf{0}$ .

The distance signal aspects are transmitted as their corresponding home signal aspects. The aspect  $2^*$  – for example – would be transmitted as 2.

It is illegal to send two commands targeting a single signal. In this case the behaviour is undefined.

Example: E1a10b32\n

Regex:  $E[1-9+]((a|b)[0-3]{2}){1,2}\n$ 

### 5.4 Light Decoder

Besides controlling railway related components (switches and signals) Moba also provides lighting control through light decoders. Each light decoder provides control for 16 individually controlled digital output pins. These are directly controlled by commands. It is possible to update the entire decoder at once. The outputs can also be adjusted through bit-level manipulation fo the output pins. To support these different interaction possiblities the light decoder provides not one but 5 different commands.

The different commands are provided both for normal use and for testing purposes. It is possible to fully control lighting by only using basic u-based update commands.

### 5.4.1 u - Update Ouput

| 0 | 1    | 2 | 36        | 7  |
|---|------|---|-----------|----|
| L | addr | u | hex(data) | \n |

Table 5.9: light decoder command u

This command receives a 2-byte number encoding the data for all 16 output pins. The data is encoded in a simple bit map: Bit 0 encodes pin 1, bit 1 encodes pin 2, etc.

Example: L2u0a1f\n

Regex:  $L[1-9+]u[0-9a-f]{4}\n$ 

### 5.4.2 c - Clear with Mask

| 0 | 1    | 2 | 36        | 7  |
|---|------|---|-----------|----|
| L | addr | С | hex(data) | \n |

Table 5.10: light decoder command  ${\tt c}$ 

This command receives a 2-byte number encoding a 16-bit mask. This mask is applied to the output pins each pin for which the corresponding bit in the flag is set is disabled. The command c0902 for example would clear pins 1, 4 and 10 of the decoder.

Example: L2c0a1f\n

Regex:  $L[1-9+]c[0-9a-f]{4}\n$ 

### 5.4.3 s - Set with Mask

Table 5.11: light decoder command s

This command receives a 2-byte number encoding a 16-bit mask. This mask is applied to the output pins each pin for which the corresponding bit in the flag is set is enabled. The command s0902 for example would set pins 1, 4 and 10 of the decoder.

Example: L2s0a1f\n

Regex:  $L[1-9+]s[0-9a-f]{4}\n$ 

### 5.4.4 r - Disable Output

Table 5.12: light decoder command r

The simples command is the single-character command r. This command clears all output pins. This command is equivalent to the longer L?u0000\n.

Example: L2r\n Regex: L[1-9+]r\n

### 5.4.5 o - Enable Output

Table 5.13: light decoder command r

The second trivial command is the single-character command o. This command clears all output pins. This command is equivalent to the longer L?offff\n.

Example: L2o\n Regex: L[1-9+]o\n