B&B Electronics manual 232SDD16 Commands, Equivalent Values, Syntax, Data Bytes

Page 7

Chapter 3 - Commands

There are only two commands required to control the 232SDD16: set output lines, and read I/O lines. Three additional commands are used for configuring the module: define I/O lines, set power-up states, and read configuration. Command strings are from four to six bytes in length; the “!” character, the “0” (zero) character, two command characters, and one or two data bytes, if required. (See Table 3.1).

Table 3.1 - 232SDD16 Commands

Function

 

Command

Response

 

 

 

 

Set Output Lines

 

!0SO{I/O msb}{I/O lsb}

no response

Read I/O Lines

 

!0RD

{I/O msb}{I/O lsb}

Define I/O Lines

 

!0SD{I/O msb}{I/O lsb}

no response

Set Power-up States

 

!0SS{I/O msb}{I/O lsb}

no response

 

 

 

I/O Definitions

Read Configuration

 

!0RC

{I/O msb}{I/O lsb}

 

 

 

Power-up States

 

 

 

{I/O msb}{I/O msb}

Symbols: {...} represents one byte

 

 

<...> represents a numeric value

Before going into the specifics of each command, it is important to understand that a byte has a numeric value from 0 to 255. The byte's value can be represented in decimal (0 -255) format, hexadecimal (00 - FF) format, binary (00000000 - 11111111) format or as an ASCII character. The fixed bytes of each command will be represented as ASCII characters, for example: “!0RD”. Refer to Table 3.1. However, it is important to remember that an ASCII character has a numeric value. Example: the ASCII “0” (zero) does not have a value of zero but has a value of 48. The decimal and hexadecimal equivalents of some ASCII characters are shown in Table 3.2. Some commands require additional data bytes to complete the command. These data bytes may be represented in any of the formats listed above. Refer to Appendix A for more ASCII and decimal equivalents.

232SDD16-1005 Manual

9

Table 3.2 - Equivalent Values

ASCII

Decimal

Hexadecimal

 

 

 

!

33

21h

0

48

30h

C

67

43h

D

68

44h

O

79

4Fh

R

82

52h

S

83

53h

Syntax

Command strings consists of four to six bytes. The first byte is the start of message byte. The start of message byte is always the ASCII “!” character. The second byte is the address byte. This byte allows each unit to have a unique address (useful in RS-485 networks). Since the 232SDD16 uses RS-232 communications, this byte is always the ASCII “0” character and can not be changed. The next two bytes are the command characters. These bytes are ASCII characters and used to specify which command will be executed by the module. Some commands require an argument field. This field contains the fifth and sixth data byte, a Most Significant and a Least Significant data byte respectively.

Command Syntax: !

0

_

_

_

_

6th Data Byte

5th Data Byte

2nd Command Byte

1stCommand Byte

Address Byte

 

 

Start of Message Byte

I/O Data Bytes

When constructing commands to manipulate outputs lines or when reading the state of the I/O lines it is necessary to know how to select and interpret the I/O data bytes. The sixteen I/O lines are represented by two data bytes. The Most Significant data byte represents I/O lines #15 through #8 and the Least Significant data byte represents I/O lines #7 through #0. The Most Significant byte is always sent and received first followed by the Least Significant byte.

10

232SDD16-1005 Manual

B&B Electronics -- PO Box 1040 -- Ottawa, IL 61350

B&B Electronics -- PO Box 1040 -- Ottawa, IL 61350

PH (815) 433-5100 -- FAX (815) 433-5104

PH (815) 433-5100 -- FAX (815) 433-5104

Image 7
Contents Designed and Manufactured Ottawa, Illinois Electronics Mfg. Co. IncInternet Table of Contents Introduction 232SDD16 Features232SDD16-1005 Manual Communications 232SDD16 SpecificationsSize Serial Port Connections ConnectionsDigital I/O Connections 232SDD16 I/O Port Pinout232SDD16 To DCE Connections RS-232 Connector PinoutPower Supply Connections 232SDD16 To DTE ConnectionsSyntax Commands232SDD16 Commands Equivalent ValuesSet Output Lines Command Read I/O Lines CommandBit Assignments for I/O Lines Set Power-up States Command Define I/O Lines CommandRead Configuration Command Bin. Example !0RC01010101010000010101000001000000 Digital Inputs InterfacingIsolated Solid State Input Programming Techniques SoftwareDigital I/O Mask Values MSstates = MSstates or mask LSstates = LSstates or mask Set Output States CommandMSdefs = MSdefs and mask LSdefs = LSdefs and mask MSpups = MSpups and mask LSpups = LSpups and maskMSdefs = MSdefs and NOTmask LSdefs = LSdefs and NOTmask Define I/O Lines CommandSet Power-up States Command MSdefs = MSdefs or mask LSdefs = LSdefs or maskRunning Demonstration Program Demonstration ProgramAppendix a Appendix B Decimal to Hexadecimal Conversion 232SDD16-1005 Manual Appendix C Figure C.1 DTB25 Outline DrawingTable C.2 DBM16 I/O Connections Table C.1 DTB25 ConnectionsDBM16 Interfacing Figure C.2 DBM16 Outline DrawingFigure C.6 Isolated Solid State Input Inputs DBM16 Specifications LinesOutputs 232SDD16-1005 Manual Appendix C Comp = not x and &HFF #0RDMsb~ I/O msbI/O lsb ~ I/O lsb 00FF01FE232SDD16-1005 Manual Appendix D Table D-1 Extended Commands