PicPuter

  Home
  Products
  Contact

Using

  Download
  Manual
  Examples
  UserGroup

Development

  Revision
  Future
  Bugs

Other

  DLHexRec
  Modd Audio
  Veracity
  DSP
  Blinky

Miscellaneous

  Links
  Search
  Obsolete
  Site Design
  Disclaimer

 
.
PicPuter 2.0 : Chapter 7 : Registers

All of the internal pic registers can be accessed by name. Some registers like FSR, INFD, and PCLATH do not function in basic but their functions can all be done through other means. These registers were included for use during a disassemble.

Since registers are implemented by the pic hardware, additional information on any of these registers is available , in the __MICROCHIP__ PIC16F87x Programmers Reference Manual at thier website.


7.0 Internal Pic Registers


7.01ADRESH Adress Latch Hi
Reset Defaults:
 PowerOn:   Brownout:   MCLR:   Watchdog:

76543210
D7D6D5D4 D3D2D1D0


[ index | memory | math | statements | variables | registers | assembler ]

7.02ADRESL Adress Latch Low
Reset Defaults:
 PowerOn:   Brownout:   MCLR:   Watchdog:

76543210
D7D6D5D4D3D2D1D0


[ index | memory | math | statements | variables | registers | assembler ]

7.03ADCON0 
Reset Defaults:
 PowerOn:   Brownout:   MCLR:   Watchdog:

76543210
D7D6D5 D4D3D2D1D0


[ index | memory | math | statements | variables | registers | assembler ]

7.04ADCON1 
Reset Defaults:
 PowerOn:0x80   Brownout:0x80   MCLR:unchanged   Watchdog:unchanged

76543210
ADFM---PCFG3PCFG2PCFG1PCFG0

bit 7: ADFM
bit 0,1,2,3: PCFG3-PCFG3

[ index | memory | math | statements | variables | registers | assembler ]

7.05CCPR1H 
Reset Defaults:
7654321 0
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.06CCPR1L 
Reset Defaults:
76543210
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.07CCP1CON 
Reset Defaults:
76543210
---- ------------

[ index | memory | math | statements | variables | registers | assembler ]

7.08CCPR2H 
Reset Defaults:
76543210
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.09CCPR2L 
Reset Defaults:
76543210
-------------- --

[ index | memory | math | statements | variables | registers | assembler ]

7.10CCP2CON 
Reset Defaults:
765432 10
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.11FSR 
Reset Defaults:
76543210
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.12INDF Indirect
Reset Defaults:
76543210
---- ------------

[ index | memory | math | statements | variables | registers | assembler ]

7.13INTCON Interupt Control Register

Interupt Control Register
76543210
GIEPEIET0IEINTERBIET0IFINTFRBIF
Bit 7 : GIE  : Global Interupt Enable
Bit 6 : PEIE : Peripheral Interupt Enable
Bit 5 : T0IE : Timer 0 Interupt Enable
Bit 4 : INTE : PortB.0 Interupt Enable
Bit 3 : RBIE : PortB Interupt Enable
Bit 2 : T0IF : Timer 0 Interupt Flag
Bit 1 : INTF : PortB.0 Interupt Flag
Bit 0 : RBIF : PortB Interupt Flag

[ index | memory | math | statements | variables | registers | assembler ]

7.14OPTION_REG 'OPTION_REG Register'

The Microchip 'OPTION_REG Register'
7654 3210
RBPUINTEDGT0CST0SEPSAPS2PS1PS0

This is the only register that Microchip used an underscore. This exception causes OPTION_REG to be listed as OPTION?REG. I will probably just shorten it to OPTION in future releases.
Bit 7     : RBPU   : PortB Pull Up Enable
Bit 6     : INTEDG : Interupt Edge Select
Bit 5     : T0CS   : Timer 0 Clock Sorce
Bit 4     : T0SE   : Timer 0 Source Enable
Bit 3     : PSA    : Prescale Assignment
Bit 2,1,0 : PS_    : Prescale Rate Select

[ index | memory | math | statements | variables | registers | assembler ]

7.15PCL Assembly PC Low

Assembly Program Counter Low
765432 10
A7A6A5A4A3A2A1A0

[ index | memory | math | statements | variables | registers | assembler ]

7.16PCLATH Assembly PC Latch High

Assembly Program Counter Latch High.
76543210
------A12A11A10A9A8

[ index | memory | math | statements | variables | registers | assembler ]

7.17PCON Power Control

Power Control
76543210
------------PORBOR
Bit 7 : unused :
Bit 6 : unused :
Bit 5 : unused :
Bit 4 : unused :
Bit 3 : unused :
Bit 2 : unused :
Bit 1 : POR    : Power On Reset Flag
Bit 0 : BOR    : Brown Out Reset Flag

[ index | memory | math | statements | variables | registers | assembler ]

7.18PIE1 Peripheral Interupt Enable 1

Peripheral Interupt Enable 1.
76543 210
PSPIEADIERCIETXIESSPIECCP1IETMR2IETMR1IE
Bit 7 : PSPIE  : Parallel Slave port Interupt Enable
Bit 6 : ADIE   : ADC Interupt Enable
Bit 5 : RCIE   : Serial Port Recieve Interupt Enable
Bit 4 : TXIE   : Serial Port Transmit Interupt Enable
Bit 3 : SSPEI  : Syncronous Serial Port Interupt Enable
Bit 2 : CCP1IE : CCP1 Interupt Enable
Bit 1 : TMR2IE : Timer 2 Interupt Enable
Bit 0 : TMR1IE : Timer 1 Interupt Enable

[ index | memory | math | statements | variables | registers | assembler ]

7.19PIE2 Peripheral Interupt Enable 2

Peripheral Interupt Enable 2.
76543 210
------EEIEBCLIE----CCP2IE
Bit 7 : unused :
Bit 6 : unused :
Bit 5 : unused :
Bit 4 : EEIE   : EEProm Write Interupt Enable
Bit 3 : BCLIE  : Bus Collision Interupt Enable
Bit 2 : unused :
Bit 1 : unused :
Bit 0 : CCP2IE : CCP2 Interupt Enable

[ index | memory | math | statements | variables | registers | assembler ]

7.20PIR1 Peripheral Interupt Flag 1

Peripheral Interupt Flag 1.
76543 210
PSPIEADIERCIETXIESSPIECCP1IETMR2IETMR1IE
Bit 7 : PSPIF  : Parallel Slave port Interupt Flag
Bit 6 : ADIF   : ADC Interupt Flag
Bit 5 : RCIF   : Serial Port Recieve Interupt Flag
Bit 4 : TXIF   : Serial Port Transmit Interupt Flag
Bit 3 : SSPIF  : Syncronous Serial Port Interupt Flag
Bit 2 : CCP1IF : CCP1 Interupt Flag
Bit 1 : TMR2IF : Timer 2 Interupt Flag
Bit 0 : TMR1IF : Timer 1 Interupt Flag

[ index | memory | math | statements | variables | registers | assembler ]

7.21PIR2 Peripheral Interupt Flag 2

Peripheral Interupt Flag 2.
Bit 7 : unused :
Bit 6 : unused :
Bit 5 : unused :
Bit 4 : EEIF   : EEProm Write Interupt Flag
Bit 3 : BCLIF  : Bus Collision Interupt Flag
Bit 2 : unused :
Bit 1 : unused :
Bit 0 : CCP2IF : CCP2 Interupt Flag

[ index | memory | math | statements | variables | registers | assembler ]

7.22PORTA IO Port A data

Digital IO PortA data register.
76543 210
----D5D4D3D2D1D0

This register is used to read or write the state of the pins on PORTA. You may use the statements _SETB_ or _CLRB_ to set individual pin output or use a statement like 'PORTA = $0F' to write all of the bits. If the port is set to input data, you may read the entire port by a statement like 'X=PORTA', or you can use the _WAIT_ or _WAITLO_ statements to pause execution until a pin reads HI or LOW.

PortA is also used for the Analog to digital converters, they must be turned off prior to using PortA for digital IO. The ADC converter is turned off by clearing the CONFIGURATOR bit 6 using the statement CLRB CONFIGURATOR 6 or its _CONTRACTION_ CLRCON6 . The register _TRISA_ controls the direction of each pin of the digital IO port.

[ index | memory | math | statements | variables | registers | assembler ]

7.23PORTB IO PortB data

Digital IO PortB data register.
76543210
D7D6D5D4D3D2D1D0

This register is used to read or write the state of the pins on PORTB. You may use the statements _SETB_ or _CLRB_ to set individual pin output or use a statement like 'PORTB = 15' to write all of the bits. If the port is set to input data, you may read the entire port by a statement like 'X=PORTB', or you can use the _WAIT_ or _WAITLO_ statements to pause execution until a pin reads HI or LOW.

PortB bits 2,4,5,6,7 is also used for LCD Port, it must be turned off prior to using these bits of PortB for general purpose digital IO. The LCD port is turned off by clearing the CONFIGURATOR bit 2 using the statement CLRB CONFIGURATOR 2 or its contraction CLRCON2. The register _TRISB_ controls the direction of each pin of the digital IO port.

The remaining bits 0,1,3 are currently unused but future versions may use them to decode a PC keyboard as an alternative input device.

[ index | memory | math | statements | variables | registers | assembler ]

7.24PORTC 
Reset Defaults:
76543210
-------------- --

[ index | memory | math | statements | variables | registers | assembler ]

7.25PORTD IO PortD data

Digital IO PortD data register.
7654 3210
D7D6D5D4D3D2D1D0

This register is used to read or write the state of the pins on PORTD. You may use the statements _SETB_ or _CLRB_ to set individual pin output or use a statement like 'PORTD = 15' to write all of the bits. If the port is set to input data, you may read the entire port by a statement like 'X=PORTD', or you can use the _WAIT_ or _WAITLO_ statements to pause execution until a pin reads HI or LOW.

PortD is shared with the parallel slave port. This feature is unused by PicPuter so all of these bit are avalable for general purpose IO.

[ index | memory | math | statements | variables | registers | assembler ]

7.26PORTE 
Reset Defaults:
7654321 0
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.27PR2 
Reset Defaults:
76543210
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.28RCREG 
Reset Defaults:
76543210
---- ------------

[ index | memory | math | statements | variables | registers | assembler ]

7.29RCSTA 
Reset Defaults:
76543210
----------------

[ index | memory | math | statements | variables | registers | assembler ]

7.30STATUS Status Register

Status Register.
76543210
IRPRP1RP0TOPDZ DCC
Bit 7   : IRP : Indirect Register Bank Select
Bit 6,5 : RP_ : Register Bank Select
Bit 4   : TO  : Timeout Bit
Bit 3   : PD  : Power-Down Bit
Bit 2   : Z   : Zero Bit
Bit 1   : DC  : Digital Carry
Bit 0   : C   : Carry

[ index | memory | math | statements | variables | registers | assembler ]

7.31SSPBUF Syncronous Serial Port TX/RX Buffer

Syncronous Serial Port TX/RX Data Port.
7654 3210
D7D6D5D4D3D2D1D0

[ index | memory | math | statements | variables | registers | assembler ]

7.32SSPCON Syncronous Serial Port Control Register

Syncronous Serial Port Control Register.
76543210
WCOLSSPOVSSPEBCKPSSPM3SSPM2SSPM1SSPM0
Bit 7   : WCOL  : Write Collision Flag
Bit 6   : SSPOV : SSP Recieve Overflow Flag
Bit 5   : SSPEN : SSP Enable
Bit 4   : CKP   : Clock Polarity
Bit 3-0 : SSPM_ : SSP Select Bits

[ index | memory | math | statements | variables | registers | assembler ]

7.33SSPCON2 Syncronous Serial Port Control Register 2

Syncronous Serial Port Control Register 2.
7654 3210
GCEBACKSTATACKDTACKENRCENPENRSENSEN
Bit 7 : GCEB    : I2C General Call Enable
Bit 6 : ACKSTAT : I2C Acknowledge Status Bit
Bit 5 : ACKDT   : I2C Acknowledge Data Bit
Bit 4 : ACKEN   : I2C Acknowledge Sequence Enable
Bit 3 : RCEN    : Recieve Enable Bit
Bit 2 : PEN     : STOP Condition Enable Bit
Bit 1 : RSEN    : Repeat Start Condition Enable
Bit 0 : SEN     : Start Condition Enable Bit

[ index | memory | math | statements | variables | registers | assembler ]

7.34SSPADD I2S Slave Address

I2S Slave Address or I2S Master Baud Rate Register.
7654 3210
D7D6D5D4D3D2D1D0

[ index | memory | math | statements | variables | registers | assembler ]

7.35SSPSTAT Syncronous Serial Port Status Register

Syncronous Serial Port Status Register.
76543210
SMPCKED/APSR/WUABF
Bit 7 : SMP  : Sample Bit
Bit 6 : CKE  : SPI Clock Edge Select
Bit 5 : D/A  : I2C Data / Adress bit
Bit 4 : P    : Stop Bit
Bit 3 : S    : Start Bit
Bit 2 : R/W  : I2C Read Write Info
Bit 1 : UA   : Update Address
Bit 0 : BF   : Buffer Full Status Bit

[ index | memory | math | statements | variables | registers | assembler ]

7.36SPBRG uart baud rate period

Adjusts the serial port baud rate.
76543 210
D7D6D5D4D3D2D1D0


This register is used to set the baud rate of the serial port. Since the serial port timing is dependent on the crystal frequency, its value must also change when a different frequency crystal is used.

To alter the baud rate simply use the chart below to get the correct value for your crystal frequency and desired baud rate. A statement like 'SPBRG=32' changes the baud rate only until the next reset.

It can be change permanently by altering the autoconfig script. More information us avaiable in the serial port section.

CrystalPR2115.257.637.419.29600480024001200
20,275,20019710213265131------
19,353,600188-NA-20-NA-62125251----
18,432,0001799192959119239----
17,510,400170-NA-18 -NA-56113226----
16,588,8001618172653107215----
15,667,200152-NA-16-NA-50101203----
14,745,600143715234795191----
13,824,000134-NA-14-NA-4489179----
12,902,400125613204183167----
11,980,800 116-NA-12-NA-3877155----
11,059,200107511173571143----
10,137,60098-NA-10-NA-3265131----
9,216,0008949142959119239--


While PicPuter will fuction with any crystal frequency, you should use recommended ones because they perfectly divide by the baud rate for the serial port which ensures error free communication.

[ index | memory | math | statements | variables | registers | assembler ]

7.37T1CON Timer 1 Control Register

Timer 1 Control Register.
76543210
-- --T1CKPS1T1CKPS0T1OSCENT1SYNCTMR1CSTMR1ON

Timer1 is unused by PicPuter. PicPuter also has a vector location that can be used to determine when the timer overflows. There are several modes available for Timer 1, consult the _MICROCHIP_ documentation for further information.
Bit 7 : Unused  :
Bit 6 : Unused  :
Bit 5 : T1CKPS1 : Timer 1 Clock Prescale Select Bit 1
Bit 4 : T1CKPS0 : Timer 1 Clock Prescale Select Bit 1
Bit 3 : T1OSCEN : Timer 1 Oscillator Enable Control Bit
Bit 2 : T1SYNC  : Timer 1 External Clock Input Sync Control Bit
Bit 1 : TMR1CS  : Timer 1 Clock Source Select Bit.
Bit 0 : TMR1ON  : Timer 1 On Bit

[ index | memory | math | statements | variables | registers | assembler ]

7.38T2CON Timer 2 Control Register

Timer 2 Control Register.
76543 210
--TOUTP3TOUTP2TOUTP1TOUTP0TMR2ONT2CKPS1T2CKPS0

This register is used by Timer 2 as its control register. Timer2 is used extensively by PicPuter as its time base. It is best just to leave this register alone.
Bit 7 : Unused  :
Bit 6 : TOUTPS3 : Timer 2 Output Postscale Bit 3
Bit 5 : TOUTPS2 : Timer 2 Output Postscale Bit 2
Bit 4 : TOUTPS1 : Timer 2 Output Postscale Bit 1
Bit 3 : TOUTPS0 : Timer 2 Output Postscale Bit 0
Bit 2 : TMR2ON  : Timer 2 On Bit
Bit 1 : T2CKPS1 : Timer 2 Clock Prescale Select Bit 1
Bit 0 : T2CKPS0 : Timer 2 Clock Prescale Select Bit 0

[ index | memory | math | statements | variables | registers | assembler ]

7.39TMR0 Timer 0 Count

Timer 0 Count Register.
765432 10
D7D6D5D4D3D2D1D0

This register is used by Timer 0 as its count. Timer0 is unused by PicPuter. PicPuter has an IRQ vector location that is called whenever an unmasked interupt occurs and CONFIGURATOR SERVICE VECTORS bit is set. There are several modes available for Timer 0, consult the _MICROCHIP_ documentation for furtur information.

[ index | memory | math | statements | variables | registers | assembler ]

7.40TMR1L Timer 1 Count Low

Timer 1 Count Register Least Significant Bits.
76543210
D7D6D5D4D3D2D1D0

Timer1 is unused by PicPuter. This register is used by Timer 1 as the lower 8 bits of its count. PicPuter has an IRQ vector location that is called whenever an unmasked interupt occurs and CONFIGURATOR SERVICE VECTORS bit is set. There are several modes available for Timer 1, consult the _MICROCHIP_ documentation for furtur information.

[ index | memory | math | statements | variables | registers | assembler ]

7.41TMR1H Timer 1 count high

Timer 1 Count Register Most Significant Bits.
76543210
D15D14D13D12D11D10D9D8

This register is used by Timer 1 as the upper 8 bits of its count. Timer1 is unused by PicPuter. PicPuter has an IRQ vector location that is called whenever an unmasked interupt occurs and CONFIGURATOR SERVICE VECTORS bit is set. There are several modes available for Timer 1, consult the _MICROCHIP_ documentation for furtur information.

[ index | memory | math | statements | variables | registers | assembler ]

7.42TMR2 Timer 2 Module Register

Timer 2 count register.
76543210
D7D6 D5D4D3D2D1D0

This register is used by Timer 2 as its count. Timer2 is used extensively by PicPuter as its time base. Since Timer 1 and Timer 0 are unused, it would be better just to use them instead. It would be best just to leave all timer 2 registers alone, unless you want to goof up the clock.

[ index | memory | math | statements | variables | registers | assembler ]

7.43TRISA IO PortA direction

Digital IO PortA direction register.
76543210
----D5D4D3D2D1D0

TRISA controls the direction of each pin of the PORTA digital IO port. Writing a one to a bit sets the pin to an input, writing a zero sets the pin to an output.

PORTA is also used for the Analog to digital converters, they must be turned off before using PortA for digital IO. The ADC converter is turned off by clearing the CONFIGURATOR ADC bit.

[ index | memory | math | statements | variables | registers | assembler ]

7.44TRISB IO PortB direction

Digital IO PortB direction register.
76543210
D7D6D5D4D3D2D1D0

TRISB controls the direction of each pin of the PORTB digital IO port. Writing a one to a bit sets the pin to an input, writing a zero sets the pin to an output.

PortB bits 1,3,4,5,6,7 are also used for LCD Port. The LCD port is turned off by clearing the CONFIGURATOR LCD bit. When the LCD is off, PORTB may be used for general purpose digital IO.

[ index | memory | math | statements | variables | registers | assembler ]

7.45TRISC IO PortC direction

Digital IO PortC direction register.
76543210
D7D6D5D4D3D2D1D0

TRISC controls the direction of each pin of the PORTC digital IO port. Writing a one to a bit sets the pin to an input, writing a zero sets the pin to an output.

Bits 0, 6 and 7 of PORTC are also used for the serial port . Since there is no way to disable the serial port, these bits should remain unchanged.

Bit 1 of PORTC is used for the LED usage monitor, it can be turned off by clearing CONFIGURATOR USAGE LED bit.

Bit 2 of PORTC is used to adjust the contrast for the __LCD__ display, its default value is set int the autoconfig script.

Bits 3 and 4 are used for I2C communications, while PicPuter does not use the I2C for anything, it is possible a future version may use them.

Bits 3, 4 and 5 may be used for I2S communications in the future.

[ index | memory | math | statements | variables | registers | assembler ]

7.46TRISD IO PortD direction

Digital IO PortD direction register.
76 543210
D7D6D5D4D3D2D1D0

TRISD controls the direction of each pin of the PORTD digital IO port. Writing a one to a bit sets the pin to an input, writing a zero sets the pin to an output.

PortD is shared with the parallel slave port and the __ROBOT_PORT__. If neither are being used, all of these bit are avalable for general purpose IO.

[ index | memory | math | statements | variables | registers | assembler ]

7.47TRISE IO PortE direction

Digital IO PortE direction register.
76543210
----------D2D1D0

TRISE controls the direction of each pin of the PORTE digital IO port. Writing a one to a bit sets the pin to an input, writing a zero sets the pin to an output.



[ index | memory | math | statements | variables | registers | assembler ]

7.48TXREG UART Transmit data register

Serial Port Transmit Data Register.
76543210
D7D6D5D4D3D2D1 D0

This register is used by PicPuter each time a character is transmitted through the serial port. I guess you could transmit a character by writing to this register then enabling the serial port using the TXSTA TXEN bit, but this would be a silly way to transmit a character. Instead use the __CPRINT__ statement.

[ index | memory | math | statements | variables | registers | assembler ]

7.49TXSTA UART transmit status and control

Serial Port Transmit Status and Control Register.
76543210
CSRCTX9TXENSYNC--BRGHTRMTTXD9

This register is used to control the serial port, it is used extensively by PicPuter to provide reliable communications via the serial port. In most instances this register should be left alone, but perhaps there is a way for a cleaver PicPuter user to use it to his or her advantage.

Bit 2, the BRGH bit is useful, it divides the serial ports baud rate by a factor of four. Normally this but is set upon reset but you can adjust its default in the autoconfig script.
Bit 7 : CSRC   : Clock Source Select bit
Bit 6 : TX9    : 9 Bit Transmit Enable Bit
Bit 5 : TXEN   : Transmit Enable Bit
Bit 4 : SYNC   : USART Mode Select Bit
Bit 3 : Unused :
Bit 2 : BRGH   : High Baud Rate Select Bit
Bit 1 : TRMT   : Transmit Shift Register Status
Bit 0 : TX9D   : 9th Bit of Transmit Data or Parity.

[ index | memory | math | statements | variables | registers | assembler ]

This webpage is © Copyright 2001,2002,2003 by Todd Modjeski - All Rights Reserved - built Mon Jan 26 22:48:29 2004