B&B Electronics 485SDD16 Manual De Usuario

Descargar
Página de 28
 
485SDD16-1005 Manual 
 
25 
B&B Electronics  --  707 Dayton Road  --  Ottawa, IL  61350 
PH (815) 433-5100  --  FAX (815) 433-5104
 
 
Step 1b - Set appropriate outputs LOW 
MSstates = MSstates AND (NOT(mask)) 
LSstates = LSstates AND (NOT(mask))
 
By "ANDing" the current states with the complement of the 
appropriate mask of a digital output line, the output's bit will be set 
to a "0" (LOW). 
Step 1c - Completing the command string: 
Cmnd$ = "!" + CHR$(Maddr) + "SO" + CHR$(MSstates) + 
CHR$(LSstates) 
Step 2 - Transmitting the command string: 
Print #1, Cmnd$; 
 
Example 5.3 - Set Output #0 HIGH and Output #14 LOW of module 
#5. 
'Set module address. 
Maddr = 5 
'Set bit 0 of LSstates to make Output #0 HIGH. 
LSstates = LSstates OR &H1 
'Clear bit 4 of MSstates to make Output #14 LOW. 
MSstates = MSstates AND (NOT(&H40)) 
Cmnd$ = "!" + CHR$(Maddr) + "SO" + CHR$(MSstates) + 
CHR$(LSstates) 
PRINT #1, Cmnd$; 
Output #0 will be set HIGH and output #14 will be set LOW of 
module #5.  All other output settings of module #5 will not be 
changed. 
 
Define I/O Lines Command 
 
The Define I/O Lines command is used to define each of the 
module's I/O lines as either an input or an output.  This command 
requires two data bytes.  Refer to this command in Chapter 3 for 
more information. 
Step 1a - Construct the command string: 
Define an I/O line as Output 
MSdefs = MSdefs OR mask 
LSdefs = LSdefs OR mask
 
By "ORing" the current definitions with the appropriate I/O line 
mask, the I/O line's data bit will be set to a "1" (HIGH) and the I/O 
line will be defined as an Output. 
26 485SDD16-1005 
Manual 
B&B Electronics  --  707 Dayton Road  --  Ottawa, IL  61350 
PH (815) 433-5100  --  FAX (815) 433-5104
 
Step 1b - Define an I/O line as an Input 
MSdefs = MSdefs AND (NOT(mask)) 
LSdefs = LSdefs AND (NOT(mask))
 
By "ANDing" the current definitions with the complement of the 
appropriate I/O line mask the I/O line's data bit will be set to a "0" 
(LOW) and the I/O line will be defined as an Input. 
Step 1c - Completing the command string: 
Cmnd$ = "!" + CHR$(Maddr) + "SD" + CHR$(MSdefs) + 
CHR$(LSdefs) 
Step 2 - Transmitting the command string: 
Print #1, Cmnd$; 
 
Example 5.4 - Define I/O line #7 as an Output (HIGH) and I/O line #8 
as an input (LOW) on module #4. 
'Set module's address to 4. 
Maddr = 4 
'Set bit 7 of LSdefs to make I/O line #7 an Output (HIGH). 
LSdefs = LSdefs OR &H80 
'Clear bit 0 of MSdefs to make I/O line #8 an Input (LOW). 
MSdefs = MSdefs AND (NOT(&H1)) 
Cmnd$ = "!" + CHR$(Maddr) + "SD" + CHR$(MSdefs) + 
CHR$(LSdefs) 
PRINT #1, Cmnd$; 
MSIO$ = INPUT$(1,#1) 
I/O #7 will be defined as an Output (HIGH) and I/O line #8 will be 
defined as an Input (LOW) of module #4.  All other I/O definitions will 
not be changed. 
 
Set Power-up States Command 
 
The Set Power-up States command is used to set the states of 
the digital outputs at power-up.  This command requires two data 
bytes.  Refer to this command in Chapter 3 for more information. 
Step 1a - Construct the command string: 
Set appropriate outputs power-up states HIGH 
MSpups = MSpups OR mask 
LSpups = LSpups OR mask
 
By "ORing" the current power-up states with the appropriate mask 
of a digital output line, the power-up state's data bit will be set to a 
"1" (HIGH).