General Mechatronics GM6-PCI card based motion control system
For detailed description, please refer to the System integration manual.
The GM6-PCI motion control card is based on an FPGA and a PCI bridge interface ASIC. A small automated manufacturing cell can be controlled, with a short time system integration procedure. The following figure demonstrating the typical connection of devices related to the control system:
-
It can control up to six axis, each can be stepper or CAN bus interface or analogue servo.
-
GPIO: Four time eight I/O pins are placed on standard flat cable headers.
-
RS485 I/O expander modules: RS485 bus was designed for interfacing with compact DIN-rail mounted expander modules. An 8-channel digital input, an 8-channel relay output and an analogue I/O (4x +/-10 Volts output and 8x +/-5 Volts input) modules are available now. Up to 16 modules can be connected to the bus altogether.
-
20 optically isolated input pins: Six times three for the direct connection of two end switch and one homing sensor for each joint. And additionally, two optically isolated E-stop inputs.
Installing:
loadrt hal_gm
During loading (or attempted loading) the driver prints some useful debugging messages to the kernel log, which can be viewed with dmesg.
Up to 3 boards may be used in one system.
The following connectors can be found on the GM6-PCI card:
1. I/O connectors
9 | 7 | 5 | 3 | 1 |
---|---|---|---|---|
IOx/7 |
IOx/5 |
IOx/3 |
IOx/1 |
VCC |
10 | 8 | 6 | 4 | 2 |
---|---|---|---|---|
GND |
IOx/6 |
IOx/4 |
IOx/2 |
IOx/0 |
Each pin can be configured as digital input or output. GM6-PCI motion control card has 4 general purpose I/O (GPIO) connectors, with eight configurable I/O on each. Every GPIO pin and parameter name begins as follows:
gm.<nr. of card>.gpio.<nr of gpio con>
,where <nr of gpio con> is form 0 to 3. For example:
gm.0.gpio.0.in-0
indicates the state of the first pin of the first GPIO connector on the GM6-PCI card. Hal pins are updated by function
gm.<nr of card>.read
1.1. Pins
Pins | Type and direction | Pin description |
---|---|---|
.in-<0-7> |
(bit, Out) |
Input pin |
.in-not-<0-7> |
(bit, Out) |
Negated input pin |
.out-<0-7> |
(bit, In) |
Output pin. Used only when GPIO is set to output. |
1.2. Parameters
Pins | Type and direction | Parameter description |
---|---|---|
.is-out-<0-7> |
(bit, R/W) |
When True, the corresponding GPIO is set to totem-pole output, other wise set to high impedance input. |
.invert-out-<0-7> |
(bit, R/W) |
When True, pin value will be inverted. Used when pin is configured as output. |
2. Axis connectors
1 |
Encoder A |
2 |
+5 Volt (PC) |
3 |
Encoder B |
4 |
Encoder Index |
5 |
Fault |
6 |
Power Enabled |
7 |
Step/CCW/B |
8 |
Direction/CW/A |
9 |
Ground (PC) |
10 |
DAC serial line |
2.1. Axis interface modules
Small sized DIN rail mounted interface modules gives easy way of connecting different types of servo modules to the axis connectors. Seven different system configurations are presented in the System integration manual for evaluating typical applications. Also the detailed description of the Axis modules can be found in the System integration manual.
For evaluating the appropriate servo-drive structure the modules have to be connected as the following block diagram shows:
2.2. Encoder
The GM6-PCI motion control card has six encoder modules. Each encoder module has three channels:
-
Channel-A
-
Channel-B
-
Channel-I (index)
It is able to count quadrature encoder signals or step/dir signals. Each encoder module is connected to the inputs of the corresponding RJ50 axis connector.
Every encoder pin and parameter name begins as follows:
gm.<nr. of card>.encoder.<nr of axis>
,where <nr of axis> is form 0 to 5. For example:
gm.0.encoder.0.position
refers to the position of encoder module of axis 0.
The GM6-PCI card counts the encoder signal independently from LinuxCNC. Hal pins are updated by function:
gm.<nr of card>.read
Pins | Type and direction | Pin description |
---|---|---|
.reset |
(bit, In) |
When True, resets counts and position to zero. |
.rawcounts |
(s32, Out) |
The raw count is the counts, but unaffected by reset or the index pulse. |
.counts |
(s32, Out) |
Position in encoder counts. |
.position |
(float, Out) |
Position in scaled units (=.counts/.position-scale). |
.index-enabled |
(bit, IO) |
When True, counts and position are rounded or reset (depends on index-mode) on next rising edge of channel-I. Every time position is reset because of Index, index-enabled pin is set to 0 and remain 0 until connected hal pin does not set it. |
.velocity |
(float, Out) |
Velocity in scaled units per second. GM encoder uses high frequency hardware timer to measure time between encoder pulses in order to calculate velocity. It greatly reduces quantization noise as compared to simply differentiating the position output. When the measured velocity is below min-speed-estimate, the velocity output is 0. |
Parameters | Type and Read/Write | Parameter description |
---|---|---|
.counter-mode |
(bit, R/W) |
When True, the counter counts each rising edge of the channel-A input to the direction determined by channel-B. This is useful for counting the output of a single channel (non-quadrature) or step/dir signal sensor. When false, it counts in quadrature mode. |
.index-mode |
(bit, R/W) |
When True and .index-enabled is also true, .counts and .position are rounded (based on .counts-per-rev) at rising edge of channel-I. This is useful to correct few pulses error caused by noise. In round mode, it is essential to set .counts-per-rev parameter correctly. When .index-mode is False and .index-enabled is true, .counts and .position are reset at channel-I pulse. |
.counts-per-rev |
(s32, R/V) |
Determine how many counts are between two index pulses. It is used only in round mode, so when both .index-enabled and .index-mode parameters are True. GM encoder process encoder signal in 4x mode, so for example in case of a 500 CPR encoder it should be set to 2000. This parameter can be easily measured by setting .index-enabled True and .index-mode False (so that .counts resets at channel-I pulse), than move axis by hand and see the maximum magnitude of .counts pin in halmeter. |
.index-invert |
(bit, R/W) |
When True, channel-I event (reset or round) occur on falling edge of channel-I signal, otherwise on rising edge. |
.min-speed-estimate |
(float, R/W) |
Determine the minimum measured velocity magnitude at which .velocity will be set as nonzero. Setting this parameter too low will cause it to take a long time for velocity to go to zero after encoder pulses have stopped arriving. |
.position-scale |
(float, R/W) |
Scale in counts per length unit. .position=.counts/.position-scale. For example, if position-scale is 2000, then 1000 counts of the encoder will produce a position of 0.5 units. |
Setting encoder module of axis 0 to receive 500 CPR quadrature encoder signal and use reset to round position.
setp gm.0.encoder.0.counter-mode 0 # 0: quad, 1: stepDir
setp gm.0.encoder.0.index-mode 1 # 0: reset pos at index, 1:round pos at index
setp gm.0.encoder.0.counts-per-rev 2000 # GM process encoder in 4x mode, 4x500=2000
setp gm.0.encoder.0.index-invert 0
setp gm.0.encoder.0.min-speed-estimate 0.1 # in position unit/s
setp gm.0.encoder.0.position-scale 20000 # 10 encoder rev cause the machine to
move one position unit (10x2000)
Connect encoder position to LinuxCNC position feedback:
net Xpos-fb gm.0.encoder.0.position => joint.0.motor-pos-fb
2.3. Stepgen module
The GM6-PCI motion control card has six stepgen modules, one for each joint. Each module has two output signals. It can produce Step/Direction, Up/Down or Quadrature (A/B) pulses. Each stepgen module is connected to the pins of the corresponding RJ50 axis connector.
Every stepgen pin and parameter name begins as follows:
gm.<nr. of card>.stepgen.<nr of axis>
,where nr of axis is form 0 to 5. For example:
gm.0.stepgen.0.position-cmd
refers to the position command of stepgen module of axis 0 on card 0.
The GM6-PCI card generates step pulses independently from LinuxCNC. Hal pins are updated by function
gm.<nr of card>.write
Pins | Type and direction | Pin description |
---|---|---|
.enable |
(bit, In) |
Stepgen produces pulses only when this pin is true. |
.count-fb |
(s32, Out) |
Position feedback in counts unit. |
.position-fb |
(float, Out) |
Position feedback in position unit. |
.position-cmd |
(float, In) |
Commanded position in position units. Used in position mode only. |
.velocity-cmd |
(float, In) |
Commanded velocity in position units per second. Used in velocity mode only. |
Parameters | Type and Read/Write | Parameter description |
---|---|---|
.step-type |
(u32, R/W) |
When 0, module produces Step/Dir signal. When 1, it produces Up/Down step signals. And when it is 2, it produces quadrature output signals. |
.control-type |
(bit, R/W) |
When True, .velocity-cmd is used as reference and velocity control calculate pulse rate output. When False, .position-cmd is used as reference and position control calculate pulse rate output. |
.invert-step1 |
(bit, R/W) |
Invert the output of channel 1 (Step signal in StepDir mode) |
.invert-step2 |
(bit, R/W) |
Invert the output of channel 2 (Dir signal in StepDir mode) |
.maxvel |
(float, R/W) |
Maximum velocity in position units per second. If it is set to 0.0, .maxvel parameter is ignored. |
.maxaccel |
(float, R/W) |
Maximum acceleration in position units per second squared. If it is set to 0.0, .maxaccel parameter is ignored. |
.position-scale |
(float, R/W) |
Scale in steps per length unit. |
.steplen |
(u32, R/W) |
Length of step pulse in nano-seconds. |
.stepspace |
(u32, R/W) |
Minimum time between two step pulses in nano-seconds. |
.dirdelay |
(u32, R/W) |
Minimum time between step pulse and direction change in nano-seconds. |
For evaluating the appropriate values see the timing diagrams below:
Setting stepgen module of axis 0 to generate 1000 step pulse per position unit:
setp gm.0.stepgen.0.step-type 0 # 0:stepDir, 1:UpDown, 2:Quad
setp gm.0.stepgen.0.control-type 0 # 0:Pos. control, 1:Vel. Control
setp gm.0.stepgen.0.invert-step1 0
setp gm.0.stepgen.0.invert-step2 0
setp gm.0.stepgen.0.maxvel 0 # do not set maxvel for step
# generator, let interpolator control it.
setp gm.0.stepgen.0.maxaccel 0 # do not set max acceleration for
# step generator, let interpolator control it.
setp gm.0.stepgen.0.position-scale 1000 # 1000 step/position unit
setp gm.0.stepgen.0.steplen 1000 # 1000 ns = 1 us
setp gm.0.stepgen.0.stepspace1000 # 1000 ns = 1 us
setp gm.0.stepgen.0.dirdelay 2000 # 2000 ns = 2 us
Connect stepgen to axis 0 position reference and enable pins:
net Xpos-cmd joint.0.motor-pos-cmd => gm.0.stepgen.0.position-cmd
net Xen joint.0.amp-enable-out => gm.0.stepgen.0.enable
2.4. Enable and Fault signals
The GM6-PCI motion control card has one enable output and one fault input HAL pins, both are connected to each RJ50 axis connector and to the CAN connector.
Hal pins are updated by function:
gm.<nr of card>.read
Pins | Type and direction | Pin description |
---|---|---|
gm.<nr of card>.power-enable |
(bit, In) |
If this pin is True, * and Watch Dog Timer is not expired * and there is no power fault Then power enable pins of axis- and CAN connectors are set to high, otherwise set to low. |
gm.<nr of card>.power-fault |
(bit, Out) |
Power fault input. |
2.5. Axis DAC
The GM6-PCI motion control card has six serial axis DAC driver modules, one for each joint. Each module is connected to the pin of the corresponding RJ50 axis connector. Every axis DAC pin and parameter name begins as follows:
gm.<nr. of card>.dac.<nr of axis>
,where nr of axis is form 0 to 5. For example:
gm.0.dac.0.value
refers to the output voltage of DAC module of axis 0. Hal pins are updated by function:
gm.<nr of card>.write
Pins | Type and direction | Pin description |
---|---|---|
.enable |
(bit, In) |
Enable DAC output. When enable is false, DAC output is 0.0 V. |
.value |
(float, In) |
Value of DAC output in Volts. |
Parameters | Type and direction | Parameter description |
---|---|---|
.offset |
(float, R/W) |
Offset is added to the value before the hardware is updated |
.high-limit |
(float, R/W) |
Maximum output voltage of the hardware in volts. |
.low-limit |
(float, R/W) |
Minimum output voltage of the hardware in volts. |
.invert-serial |
(float, R/W) |
GM6-PCI card is communicating with DAC hardware via fast serial communication to highly reduce time delay compared to PWM. DAC module is recommended to be isolated which is negating serial communication line. In case of isolation, leave this parameter to default (0), while in case of none-isolation, set this parameter to 1. |
3. CAN-bus servo amplifiers
The GM6-PCI motion control card has CAN module to drive CAN servo amplifiers. Implementation of higher level protocols like CANopen is further development. Currently GM produced power amplifiers has upper level driver which export pins and parameters to HAL. They receive position reference and provide encoder feedback via CAN bus.
The frames are standard (11 bit) ID frames, with 4 byte data length. The baud rate is 1 Mbit. The position command IDs for axis 0..5 are 0x10..0x15. The position feedback IDs for axis 0..5 are 0x20..0x25.
These configuration can be changed with the modifivation of hal_gm.c and recompiling LinuxCNC.
Every CAN pin and parameter name begins as follows:
gm.<nr. of card>.can-gm.<nr of axis>
,where <nr of axis> is form 0 to 5. For example:
gm.0.can-gm.0.position
refers to the output position of axis 0 in position units.
Hal pins are updated by function:
gm.<nr of card>.write
3.1. Pins
Pins | Type and direction | Pin description |
---|---|---|
.enable |
(bit, In) |
Enable sending position references. |
.position-cmd |
(float, In) |
Commanded position in position units. |
.position-fb |
(float, In) |
Feed back position in position units. |
3.2. Parameters
Parameters | Type and direction | Parameter description |
---|---|---|
.position-scale |
(float, R/W) |
Scale in per length unit. |
4. Watchdog timer
Watchdog timer resets at function:
gm.<nr of card>.read
4.1. Pins
Pins | Type and direction | Pin description |
---|---|---|
gm.<nr of card>.watchdog-expired |
(bit, Out) |
Indicates that watchdog timer is expired. |
Watchdog timer overrun causes the set of power-enable to low in hardware.
4.2. Parameters
Parameters | Type and direction | Parameter description |
---|---|---|
gm.<nr of card>.watchdog-enable |
(bit, R/W) |
Enable watchdog timer. It is strongly recommended to enable watchdog timer, because it can disables all the servo amplifiers by pulling down all enable signal in case of PC error. |
gm.<nr of card>.watchdog-timeout-ns |
(float, R/W) |
Time interval in within the gm.<nr of card>.read function must be executed. The gm.<nr of card>.read is typically added to servo-thread, so watch timeout is typically set to 3 times of the servo period. |
5. End-, homing- and E-stop switches
25 | 23 | 21 | 19 | 17 | 15 | 13 | 11 | 9 | 7 | 5 | 3 | 1 |
---|---|---|---|---|---|---|---|---|---|---|---|---|
GND |
1/End- |
2/End+ |
2/Hom-ing |
3/End- |
4/End+ |
4/Hom-ing |
5/End- |
6/End+ |
6/Hom-ing |
E-Stop 2 |
V+ (Ext.) |
26 | 24 | 22 | 20 | 18 | 16 | 14 | 12 | 10 | 8 | 6 | 4 | 2 |
---|---|---|---|---|---|---|---|---|---|---|---|---|
GND |
1/End+ |
1/Hom-ing |
2/End- |
3/End+ |
3/Hom-ing |
4/End- |
5/End+ |
5/Hom-ing |
6/End- |
E-Stop 1 |
V+ (Ext.) |
The GM6-PCI motion control card has two limit- and one homing switch input for each joint. All the names of these pins begin as follows:
gm.<nr. of card>.joint.<nr of axis>
,where nr of axis is form 0 to 5. For example:
gm.0.joint.0.home-sw-in
indicates the state of the axis 0 home switch.
Hal pins are updated by function:
gm.<nr of card>.read
5.1. Pins
Pins | Type and direction | Pin description |
---|---|---|
.home-sw-in |
(bit, Out) |
Home switch input |
.home-sw-in-not |
(bit, Out) |
Negated home switch input |
.neg-lim-sw-in |
(bit, Out) |
Negative limit switch input |
.neg-lim-sw-in-not |
(bit, Out) |
Negated negative limit switch input |
.pos-lim-sw-in |
(bit, Out) |
Positive limit switch input |
.pos-lim-sw-in-not |
(bit, Out) |
Negated positive limit switch input |
5.2. Parameters
Parameters | Type and direction | Parameter description |
---|---|---|
gm.0.estop.0.in |
(bit, Out) |
Estop 0 input |
gm.0.estop.0.in-not |
(bit, Out) |
Negated Estop 0 input |
gm.0.estop.1.in |
(bit, Out) |
Estop 1 input |
gm.0.estop.1.in-not |
(bit, Out) |
Negated Estop 1 input |
6. Status LEDs
6.1. CAN
Color: Orange
-
Blink, during data communication.
-
On, when any of the buffers are full - communication error.
-
Off, when no data communication.
6.2. RS485
Color: Orange
-
Blink, during initialization of modules on the bus
-
On, when the data communication is up between all initialized modules.
-
Off, when any of the initialized modules dropped off because of an error.
6.3. EMC
Color: White
-
Blink, when LinuxCNC is running.
-
Otherwise off.
6.4. Boot
Color: Green
-
On, when system booted successfully.
-
Otherwise off.
6.5. Error
Color: Red
-
Off, when there is no fault in the system.
-
Blink, when PCI communication error.
-
On, when watchdog timer overflowed.
7. RS485 I/O expander modules
These modules were developed for expanding the I/O and function capability along an RS485 line of the GM6-PCI motion control card.
Available module types:
-
8-channel relay output module - gives eight NO-NC relay output on a three pole terminal connector for each channel.
-
8-channel digital input module - gives eight optical isolated digital input pins.
-
8 channel ADC and 4-channel DAC module - gives four digital-to-analogue converter outputs and eight analogue-to-digital inputs. This module is also optically isolated from the GM6-PCI card.
Automatic node recognizing:
Each node connected to the bus was recognized by the GM6-PCI card automatically. During starting LinuxCNC, the driver export pins and parameters of all available modules automatically.
Fault handling:
If a module does not answer regularly the GM6-PCI card drops down the module. If a module with output do not gets data with correct CRC regularly, the module switch to error state (green LED blinking), and turns all outputs to error state.
Connecting the nodes:
The modules on the bus have to be connected in serial topology, with termination resistors on the end. The start of the topology is the PCI card, and the end is the last module.
Addressing:
Each node on the bus has a 4 bit unique address that can be set with a red DIP switch.
Status LED:
A green LED indicates the status of the module:
-
Blink, when the module is only powered, but not jet identified, or when module is dropped down.
-
Off, during identification (computer is on, but LinuxCNC not started)
-
On, when it communicates continuously.
7.1. Relay output module
For pinout, connection and electrical charasteristics of the module, please refer to the System integration manual.
All the pins and parameters are updated by the following function:
gm.<nr. of card>.rs485
It should be added to servo thread or other thread with larger period to avoid CPU overload. Every RS485 module pin and parameter name begins as follows:
gm.<nr. of card>.rs485.<modul ID>
,where <modul ID> is form 00 to 15.
Pins | Type and direction | Pin description |
---|---|---|
.relay-<0-7> |
(bit, Out) |
Output pin for relay |
Parameters | Type and direction | Parameter description |
---|---|---|
.invert-relay-<0-7> |
(bit, R/W) |
Negate relay output pin |
gm.0.rs485.0.relay-0 # First relay of the node.
gm.0 # Means the first GM6-PCI motion control card (PCI card address = 0)
.rs485.0 # Select node with address 0 on the RS485 bus
.relay-0 # Select the first relay
7.2. Digital input module
For pinout, connection and electrical charasteristics of the module, please refer to the System integration manual.
All the pins and parameters are updated by the following function:
gm.<nr. of card>.rs485
It should be added to servo thread or other thread with larger period to avoid CPU overload. Every RS485 module pin and parameter name begins as follows:
gm.<nr. of card>.rs485.<modul ID>
,where <modul ID> is form 00 to 15.
Pins | Type and direction | Pin description |
---|---|---|
.in-<0-7> |
(bit, Out) |
Input pin |
.in-not-<0-7> |
(bit, Out) |
Negated input pin |
gm.0.rs485.0.in-0 # First input of the node.
# gm.0 - Means the first GM6-PCI motion control card (PCI card address = 0)
# .rs485.0 - Select node with address 0 on the RS485 bus
# .in-0 - Select the first digital input module
7.3. DAC & ADC module
For pinout, connection and electrical charasteristics of the module, please refer to the System integration manual.
All the pins and parameters are updated by the following function:
gm.<nr. of card>.rs485
It should be added to servo thread or other thread with larger period to avoid CPU overload. Every RS485 module pin and parameter name begins as follows:
gm.<nr. of card>.rs485.<modul ID>
,where <modul ID> is form 00 to 15.
Pins | Type and direction | Pin description |
---|---|---|
.adc-<0-7> |
(float, Out) |
Value of ADC input in Volts. |
.dac-enable-<0-3> |
(bit, In) |
Enable DAC output. When enable is false DAC output is set to 0.0 V. |
.dac-<0-3> |
(float, In) |
Value of DAC output in Volts. |
Parameters | Type and direction | Parameter description |
---|---|---|
.adc-scale-<0-7> |
(float, R/W) |
The input voltage will be multiplied by scale before being output to .adc- pin. |
.adc-offset-<0-7> |
(float, R/W) |
Offset is subtracted from the hardware input voltage after the scale multiplier has been applied. |
.dac-offset-<0-3> |
(float, R/W) |
Offset is added to the value before the hardware is updated. |
.dac-high-limit-<0-3> |
(float, R/W) |
Maximum output voltage of the hardware in volts. |
.dac-low-limit-<0-3> |
(float, R/W) |
Minimum output voltage of the hardware in volts. |
gm.0.rs485.0.adc-0 # First analogue channel of the node.
# gm.0 - Means the first GM6-PCI motion control card (PCI card address = 0)
# .rs485.0 - Select node with address 0 on the RS485 bus
# .adc-0 - Select the first analogue input of the module
7.4. Teach Pendant module
For pinout, connection and electrical charasteristics of the module, please refer to the System integration manual.
All the pins and parameters are updated by the following function:
gm.<nr. of card>.rs485
It should be added to servo thread or other thread with larger period to avoid CPU overload. Every RS485 module pin and parameter name begins as follows:
gm.<nr. of card>.rs485.<modul ID>
,where <modul ID> is form 00 to 15. Note that on the Teach Pendant module it cannot be changed, and pre-programmed as zero. Upon request it can be delivered with firmware pre-programmed different ID.
Pins | Type and direction | Pin description |
---|---|---|
.adc-<0-5> |
(float, Out) |
Value of ADC input in Volts. |
.enc-reset |
(bit, In) |
When True, resets counts and position to zero. |
.enc-counts |
(s32, Out) |
Position in encoder counts. |
.enc-rawcounts |
(s32, Out) |
The raw count is the counts, but unaffected by reset. |
.enc-position |
(float, Out) |
Position in scaled units (=.enc-counts/.enc-position-scale). |
.in-<0-7> |
(bit, Out) |
Input pin |
.in-not-<0-7> |
(bit, Out) |
Negated input pin |
Parameters | Type and direction | Parameter description |
---|---|---|
.adc-scale-<0-5> |
(float, R/W) |
The input voltage will be multiplied by scale before being output to .adc- pin. |
.adc-offset-<0-5> |
(float, R/W) |
Offset is subtracted from the hardware input voltage after the scale multiplier has been applied. |
.enc-position-scale |
(float, R/W) |
Scale in per length unit. |
gm.0.rs485.0.adc-0 # First analogue channel of the node.
# gm.0 - Means the first GM6-PCI motion control card (PCI card address = 0)
# .rs485.0 - Select node with address 0 on the RS485 bus
# .adc-0 - Select the first analogue input of the module
8. Errata
8.1. GM6-PCI card Errata
The revision number in this section refers to the revision of the GM6-PCI card device.
-
Error: The PCI card do not boot, when Axis 1. END B switch is active (low). Found on November 16, 2013.
-
Reason: This switch is connected to a boot setting pin of FPGA
-
Problem fix/workaround: Use other switch pin, or connect only normally open switch to this switch input pin.