5 – gpio port 6 register descriptions, 1 – gpio direction register port 6 (pd6), 2 – gpio output register port 6 (po6) – Maxim Integrated DS4830 Optical Microcontroller User Manual
Page 133: 3 – gpio input register for port 6 (pi6), Gpio port 6 register descriptions, Gpio direction register port 6 (pd6), Gpio output register port 6 (po6), Gpio input register for port 6 (pi6)

DS4830 User’s Guide
133
15.5
– GPIO Port 6 Register Descriptions
Port 6 provides seven GPIO pins that are multiplexed with the test access port (TAP), DAC, Sample trigger input, PWM 
and ADC. 
ADC function is enabled when PINSEL.n is set to ‘1’ (where n = 4, 5, 10 or 11). Single or Differential ADC
mode is selected by ADDATA.DIFF bit during ADC c
onfiguration (when ADCN.CFG is set to ‘1’). DAC function is enabled
when DACCFG.n is set to either “10b” or “01b” (where n = 2 or 6). PWM is enabled when corresponding PWM local 
enable and PWM master enable is set to ‘1’. 
 
On device reset, the TAP port is active, allowing for in-circuit debugging and programming. The JTAG is active by default 
on Port6.0-
3 and it is disabled when SC.TAP bit is set to ‘0’. Enabled special functions operate on the JTAG ports only if
SC.TAP bit is set to ‘0’. Port 6 also provides GPIO interrupts on all of the pins. The GPIO works only when SC.TAP = 0. A 
GPIO interrupt can be generated when the pin is being operated as a GPIO, or a special or alternate function. Three 
additional registers, EIF6, EIE6, and EIES6 are used to control the GPIO interrupts. Port6.7 is not present in the Port6. 
 
15.5.1 
– GPIO Direction Register Port 6 (PD6)
Bit #
7
6
5
4
3
2
1
0
Name
Reserved
PD6_6
PD6_5
PD6_4
PD6_3
PD6_2
PD6_1
PD6_0
Reset
0
0
0
0
0
0
0
0
Access
r
rw
rw
rw
rw
rw
rw
rw
PD6 is an 8-bit register used to determine the direction of the pins when they are used as GPIO pins. Each pin is 
independently controlled by its direction bit. When PD6.n (n = 0 to 6) is set to 1, the pin is an output; data in the PO6.n bit 
will be driven on the pin. When PD6.n is cleared to 0, the pin is an input, and allows an external signal to drive the pin. 
The P channel pull-up transistor is controlled by the PO6.n bit. If PO6.n is set to 1, the corresponding weak pull-up is 
turned on, if the PO6.n bit is cleared to 0, the weak pull-
up is turned off and the pin’s input is high-impedance.
 
15.5.2 
– GPIO Output Register Port 6 (PO6)
Bit #
7
6
5
4
3
2
1
0
Name
Reserved
PO6_6
PO6_5
PO6_4
PO6_3
PO6_2
PO6_1
PO6_0
Reset
1
1
1
1
1
1
1
1
Access
r
rw
rw
rw
rw
rw
rw
rw
 
PO6 is an 8-bit register that controls the output data of a GPIO pin. If the pin is setup to be an output (PD6.n = 1), the 
data in PO6.n will be output on the pin. If the pin is set as an input (PD6.n = 0), setting PO6.n to a 1 enables a p-channel 
weak pull-
up, otherwise the pin’s input is high impedance.
 
15.5.3 
– GPIO Input Register for Port 6 (PI6)
Bit #
7
6
5
4
3
2
1
0
Name
Reserved
PI6_6
PI6_5
PI6_4
PI6_3
PI6_2
PI6_1
PI6_0
Reset
1
s
s
s
s
s
s
s
Access
r
r
r
r
r
r
r
r
 
PI6 is an 8-bit register which contains the data that is applied to the GPIO pins. The PI6 input register contains valid input 
data even when the pin is not operating as GPIO. The reset value for this register is dependent on the logical states 
applied to the pins. Note that each pin has a weak pull-up circuit when functioning as an input and the P channel pull-up 
transistor is controlled by the PO6.n bit. 
 
15.5.4 
– GPIO Port 6 External Interrupt Edge Select Register (EIES6)
Bit #
7
6
5
4
3
2
1
0
Name
Reserved
IT6
IT5
IT4
IT3
IT2
IT1
IT0
Reset
0
0
0
0
0
0
0
0
Access
r
rw
rw
rw
rw
rw
rw
rw
 
The EIES6 register sets the interrupt edge select to trigger an interrupt on either a rising or falling edge. Setting the 
IESP6_n bits to 
‘0’ will trigger the corresponding interrupt on a positive edge. When these bits are set to a ‘1’, the
interrupt will be on a negative edge.
