Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Details | | |----------------------------|---------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 20MHz | | Connectivity | I <sup>2</sup> C, SPI | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 33 | | Program Memory Size | 3.5KB (2K x 14) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 4V ~ 6V | | Data Converters | - | | Oscillator Type | External | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Through Hole | | Package / Case | 40-DIP (0.600", 15.24mm) | | Supplier Device Package | 40-PDIP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c64a-20i-p | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong FIGURE 3-2: PIC16C62/62A/R62/64/64A/R64 BLOCK DIAGRAM #### FIGURE 7-3: TIMER0 TIMING: INTERNAL CLOCK/PRESCALE 1:2 ## FIGURE 7-4: TMR0 INTERRUPT TIMING #### 7.3 Prescaler **Applicable Devices** 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 An 8-bit counter is available as a prescaler for the Timer0 module or as a postscaler for the Watchdog Timer (WDT), respectively (Figure 7-6). For simplicity, this counter is being referred to as "prescaler" throughout this data sheet. Note that the prescaler may be used by either the Timer0 module or the Watchdog Timer, but not both. Thus, a prescaler assignment for the Timer0 module means that there is no prescaler for the Watchdog Timer, and vice-versa. The PSA and PS2:PS0 bits (OPTION<3:0>) determine the prescaler assignment and prescale ratio. When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g. CLRF TMR0, MOVWF TMR0, BSF TMR0,bitx) will clear the prescaler count. When assigned to the Watchdog Timer, a CLRWDT instruction will clear the Watchdog Timer and the prescaler count. The prescaler is not readable or writable. Note: Writing to TMR0 when the prescaler is assigned to Timer0 will clear the prescaler count, but will not change the prescaler assignment. FIGURE 7-6: BLOCK DIAGRAM OF THE TIMERO/WDT PRESCALER ## 11.2.1 OPERATION OF SSP MODULE IN SPI MODE #### Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 The SPI mode allows 8-bits of data to be synchronously transmitted and received simultaneously. To accomplish communication, typically three pins are used: - · Serial Data Out (SDO) - · Serial Data In (SDI) - · Serial Clock (SCK) Additionally a fourth pin may be used when in a slave mode of operation: Slave Select (SS) When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits in the SSPCON register (SSPCON<5:0>). These control bits allow the following to be specified: - · Master Mode (SCK is the clock output) - · Slave Mode (SCK is the clock input) - Clock Polarity (Output/Input data on the Rising/ Falling edge of SCK) - Clock Rate (Master mode only) - Slave Select Mode (Slave mode only) The SSP consists of a transmit/receive Shift Register (SSPSR) and a Buffer register (SSPBUF). The SSPSR shifts the data in and out of the device, MSb first. The SSPBUF holds the data that was written to the SSPSR, until the received data is ready. Once the 8-bits of data have been received, that byte is moved to the SSPBUF register. Then the Buffer Full bit, BF (SSPSTAT<0>) and flag bit SSPIF are set. This double buffering of the received data (SSPBUF) allows the next byte to start reception before reading the data that was just received. Any write to the SSPBUF register during transmission/reception of data will be ignored, and the write collision detect bit, WCOL (SSPCON<7>) will be set. User software must clear bit WCOL so that it can be determined if the following write(s) to the SSPBUF completed successfully. When the application software is expecting to receive valid data, the SSPBUF register should be read before the next byte of data to transfer is written to the SSPBUF register. The Buffer Full bit BF (SSPSTAT<0>) indicates when the SSPBUF register has been loaded with the received data (transmission is complete). When the SSPBUF is read, bit BF is cleared. This data may be irrelevant if the SPI is only a transmitter. Generally the SSP Interrupt is used to determine when the transmission/reception has completed. The SSPBUF register must be read and/or written. If the interrupt method is not going to be used, then software polling can be done to ensure that a write collision does not occur. Example 11-1 shows the loading of the SSPBUF (SSPSR) register for data transmission. The shaded instruction is only required if the received data is meaningful. ## EXAMPLE 11-1: LOADING THE SSPBUF (SSPSR) REGISTER | | | BSF | STATUS, | RP0 | ;Specify Bank 1 | |----|-----|-------|----------|-----|-------------------| | L( | OOP | BTFSS | SSPSTAT, | BF | ;Has data been | | | | | | | ;received | | | | | | | ;(transmit | | | | | | | ;complete)? | | | | GOTO | LOOP | | ; No | | | | BCF | STATUS, | RP0 | ;Specify Bank 0 | | | | MOVF | SSPBUF, | W | ;W reg = contents | | | | | | | ;of SSPBUF | | | | MOVWF | RXDATA | | ;Save in user RAM | | | | MOVF | TXDATA, | W | ;W reg = contents | | | | | | | ; of TXDATA | | | | MOVWF | SSPBUF | | ;New data to xmit | The block diagram of the SSP module, when in SPI mode (Figure 11-3), shows that the SSPSR register is not directly readable or writable, and can only be accessed from addressing the SSPBUF register. Additionally, the SSP status register (SSPSTAT) indicates the various status conditions. # FIGURE 11-3: SSP BLOCK DIAGRAM (SPI MODE) To enable the serial port, SSP enable bit SSPEN (SSPCON<5>) must be set. To reset or reconfigure SPI mode, clear enable bit SSPEN, re-initialize SSPCON register, and then set enable bit SSPEN. This configures the SDI, SDO, SCK, and \$\overline{SP}\$ pins as serial port pins. For the pins to behave as the serial port function, they must have their data direction bits (in the TRIS register) appropriately programmed. That is: - · SDI must have TRISC<4> set - · SDO must have TRISC<5> cleared - SCK (Master mode) must have TRISC<3> cleared - SCK (Slave mode) must have TRISC<3> set - SS must have TRISA<5> set (if implemented) Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value. An example would be in master mode where you are only sending data (to a display driver), then both SDI and SS could be used as general purpose outputs by clearing their corresponding TRIS register bits. Figure 11-4 shows a typical connection between two microcontrollers. The master controller (Processor 1) initiates the data transfer by sending the SCK signal. Data is shifted out of both shift registers on their programmed clock edge, and latched on the opposite edge of the clock. Both processors should be programmed to the same Clock Polarity (CKP), then both controllers would send and receive data at the same time. Whether the data is meaningful (or dummy data) depends on the application software. This leads to three scenarios for data transmission: - Master sends data Slave sends dummy data - Master sends data Slave sends data - · Master sends dummy data Slave sends data The master can initiate the data transfer at any time because it controls the SCK. The master determines when the slave (Processor 2) is to broadcast data by the software protocol. In master mode the data is transmitted/received as soon as the SSPBUF register is written to. If the SPI is only going to receive, the SCK output could be disabled (programmed as an input). The SSPSR register will continue to shift in the signal present on the SDI pin at the programmed clock rate. As each byte is received, it will be loaded into the SSPBUF register as if a normal received byte (interrupts and status bits appropriately set). This could be useful in receiver applications as a "line activity monitor" mode. In slave mode, the data is transmitted and received as the external clock pulses appear on SCK. When the last bit is latched interrupt flag bit SSPIF (PIR1<3>) is set The clock polarity is selected by appropriately programming bit CKP (SSPCON<4>). This then would give waveforms for SPI communication as shown in Figure 11-5 and Figure 11-6 where the MSB is transmitted first. In master mode, the SPI clock rate (bit rate) is user programmable to be one of the following: - Fosc/4 (or Tcy) - Fosc/16 (or 4 Tcy) - Fosc/64 (or 16 Tcy) - · Timer2 output/2 This allows a maximum bit clock frequency (at 20 MHz) of 5 MHz. When in slave mode the external clock must meet the minimum high and low times. In sleep mode, the slave can transmit and receive data and wake the device from sleep. #### FIGURE 11-4: SPI MASTER/SLAVE CONNECTION #### 11.5.1.2 RECEPTION When the $R/\overline{W}$ bit of the address byte is clear and an address match occurs, the $R/\overline{W}$ bit of the SSPSTAT register is cleared. The received address is loaded into the SSPBUF register. When the address byte overflow condition exists, then no acknowledge (ACK) pulse is given. An overflow condition is defined as either bit BF (SSPSTAT<0>) is set or bit SSPOV (SSPCON<6>) is set. An SSP interrupt is generated for each data transfer byte. Flag bit SSPIF (PIR1<3>) must be cleared in software. The SSPSTAT register is used to determine the status of the byte. ## FIGURE 11-25: I<sup>2</sup>C WAVEFORMS FOR RECEPTION (7-BIT ADDRESS) TABLE 12-5: BAUD RATES FOR ASYNCHRONOUS MODE (BRGH = 1) | BAUD<br>RATE<br>(K) | FOSC = 2 | % ERROR | SPBRG<br>value<br>(decimal) | 16 MHz<br>KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | 10 MHz<br>KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | 7.16 MH<br>KBAUD | z<br>%<br>ERROR | SPBRG<br>value<br>(decimal) | |---------------------|----------|---------|-----------------------------|-----------------|------------|-----------------------------|-----------------|------------|-----------------------------|------------------|-----------------|-----------------------------| | 9.6 | 9.615 | +0.16 | 129 | 9.615 | +0.16 | 103 | 9.615 | +0.16 | 64 | 9.520 | -0.83 | 46 | | 19.2 | 19.230 | +0.16 | 64 | 19.230 | +0.16 | 51 | 18.939 | -1.36 | 32 | 19.454 | +1.32 | 22 | | 38.4 | 37.878 | -1.36 | 32 | 38.461 | +0.16 | 25 | 39.062 | +1.7 | 15 | 37.286 | -2.90 | 11 | | 57.6 | 56.818 | -1.36 | 21 | 58.823 | +2.12 | 16 | 56.818 | -1.36 | 10 | 55.930 | -2.90 | 7 | | 115.2 | 113.636 | -1.36 | 10 | 111.111 | -3.55 | 8 | 125 | +8.51 | 4 | 111.860 | -2.90 | 3 | | 250 | 250 | 0 | 4 | 250 | 0 | 3 | NA | - | - | NA | - | - | | 625 | 625 | 0 | 1 | NA | - | - | 625 | 0 | 0 | NA | - | - | | 1250 | 1250 | 0 | 0 | NA | - | - | NA | - | - | NA | - | - | | BAUD | Fosc = 5 | 5.068 MHz | SPBRG | 4 MHz | | SPBRG | 3.579 MI | Ηz | SPBRG | 1 MHz | | SPBRG | 32.768 I | kHz | SPBRG | |-------------|----------|------------|--------------------|--------|------------|--------------------|----------|------------|--------------------|--------|------------|--------------------|----------|------------|--------------------| | RATE<br>(K) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | | 9.6 | 9.6 | 0 | 32 | NA | - | - | 9.727 | +1.32 | 22 | 8.928 | -6.99 | 6 | NA | - | - | | 19.2 | 18.645 | -2.94 | 16 | 1.202 | +0.17 | 207 | 18.643 | -2.90 | 11 | 20.833 | +8.51 | 2 | NA | - | - | | 38.4 | 39.6 | +3.12 | 7 | 2.403 | +0.13 | 103 | 37.286 | -2.90 | 5 | 31.25 | -18.61 | 1 | NA | - | - | | 57.6 | 52.8 | -8.33 | 5 | 9.615 | +0.16 | 25 | 55.930 | -2.90 | 3 | 62.5 | +8.51 | 0 | NA | - | - | | 115.2 | 105.6 | -8.33 | 2 | 19.231 | +0.16 | 12 | 111.860 | -2.90 | 1 | NA | - | - | NA | - | - | | 250 | NA | - | - | NA | - | - | 223.721 | -10.51 | 0 | NA | - | - | NA | - | - | | 625 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 1250 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | NA | - | - | **Note:** For the PIC16C63/R63/656A/R65 the asynchronous high speed mode (BRGH = 1) may experience a high rate of receive errors. It is recommended that BRGH = 0. If you desire a higher baud rate than BRGH = 0 can support, refer to the device errata for additional information or use the PIC16C66/67. TABLE 13-12: INITIALIZATION CONDITIONS FOR ALL REGISTERS (Cont.'d) | Register | Applicable Devices | | | | | | | | Power-on Reset<br>Brown-out<br>Reset | MCLR Reset during: - normal operation - SLEEP WDT Reset | Wake-up via<br>interrupt or<br>WDT Wake-up | | | | | | | |----------|--------------------|----|-----|-----|----|-----|----|-----|--------------------------------------|-----------------------------------------------------------|--------------------------------------------|-----|----|----|-----------|-----------|-----------| | TRISD | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 1111 1111 | 1111 1111 | uuuu uuuu | | TRISE | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0000 -111 | 0000 -111 | uuuu -uuu | | PIE1 | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 00 0000 | 00 0000 | uu uuuu | | | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0000 0000 | 0000 0000 | uuuu uuuu | | PIE2 | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0 | 0 | u | | PCON | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0u | uu | uu | | FCON | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0- | u- | u- | | PR2 | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 1111 1111 | 1111 1111 | 1111 1111 | | SSPADD | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0000 0000 | 0000 0000 | uuuu uuuu | | SSPSTAT | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 00 0000 | 00 0000 | uu uuuu | | TXSTA | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0000 -010 | 0000 -010 | uuuu -uuu | | SPBRG | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | 0000 0000 | 0000 0000 | uuuu uuuu | $<sup>\</sup>label{eq:local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_$ Note 1: One or more bits in INTCON, PIR1 and/or PIR2 will be affected (to cause wake-up). <sup>2:</sup> When the wake-up is due to an interrupt and the global enable bit, GIE is set, the PC is loaded with the interrupt vector (0004h) after execution of PC + 1. <sup>3:</sup> See Table 13-10 and Table 13-11 for reset value for specific conditions. NOP No Operation Syntax: [label] NOP Operands: None Operation: No operation Status Affected: None Encoding: 0000 0xx00000 Description: No operation. Words: Cycles: 1 Q3 Q4 Q Cycle Activity: Q1 Q2 Decode No-No-No-Operation Operation Operation NOP | RETFIE | Return fr | om Inter | rupt | | | | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|--------------------|--|--|--|--|--| | Syntax: | [ label ] | RETFIE | | | | | | | | | Operands: | None | | | | | | | | | | Operation: | $\begin{array}{c} TOS \to P \\ 1 \to GIE \end{array}$ | PC, | | | | | | | | | Status Affected: | None | | | | | | | | | | Encoding: | 0.0 | 0000 | 0000 | 1001 | | | | | | | Description: | Return from Interrupt. Stack is POPed and Top of Stack (TOS) is loaded in the PC. Interrupts are enabled by setting Global Interrupt Enable bit, GIE (INTCON<7>). This is a two cycle instruction. | | | | | | | | | | Words: | 1 | | | | | | | | | | Cycles: | 2 | | | | | | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | | | | | 1st Cycle | Decode | No-<br>Operation | Set the<br>GIE bit | Pop from the Stack | | | | | | | 2nd Cycle | No-<br>Operation | No-<br>Operation | No-<br>Operation | No-<br>Operation | | | | | | OPTION Load Option Register Syntax: [ label ] OPTION Operands: None Operation: $(W) \rightarrow OPTION$ Status Affected: None Encoding: Description: Example The contents of the W register are loaded in the OPTION register. This instruction is supported for code compatibility with PIC16C5X products. Since OPTION is a readable/writable register, the user can directly address it. 0110 0010 0000 Words: 1 Cycles: 1 Example To maintain upward compatibility with future PIC16CXX products, do not use this instruction. After Interrupt PC = TOS GIE = 1 | SUBWF | Subtract | W from f | | | |-------------------|--------------------------------|-------------------------------|-------------------------------------------------------------------|----------------------| | Syntax: | [ label ] | SUBWF | f,d | | | Operands: | $0 \le f \le 12$ $d \in [0,1]$ | 7 | | | | Operation: | (f) - (W) - | → (destina | ıtion) | | | Status Affected: | C, DC, Z | | | | | Encoding: | 00 | 0010 | dfff | ffff | | Description: | ister from r<br>stored in th | egister 'f'. l<br>ne W regist | nent metho<br>If 'd' is 0 the<br>er. If 'd' is 1<br>n register 'f | result is<br>the | | Words: | 1 | | | | | Cycles: | 1 | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | Decode | Read<br>register 'f' | Process<br>data | Write to destination | | Example 1: | SUBWF | REG1,1 | | | | | Before Ins | struction | | | | | REG1<br>W<br>C<br>Z | =<br>=<br>= | 3<br>2<br>? | | | | After Instr | uction | | | | | REG1 | = | 1 | | | | W<br>C | = | 2<br>1; result is | positive | | | Z | = | 0 | p | | Example 2: | Before Ins | struction | | | | | REG1 | | 2 | | | | W<br>C | = | 2 | | | | Z | = | ? | | | | After Instr | ruction | | | | | REG1<br>W | = | 0 | | | | C | = | 1; result is | zero | | | Z | = | 1 | | | Example 3: | Before Ins | | | | | | REG1<br>W | = | 1 | | | | C | = | ? | | | | Z<br>After Instr | =<br>ruotion | ? | | | | REG1 | | 0xFF | | | | W | = | 2 | | | | C<br>Z | = | 0; result is<br>0 | negative | | | _ | | - | | | SWAPF | Swap Ni | bbles in 1 | f | | |-------------------|--------------------------------|-----------------------------------------------------|-----------------|----------------------| | Syntax: | [ label ] | SWAPF f | ,d | | | Operands: | $0 \le f \le 12$ $d \in [0,1]$ | 27 | | | | Operation: | . , | → (destin<br>→ (destin | | , . | | Status Affected: | None | | | | | Encoding: | 00 | 1110 | dfff | ffff | | Description: | 'f' are exch<br>placed in \ | and lower<br>nanged. If<br>Wregister.<br>nregister! | 'd' is 0 the | e result is | | Words: | 1 | | | | | Cycles: | 1 | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | Decode | Read<br>register 'f' | Process<br>data | Write to destination | | Example | SWAPF | REG, | 0 | | | | Before In | struction | | | | | | REG1 | = 0x/ | <b>4</b> 5 | | | After Inst | ruction | | | | | | REG1 | = 0x/ | | | | | W | = 0x5 | οA | | | | | | | | TRIS | Load TRIS Register | | | | | | | | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | Syntax: | [label] TRIS f | | | | | | | | | | | Operands: | $5 \leq f \leq 7$ | | | | | | | | | | | Operation: | $(W) \rightarrow TRIS$ register f;<br>None | | | | | | | | | | | Status Affected: | | | | | | | | | | | | Encoding: | 00 0000 0110 Offf | | | | | | | | | | | Description: | The instruction is supported for code compatibility with the PIC16C5X products. Since TRIS registers are readable and writable, the user can directly address them. | | | | | | | | | | | Words: | 1 | | | | | | | | | | | Cycles: | 1 | | | | | | | | | | | Example | | | | | | | | | | | | | To maintain upward compatibility with future PIC16CXX products, do not use this instruction. | | | | | | | | | | | | | | | | | | | | | | FIGURE 17-7: PARALLEL SLAVE PORT TIMING (PIC16C64) TABLE 17-7: PARALLEL SLAVE PORT REQUIREMENTS (PIC16C64) | Parameter<br>No. | Sym | Characteristic | | Min | Typ† | Max | Units | Conditions | |------------------|----------|--------------------------------|----------------------------------------------|-----|------|-----|-------|------------| | 62 | TdtV2wrH | Data in valid before WR↑ or CS | oata in valid before WR↑ or CS↑ (setup time) | | | | ns | | | 63* | TwrH2dtl | WR↑ or CS↑ to data–in invalid | PIC16 <b>C</b> 64 | 20 | _ | _ | ns | | | | | (hold time) | PIC16 <b>LC</b> 64 | 35 | _ | _ | ns | | | 64 | TrdL2dtV | RD↓ and CS↓ to data-out valid | RD↓ and CS↓ to data–out valid | | | 80 | ns | | | 65 | TrdH2dtl | RD↑ or CS↑ to data-out invalid | D↑ or CS↑ to data–out invalid | | | | ns | | These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. #### FIGURE 20-12: USART SYNCHRONOUS TRANSMISSION (MASTER/SLAVE) TIMING #### TABLE 20-11: USART SYNCHRONOUS TRANSMISSION REQUIREMENTS | Parameter No. | Sym | Characteristic | | Min | Typ† | Max | Units | Conditions | |---------------|----------|-----------------------------------|------------------------|-----|------|-----|-------|------------| | 120* | TckH2dtV | SYNC XMIT (MASTER & SLAVE) | PIC16 <b>C</b> 63/65A | | _ | 80 | ns | | | | | Clock high to data out valid | PIC16 <b>LC</b> 63/65A | _ | _ | 100 | ns | | | 121* | Tckrf | Clock out rise time and fall time | PIC16 <b>C</b> 63/65A | | _ | 45 | ns | | | | | (Master Mode) | PIC16 <b>LC</b> 63/65A | _ | _ | 50 | ns | | | 122* | Tdtrf | Data out rise time and fall time | PIC16 <b>C</b> 63/65A | | _ | 45 | ns | | | | | | PIC16 <b>LC</b> 63/65A | _ | _ | 50 | ns | | These parameters are characterized but not tested. #### FIGURE 20-13: USART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING #### TABLE 20-12: USART SYNCHRONOUS RECEIVE REQUIREMENTS | Parameter No. | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | |---------------|----------|------------------------------------------------------------------|-----|------|-----|-------|------------| | 125* | TdtV2ckL | SYNC RCV (MASTER & SLAVE) Data setup before CK ↓ (DT setup time) | 15 | _ | _ | ns | | | 126* | TckL2dtl | Data hold after CK ↓ (DT hold time) | 15 | _ | _ | ns | | <sup>\*</sup> These parameters are characterized but not tested. <sup>†:</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. <sup>†:</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. FIGURE 21-7: CAPTURE/COMPARE/PWM TIMINGS (CCP1 AND CCP2) TABLE 21-6: CAPTURE/COMPARE/PWM REQUIREMENTS (CCP1 AND CCP2) | Param<br>No. | Sym | Characteristic | | | Min | Typ† | Max | Units | Conditions | |--------------|------|-------------------------------------|----------------|-------------------------|----------------|------|-----|-------|------------------------------------| | 50* | TccL | CCP1 and CCP2 | No Prescaler | | 0.5Tcy + 20 | _ | _ | ns | | | | | input low time | With Prescaler | PIC16 <b>CR</b> 63/R65 | 10 | _ | _ | ns | | | | | | | PIC16 <b>LCR</b> 63/R65 | 20 | _ | _ | ns | | | 51* | TccH | CCP1 and CCP2 | No Prescaler | | 0.5TCY + 20 | _ | _ | ns | | | | | input high time | With Prescaler | PIC16 <b>CR</b> 63/R65 | 10 | _ | _ | ns | | | | | | | PIC16 <b>LCR</b> 63/R65 | 20 | _ | _ | ns | | | 52* | TccP | CCP1 and CCP2 input period | | | 3Tcy + 40<br>N | _ | _ | ns | N = prescale value<br>(1,4, or 16) | | 53* | TccR | | | PIC16 <b>CR</b> 63/R65 | _ | 10 | 25 | ns | | | | | | | PIC16 <b>LCR</b> 63/R65 | _ | 25 | 45 | ns | | | 54* | TccF | TccF CCP1 and CCP2 output fall time | | PIC16 <b>CR</b> 63/R65 | _ | 10 | 25 | ns | | | | | | | PIC16 <b>LCR</b> 63/R65 | _ | 25 | 45 | ns | | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. #### FIGURE 21-11: I<sup>2</sup>C BUS DATA TIMING TABLE 21-10: I<sup>2</sup>C BUS DATA REQUIREMENTS | Parameter No. | Sym | Characteristic | | Min | Max | Units | Conditions | |---------------|---------|------------------------|--------------|------------|------|-------|--------------------------------------------------| | 100* | THIGH | Clock high time | 100 kHz mode | 4.0 | _ | μS | Device must operate at a mini-<br>mum of 1.5 MHz | | | | | 400 kHz mode | 0.6 | _ | μS | Device must operate at a mini-<br>mum of 10 MHz | | | | | SSP Module | 1.5TcY | _ | | | | 101* | TLOW | Clock low time | 100 kHz mode | 4.7 | _ | μS | Device must operate at a mini-<br>mum of 1.5 MHz | | | | | 400 kHz mode | 1.3 | _ | μS | Device must operate at a mini-<br>mum of 10 MHz | | | | | SSP Module | 1.5Tcy | _ | | | | 102* | TR | SDA and SCL rise | 100 kHz mode | _ | 1000 | ns | | | | | time | 400 kHz mode | 20 + 0.1Cb | 300 | ns | Cb is specified to be from 10-400 pF | | 103* | TF | SDA and SCL fall time | 100 kHz mode | _ | 300 | ns | | | | | | 400 kHz mode | 20 + 0.1Cb | 300 | ns | Cb is specified to be from 10-400 pF | | 90* | Tsu:sta | START condition | 100 kHz mode | 4.7 | _ | μS | Only relevant for repeated | | | | setup time | 400 kHz mode | 0.6 | _ | μS | START condition | | 91* | THD:STA | START condition hold | 100 kHz mode | 4.0 | _ | μS | After this period the first clock | | | | time | 400 kHz mode | 0.6 | _ | μS | pulse is generated | | 106* | THD:DAT | Data input hold time | 100 kHz mode | 0 | _ | ns | | | | | | 400 kHz mode | 0 | 0.9 | μS | | | 107* | Tsu:dat | Data input setup time | 100 kHz mode | 250 | _ | ns | Note 2 | | | | | 400 kHz mode | 100 | _ | ns | 1 | | 92* | Tsu:sto | STOP condition setup | 100 kHz mode | 4.7 | _ | μS | | | | | time | 400 kHz mode | 0.6 | _ | μS | 1 | | 109* | TAA | Output valid from | 100 kHz mode | _ | 3500 | ns | Note 1 | | | | clock | 400 kHz mode | _ | _ | ns | | | 110* | TBUF | Bus free time | 100 kHz mode | 4.7 | _ | μS | Time the bus must be free | | | | | 400 kHz mode | 1.3 | _ | μS | before a new transmission can start | | | Cb | Bus capacitive loading | | _ | 400 | pF | | These parameters are characterized but not tested. Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions. <sup>2:</sup> A fast-mode (400 kHz) I<sup>2</sup>C-bus device can be used in a standard-mode (100 kHz) I<sup>2</sup>C-bus system, but the requirement Tsu:DAT ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line TR max.+tsu;DAT = 1000 + 250 = 1250 ns (according to the standard-mode I<sup>2</sup>C bus specification) before the SCL line is released. #### FIGURE 22-3: CLKOUT AND I/O TIMING #### TABLE 22-3: CLKOUT AND I/O TIMING REQUIREMENTS | Parameter No. | Sym | Characteristic | | Min | Тур† | Max | Units | Conditions | |---------------|--------------|-----------------------------------------------------------------------|-------------------------------|-----|------|-------------|--------|------------| | 10* | TosH2ckL | OSC1↑ to CLKOUT↓ | _ | 75 | 200 | ns | Note 1 | | | 11* | TosH2ckH | OSC1↑ to CLKOUT↑ | | _ | 75 | 200 | ns | Note 1 | | 12* | TckR | CLKOUT rise time | | _ | 35 | 100 | ns | Note 1 | | 13* | TckF | CLKOUT fall time | | _ | 35 | 100 | ns | Note 1 | | 14* | TckL2ioV | CLKOUT ↓ to Port out valid | | _ | _ | 0.5Tcy + 20 | ns | Note 1 | | 15* | TioV2ckH | Port in valid before CLKOUT ↑ | Port in valid before CLKOUT ↑ | | _ | _ | ns | Note 1 | | 16* | TckH2iol | Port in hold after CLKOUT ↑ | | 0 | _ | _ | ns | Note 1 | | 17* | TosH2ioV | OSC1↑ (Q1 cycle) to Port out valid | | _ | 50 | 150 | ns | | | 18* | TosH2iol OSC | OSC1 <sup>↑</sup> (Q2 cycle) to Port input invalid (I/O in hold time) | PIC16 <b>C</b> 66/67 | 100 | _ | _ | ns | | | | | | PIC16 <b>LC</b> 66/67 | 200 | _ | _ | ns | | | 19* | TioV2osH | Port input valid to OSC1↑ (I/O in setup time) | | 0 | _ | _ | ns | | | 20* | TioR | Port output rise time | PIC16 <b>C</b> 66/67 | _ | 10 | 40 | ns | | | | | | PIC16 <b>LC</b> 66/67 | _ | _ | 80 | ns | | | 21* | TioF | Port output fall time | PIC16 <b>C</b> 66/67 | _ | 10 | 40 | ns | | | | | | PIC16 <b>LC</b> 66/67 | _ | _ | 80 | ns | | | 22††* | Tinp | INT pin high or low time | | Tcy | _ | _ | ns | | | 23††* | Trbp | RB7:RB4 change INT high or low time | | Tcy | _ | _ | ns | | <sup>\*</sup> These parameters are characterized but not tested. Note 1: Measurements are taken in RC Mode where CLKOUT output is 4 x Tosc. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. <sup>††</sup> These parameters are asynchronous events not related to any internal clock edge. FIGURE 23-29: TYPICAL IDD vs. FREQUENCY (HS MODE, 25°C) ## FIGURE 23-30: MAXIMUM IDD vs. FREQUENCY (HS MODE, -40°C TO 85°C) ### 24.7 28-Lead Ceramic CERDIP Dual In-line with Window (300 mil)) (JW) Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Package Group: Ceramic CERDIP Dual In-Line (CDP) | | | | | | | | | |--------------------------------------------------|-------------|-------|-----------|--------|-------|-----------|--|--| | | Millimeters | | | Inches | | | | | | Symbol | Min | Max | Notes | Min | Max | Notes | | | | α | 0° | 10° | | 0° | 10° | | | | | Α | 3.30 | 5.84 | | .130 | 0.230 | | | | | A1 | 0.38 | _ | | 0.015 | _ | | | | | A2 | 2.92 | 4.95 | | 0.115 | 0.195 | | | | | В | 0.35 | 0.58 | | 0.014 | 0.023 | | | | | B1 | 1.14 | 1.78 | Typical | 0.045 | 0.070 | Typical | | | | С | 0.20 | 0.38 | Typical | 0.008 | 0.015 | Typical | | | | D | 34.54 | 37.72 | | 1.360 | 1.485 | | | | | D2 | 32.97 | 33.07 | Reference | 1.298 | 1.302 | Reference | | | | E | 7.62 | 8.25 | | 0.300 | 0.325 | | | | | E1 | 6.10 | 7.87 | | 0.240 | 0.310 | | | | | е | 2.54 | 2.54 | Typical | 0.100 | 0.100 | Typical | | | | eA | 7.62 | 7.62 | Reference | 0.300 | 0.300 | Reference | | | | eB | _ | 11.43 | | _ | 0.450 | | | | | L | 2.92 | 5.08 | | 0.115 | 0.200 | | | | | N | 28 | 28 | | 28 | 28 | | | | | D1 | 0.13 | _ | | 0.005 | _ | | | | #### 24.12 44-Lead Plastic Surface Mount (MQFP 10x10 mm Body 1.6/0.15 mm Lead Form) (PQ) Mote: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Package Group: Plastic MQFP | | | | | | | | | |-----------------------------|-------------|--------|-----------|--------|-------|-----------|--|--| | | Millimeters | | | Inches | | | | | | Symbol | Min | Max | Notes | Min | Max | Notes | | | | α | 0° | 7° | | 0° | 7° | | | | | Α | 2.000 | 2.350 | | 0.078 | 0.093 | | | | | A1 | 0.050 | 0.250 | | 0.002 | 0.010 | | | | | A2 | 1.950 | 2.100 | | 0.768 | 0.083 | | | | | b | 0.300 | 0.450 | Typical | 0.011 | 0.018 | Typical | | | | С | 0.150 | 0.180 | | 0.006 | 0.007 | | | | | D | 12.950 | 13.450 | | 0.510 | 0.530 | | | | | D1 | 9.900 | 10.100 | | 0.390 | 0.398 | | | | | D3 | 8.000 | 8.000 | Reference | 0.315 | 0.315 | Reference | | | | E | 12.950 | 13.450 | | 0.510 | 0.530 | | | | | E1 | 9.900 | 10.100 | | 0.390 | 0.398 | | | | | E3 | 8.000 | 8.000 | Reference | 0.315 | 0.315 | Reference | | | | е | 0.800 | 0.800 | | 0.031 | 0.032 | | | | | L | 0.730 | 1.030 | | 0.028 | 0.041 | | | | | N | 44 | 44 | | 44 | 44 | | | | | CP | 0.102 | - | | 0.004 | _ | | | | #### Package Marking Information (Cont'd) #### 28-Lead CERDIP Skinny Windowed #### 28-Lead Side Brazed Skinny Windowed ## 40-Lead PDIP | Legend: | MMM | Microchip part number information | |---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | XXX | Customer specific information* | | | AA | Year code (last 2 digits of calender year) | | | BB | Week code (week of January 1 is week '01') | | | С | Facility code of the plant at which wafer is manufactured. C = Chandler, Arizona, U.S.A. S = Tempe, Arizona, U.S.A. | | | $D_1$ | Mask revision number for microcontroller | | | E | Assembly code of the plant or country of origin in which part was assembled. | | Note: | line, it will b | t the full Microchip part number cannot be marked on one be carried over to the next line thus limiting the number of paracters for customer specific information. | <sup>\*</sup> Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask revision number, and assembly code. For OTP marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price. # PIC16C6X | TXSTA | SSP in I <sup>2</sup> C Mode - See I <sup>2</sup> C | |-------------------------------------------------------|-------------------------------------------------------| | Diagram105 | SSPADD25, 27, 29, 31, 33, 34, 9 | | Section105 | SSPBUF 24, 26, 28, 30, 32, 34, 9 | | Summary31, 33 | SSPCON | | W9 | SSPEN | | Special Function Registers, Initialization | SSPIE | | Conditions | SSPIF4 | | Special Function Registers, Reset Conditions131 | SSPM3:SSPM0 | | Special Function Register Summary 24, 26, 28, 30, 32 | · · · · · · · · · · · · · · · · · · · | | • | SSPOV | | File Maps21 | SSPSTAT | | Resets | SSPSTAT Register | | ROM7 | Stack4 | | RP0 bit | Start bit, S 84, 8 | | RP1 | STATUS24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 3 | | RX9106 | Status bits | | RX9D106 | Status Bits During Various Resets | | • | Stop bit, P | | S | Switching Prescalers | | S84, 89 | SYNC,USART Mode Select bit, SYNC | | SCI - See Universal Synchronous Asynchronous Receiver | Synchronizing Clocks, TMR0 | | Transmitter (USART) | Synchronous Serial Port (SSP) | | SCK86 | Block Diagram, SPI Mode8 | | SCL | CDI Manta (Olava Dia system | | SDI | SPI Master/Slave Diagram | | SDO | SPI Mode | | | Synchronous Serial Port Enable bit, SSPEN85, 9 | | Serial Port Enable bit, SPEN | Synchronous Serial Port Interrupt Enable bit, SSPIE 3 | | Serial Programming142 | Synchronous Serial Port Interrupt Flag bit, SSPIF 4 | | Serial Programming, Block Diagram142 | Synchronous Serial Port Mode Select bits, | | Serialized Quick-Turnaround-Production7 | SSPM3:SSPM0 85, 9 | | Single Receive Enable bit, SREN106 | Synchronous Serial Port Module 8 | | Slave Mode | Synchronous Serial Port Status Register 8 | | SCL100 | | | SDA100 | T | | SLEEP Mode123, 141 | T0CS3 | | SMP89 | TOIE | | Software Simulator (MPSIM)161 | TOIF | | SPBRG25, 27, 29, 31, 33, 34 | TOSE | | Special Features, Section | T1CKPS1:T1CKPS0 | | SPEN | | | | T1CON | | SPI | T10SCEN | | Block Diagram86, 91 | T1SYNC 7 | | Master Mode92 | T2CKPS1:T2CKPS07 | | Master Mode Timing93 | T2CON | | Mode86 | TIme-out | | Serial Clock91 | Time-out bit | | Serial Data In91 | Time-out Sequence13 | | Serial Data Out91 | Timer Modules | | Slave Mode Timing94 | Overview, all6 | | Slave Mode Timing Diagram93 | Timer0 | | Slave Select | Block Diagram6 | | SPI clock | Counter Mode | | SPI Mode91 | | | SSPCON 90 | External Clock6 | | | Interrupt 6 | | SSPSTAT89 | Overview 6 | | SPI Clock Edge Select bit, CKE89 | Prescaler 6 | | SPI Data Input Sample Phase Select bit, SMP89 | Section 6 | | SPI Mode86 | Timer Mode 6 | | SREN106 | Timing DiagramTilming Diagrams | | <del>SS</del> 86 | Timer0 6 | | SSP | TMR0 register6 | | Module Overview83 | Timer1 | | Section | Block Diagram | | SSPBUF 92 | | | SSPCON | Capacitor Selection | | SSPSR | Counter Mode, Asynchronous | | | Counter Mode, Synchronous | | SSPSTAT89 | External Clock | | | Oscillator 7 |