28
Packet Checksum
The above charts show that at the end of each packet, a checksum
word is available for reading.
Although host to chip set I/O operations are extremely reliable, for
critical applications the checksumcan provide a further reliability
enhancement (particularly in very noisy electrical environments, or
when the communication signals are routed over a media that may
have data losses such as a serial link).
This checksumconsists of a 16-bit sumof all previous communications
that have occurred for the associated command. The command byte is
included in the low byte of the 1st checksumword (high byte set to 0).
Data words are added as is to the checksumvalue.
For example if a SET_VEL command (which takes two 16-bit words of
data) was sent with a data value of fedcba98 (hex), the checksum
would be:
0011
+ fedc
+ ba98
----------
1b985
check sum= b985 (keep bottom16 bits only)
(code for SET_VEL command)
(high data word)
(low data word)
Reading the checksumis optional. Recovering froman incorrect packet
transfer (bad checksum will depend on the nature of the packet. Read
and Write operations can always be re-transmtted, while a command
resulting in an action may or may not be re-tried, depending on the
command and the state of the axis.
Illegal Commands
When the MC1231A receives a command that is illegal (see host
command summary for listing of illegal commands), it will signal this
condition by returning a checksumof 0, regardless of the illegal
command value or the value of any subsequent data written to the host
as part of the illegal command sequence.
In this manner the host processor checksumcan be used to detect
communication problems as well as an illegal command sequence,
resulting in a simplification of the host processor communication code.
Command Errors
If a command, or command sequence is sent to the chipset that is not
valid at a given operating condition of the chipset, but is valid at other
times, this command is said to cause a command error.
When a command error occurs this condition is indicated by the
'command error' bit of the axis status word (See the section of this
manual entitled "Axis Status" for more information on the axis status
word).
The following list indicates the command sequences that result in a
command error:
-
Changing and updating the acceleration (SET_ACC, UPDATE)
when in the trapezoidal profile mode and when the axis
trajectory is still in motion.
-
Changing and updating either the velocity, max acceleration, or
jerk (SET_VEL or SET_MAX_ACC or SET_JERK, and then
UPDATE) when in the S-curve profiling mode and when the
trajectory is in motion
-
Commanding a move in the same direction as a limt switch
condition when in Trapezoidal or S-curve profile mode. For
example if travelling in the positive direction and a limt switch
is encountered, a further move in the positive direction will be
ignored and a command error will be generated.
Once a command error occurs the command error bit is set, and the
illegal profile changes are ignored. If additional parameters are also
changed such as position or any filter values as part of the same
UPDATE command then these parameters will not be rejected at the
time of the UPDATE, and they will become the active values.
Axis Addressing
Most chip set commands alter the parameters or the operating state of
one axis at a time. In this way each axis can be controlled separately.
To facilitate efficient communication for these types of commands, the
chip set maintains the concept of a current axis number, which can be
set explicitly by the host. After setting the current axis number,
commands that are addressed to the current axis will automatically
operate on this axis. The current axis number will stay the same until it
is changed by one of the commands that alter the current axis number.
As an illustration of this, the following sequence sets the current axis to
#2, updates some motion parameters, and switches to axis #1, and
alters some other motion parameters.
SET_2
SET_POS
-> sets current axis to #2
-> loads current axis (#2) dest.
position with value of 2345678
-
> causes the loaded value to take
effect (axis #2)
-> sets current axis to #1
-> loads current axis (#1) with
acceleration value 1234
-
> causes the loaded value to take
effect (axis #1)
02345678
UPDATE
SET_1
SET_ACCEL
00001234
UPDATE