1-Wi with Microchip PICmicro microcontroller

Abstract: Some of Dallas Semiconductor's products include a 1-Wire® communication interface, which is suitable for different systems. These systems may need to interface with the well-known Microchip PICmicro® (PIC). To facilitate the interface between 1-Wire devices and PIC microcontrollers, this application note provides 1-Wire software routines, timing instructions and related materials for PIC microcontrollers. This application also provides a file containing all 1-Wire subroutines. The provided assembler is written for the PIC16F628 to read the data of the high-precision Li + battery monitor DS2761.

Introduction Microchip's PICmicro microcontroller (PIC) has become the mainstream choice for low-power, low-cost system solutions. These microprocessors have multiple general-purpose input and output pins (GPIO). By simply combining these pins, the 1-Wire protocol of Dallas Semiconductor can be realized. Various Dallas Semiconductor devices including iButton® work in coordination. This application note gives a 1-Wire communication subroutine based on PIC16F628, and introduces its timing and other related contents in detail. For convenience, all clock frequencies are assumed to be 4MHz. Everyone knows that this frequency is also the internal clock frequency of many PICs. Appendix A is a file included in all these subroutines, and Appendix B is a piece of assembly language code that PIC16F628 reads data from the high-precision lithium battery monitor DS2761. One thing to note here is that this application note is only suitable for normal speed 1-Wire communication. For the implementation of the 1-Wire protocol on the host side of the general macro command, GPIO only needs two states, namely the high-impedance state and the logic low level. The following small assembly procedure is used to achieve this function. PIC16F628 has two sets of GPIO ports: PORTA and PORTB, any of which can be used to complete 1-Wire communication. In this example, PORTB is selected, and a constant DQ is also configured in the assembly code, which is used to set which bit of PORTB is used as the 1-Wire pin. Throughout the code, this bit is simply referred to as DQ. Outside the circuit, this pin should be connected to the positive terminal of the power supply through a pull-up resistor. OW_HIZ: MACRO; Force the DQ line into a high impedance state. BSF STATUS, RP0; Select Bank 1 of data memory BSF TRISB, DQ; Make DQ pin High Z BCF STATUS, RP0; Select Bank 0 of data memory ENDM OW_LMACRO; Force the DQ line to a logic low. BCF STATUS, RP0; Select Bank 0 of data memory BCF PORTB, DQ; Clear the DQ bit BSF STATUS, RP0; Select Bank 1 of data memory BCF TRISB, DQ; Make DQ pin an output BCF STATUS, RP0; Select Bank 0 of data memory ENDM These two codes are written as macro instructions. Write them as macro instructions, and insert them automatically by calling a macro instruction in the assembly source code, thus reducing the number of code rewriting. The function of the first macro instruction OW_HIZ is to force DQ to high impedance state. Since the TRISB register is located in bank 1 of the data memory, the first step is to select bank 1 of the data memory. Then, by setting the DQ bit in the TRISB register, the DQ output driver becomes high impedance. The last line of the code changes back to bank 0 of the data memory. The last line is not necessary, but it is still added here so that the data memory is in a certain state after all macro instructions and function calls.

The function of the second macro instruction OW_LO is to force DQ to low level. First select bank 0 of the data memory so that the PORTB register is addressed. The PORTB register is a data memory. When set as an output, it contains the forced output values ​​of those configured as output pins in TRISB.

Clear the DQ bit of PORTB so that the lead is forced low. Finally, select bank 1 of the data register and clear the DQ bit of the PORTB register to use it as an output driver. As with the other, the macro instruction ends with the selection of bank 0 of the data memory.

The final macro instruction WAIT is used to generate the delay required for 1-Wire signaling. WAIT can generate delay times that are integer multiples of 5µs. In this macro, first simply calculate the required multiple of the 5µs delay, and then do the corresponding number of cycles in WAIT5U. The WAIT5U subroutine will be discussed in the next section. For each instruction in WAIT, the processing time used is annotated to facilitate the understanding of how the delay is realized. WAIT: MACRO TIME; Delay for TIME µs .; Variable TIme must be in mulTIples of 5µs. MOVLW (TIME / 5 )-1; 1 µs to process MOVWF TMP0; 1 µs to process CALL WAIT5U; 2 µs to process ENDM 1-Wire general subroutine In order to ensure successful communication, the 1-Wire timing protocol has some special timing restrictions that must be observed. To facilitate the generation of special delays, the subroutine WAIT5U can be used to generate a delay of 5µs. This subroutine is as follows: WAIT5U:; This takes 5µs to complete NOP; 1µs to process NOP; 1µs to process DECFSZ TMP0, F; 1µs if not zero or 2µs if zero GOTO WAIT5U; 2µs to process RETLW 0; 2µs to process The program can be used together with WAIT macros to generate commonly used delays. For example, if a delay of 40µs is required, WAIT 0.40 is called. Run the first 3 lines of WAIT first to generate a delay of 4µs, then run the first 4 lines of WAIT5U 6 times, each time to generate a delay of 5μs, the total delay is 30μs, the last round of WAIT5U needs 6μs, and then return to WAIT macro, so the total processing time is 30 + 4 + 6 = 40µs.

Table 1. 1-Wire interface timing requirements at standard speed
2.5V <VDD <5.5V, TA = -20 ° C to 70 ° C
Parameter Symbol Min Typ Max Units
Time Slot tSLOT 60 120 µs
Recovery Time tREC 1 µs
Write 0 Low Time tLOW0 60 120 µs
Write 1 Low Time tLOW1 1 15 µs
Read Data Valid tRDV 15 µs
Reset Time High tRSTH 480 µs
Reset Time Low tRSTL 480 960 µs
Presence Detect High tPDH 15 60 µs
Presence Detect Low tPDL 60 240 µs

All processes of 1-Wire communication start with a reset pulse sent by the master, followed by the slave's response detect pulse. Figure 1 illustrates this transaction. The initialization sequence can be issued through PIC, it is very simple, the corresponding assembly code is shown in Figure 1. The timing parameters of initialization, read operation, and write operation are listed in Table 1. These parameters will also be referenced later in this article.

Figure 1. 1-Wire initialization sequence
Figure 1. 1-Wire initialization sequence OW_RESET: OW_HIZ; Start with the line high CLRF PDBYTE; Clear the PD byte OW_LO WAIT .500; Drive Low for 500µs OW_HIZ WAIT .70; Release line and wait 70µs for PD Pulse BTFSS PORTB, DQ; Read for a PD Pulse INCF PDBYTE, F; Set PDBYTE to 1 if get a PD Pulse WAIT .430; Wait 430µs after PD Pulse RETLW 0 The OW_RESET subroutine starts from ensuring that the DQ pin is in a high-impedance state so that it can pass The pull-up resistor pulls DQ high. Then clear the PDBYTE register, so that it is ready for the subsequent presence detection pulse. After that, DQ goes low for 500µs, which meets the requirements of the tRSTL parameter in Table 1, while leaving 20µs extra buffer time. After turning this pin to low level, it returns to the high impedance state, and a delay of 70µs is added before reading the in-position detection pulse. This 70µs delay ensures that no matter how tPDL or tPDH changes, the PIC can always sample at the effective time. Once the presence detection pulse is read, the PDBYTE register is set to the logic state value that has been read. The DQ pin is kept in a high-impedance state for 430µs to ensure that tRSTH is met, and 20µs of extra buffer time is allowed.

Another subroutine required for 1-Wire communication is DSTXBYTE, which is used to send data to a 1-Wire slave device. The PIC code of this subroutine is shown in Figure 2. This subroutine needs to be called with the data to be sent in the WREG register. First put the data to be sent into the IOBYTE register immediately, and then initialize the COUNT register to 8 to count the bits to be sent on the DQ port line. Starting from DSTXLP, PIC sends data. Regardless of whether the transmitted level is high or low at the beginning, the DQ pin goes low for 3µs, which meets the requirements of tLOW1. Then the LSB of IOBYTE is shifted to the CARRY bit, and then it is checked whether it is 0 or 1. If CARRY is 1, the DQ bit of TRISB is set, the pin becomes high impedance, and the line is pulled high by the pull-up resistor. If CARRY is 0, the line remains low. After that, a delay of 60µs was introduced to allow normal operation when tLOW0 is at the minimum value. After a 60µs wait, the pin becomes high impedance, followed by an additional delay of 2µs for the pull-up resistor to recover. Finally, COUNT decreases by 1. If the value of the COUNT register becomes 0, it means that all data has been sent and the subroutine ends. If the value of the COUNT register is not 0, continue to send the next bit of data from DSTXLP. Refer to Figure 2 for how to write 0 or 1 in the program.

Figure 2. 1-Wire write operation timing
Figure 2. 1-Wire write timing DSTXBYTE:; Byte to send starts in W MOVWF IOBYTE; We send it from IOBYTE MOVLW .8 MOVWF COUNT; Set COUNT equal to 8 to count the bits DSTXLP: OW_LO NOP NOP NOP; Drive the line low for 3µs RRF IOBYTE, F BSF STATUS, RP0; Select Bank 1 of data memory BTFSC STATUS, C; Check the LSB of IOBYTE for 1 or 0 BSF TRISB, DQ; HiZ the line if LSB is 1 BCF STATUS, RP0; Select Bank 0 of data memory WAIT .60; Continue driving line for 60µs OW_HIZ; Release the line for pullup NOP NOP; Recovery time of 2µs DECFSZ COUNT, F; Decrement the bit counter GOTO DSTXLP RETLW 0 The last child of 1-Wire communication The program is DSRXBYTE, the main function is to receive information from the slave device, and its code is shown in Figure 3. Before the DQ takes action, first initialize the COUNT register to 8, indicating the number of bits to be received. At the beginning, DSRXLP first turns the DQ pin to a low level and sends a signal to the slave device, indicating that it is ready to receive data. This line is kept low for 6µs, and the port line is released by setting the DQ line to a high-impedance state, and then the PIC waits another 4µs before sampling the data line. When the line level goes low, there is 1 line of code in OW_LO and 3 lines of code in OW_HIZ. The processing time of one line of code is 1µs, and all the time is 1 + 6 + 3 + 4 = 14µs, which is just lower than the tRDV of 15µs. After PORTB is read, the DQ bit is masked. This register performs addition until 255, forcing the CARRY bit to mirror the DQ bit, and then CARRY shifts the bit to the IOBYTE that holds the received data. Once this byte is stored, a delay of 50 µs is required to ensure that the tSLOT requirement is met. The final check is to determine whether the COUNT register is zero. If it is zero, it means that 8 bits have been read and exit the subroutine; otherwise, go to DSRXLP and repeat the cycle. The process of reading 0 and reading 1 is shown in Figure 3.

Figure 3. 1-Wire read time slot
Figure 3. 1-Wire read slot DSRXBYTE:; Byte read is stored in IOBYTE MOVLW .8 MOVWF COUNT; Set COUNT equal to 8 to count the bits DSRXLP: OW_LO NOP NOP NOP NOP NOP NOP; Bring DQ low for 6µs OW_HIZ NOP NOP NOP NOP; Change to HiZ and Wait 4µs MOVF PORTB, W; Read DQ ANDLW 1 <
Appendix A: 1-Wire contains FILE (1W_16F6X.INC); ************************************ *******************;; Dallas 1-Wire Support for PIC16F628;; Processor has 4MHz clock and 1µs per instruction cycle.;; ******** ***********************************************; ** ************************************************** ***; Dallas Semiconductor 1-Wire MACROS; *************************************** **************** OW_HIZ: MACRO BSF STATUS, RP0; Select Bank 1 of data memory BSF TRISB, DQ; Make DQ pin High Z BCF STATUS, RP0; Select Bank 0 of data memory ENDM; ----------------------------------------------- --------- OW_LMACRO BCF STATUS, RP0; Select Bank 0 of data memory BCF PORTB, DQ; Clear the DQ bit BSF STATUS, RP0; Select Bank 1 of data memory BCF TRISB, DQ; Make DQ pin an output BCF STATUS, RP0; Select Bank 0 of data memory ENDM; ------------------------------------ -------------------- WAIT: MACRO TIME; Delay for TIME µs.; Variable time must be in multiples of 5µs. MOVLW (TIME / 5) -1 ; 1µs MOVWF TMP0; 1µs CALL WAIT5U; 2µs ENDM; ************************************** *****************; Dallas Semiconductor 1-Wire ROUTINES; ************************* ****************************** WAIT5U:; This takes 5µS to complete NOP; 1µs NOP; 1µs DECFSZ TMP0, F; 1µs or 2µs GOTO WAIT5U; 2µs RETLW 0; 2µs; --------------------------------------- ----------------- OW_RESET: OW_HIZ; Start with the line high CLRF PDBYTE; Clear the PD byte OW_LO WAIT .500; Drive Low for 500µs OW_HIZ WAIT .70; Release line and wait 70µs for PD Pulse BTFSS PORTB, DQ; Read for a PD Pulse INCF PDBYTE, F; Set PDBYTE to 1 if get a PD Pulse WAIT .400; Wait 400µs after PD Pulse RETLW 0; --------- ----------------------------------------------- DSRXBYTE:; Byte read is stored in IOBYTE MOVLW .8 MOVWF COUNT; Set COUNT equal to 8 to count the bits DSRXLP: OW_LO NOP NOP NOP NOP NOP NOP NOP; Bring DQ low for 6µs OW_HIZ NOP NOP NOP NOP; Change to HiZ and Wait 4µs MOVF PORTB , W; Read DQ ANDLW 1 < ; ------------------------------------------------- --------; Assign the PORTB with Constants constant DQ = 1; Use RB1 (pin7) for 1-Wire; --------------------- -----------------------------------; These constants are standard 1-Wire ROM commands constant SRCHROM = 0xF0 constant RDROM = 0x33 constant MTCHROM = 0x55 constant SKPROM = 0xCC; -------------------------------------- -------------------; These constants are used throughout the code cblock 0x20 IOBYTE TMP0; Address 0x23 COUNT; Keep track of bits PICMSB; Store the MSB PICLSB; Store the LSB PDBYTE; Presence Detect Pulse endc; ------------------------------------------- --------------; Setup your configuration word by using __config.; For the 16F628, the bits are:; CP1, CP0, CP1, CP0, N / A, CPD, LVP, BODEN , MCLRE, FOSC2, PWRTE, WDTE, FOSC1, FOSC0; CP1 and CP0 are the Code Protection bits; CPD: is the Data Code Protection Bit; LVP is the Low Voltage Programming Enable bit; PWRTE is the power-up Timer enable bit; WDTE is the Watchdog t imer enable bit; FOSC2, FOSC1 and FOSC0 are the oscillator selection bits.; CP disabled, LVP disabled, BOD disabled, MCLR enabled, PWRT disabled, WDT disabled, INTRC I / O oscillator; 11111100111000 __config 0x3F38; ------ -------------------------------------------------- -; Set the program origin for subsequent code. Org 0x00 GOTO SETUP NOP NOP NOP GOTO INTERRUPT; PC 0x04 ... INTERRUPT VECTOR!; --------------------- ------------------------------------ INTERRUPT: SLEEP; ---------- -----------------------------------------------; Option Register bits; ____; RBPU, INTEDG, TOCS, TOSE, PSA, PS2, PS1, PS0; 7 = PORTB Pullup Enable, 6 = Interrupt Edge Select, 5 = TMR0 Source,; 4 = TMR0 Source Edge, 3 = Prescaler Assign, 2 -0 = Prescaler Rate Select; 11010111; PORTB pullups disabled, rising edge, internal, hightolow, TMR0,1: 256 SETUP: BCF STATUS, RP1 BSF STATUS, RP0; Select Bank 1 of data memory MOVLW 0xD7 MOVWF OPTION_REG BCF STATUS, RP0 ; Select Bank 0 of data memory; ------------------------------------------ - -------------- BCF INTCON, 7; Disable all interrupts.; -------------------------- ------------------------------- GOTO START; ---------------- -----------------------------------------; Include the 1-Wire communication routines and macros #INCLUDE 1w_16f6x.inc; ------------------------------------------- -------------- START:; --------------------------------- ------------------------ GET_TEMP: CALL OW_RESET; Send Reset Pulse and read for Presence Detect Pulse BTFSS PDBYTE, 0; 1 = Presence Detect Detected GOTO NOPDPULSE MOVLW SKPROM CALL DSTXBYTE; Send Skip ROM Command (0xCC) MOVLW 0x69 CALL DSTXBYTE; Send Read Data Command (0x69) MOVLW 0x0E CALL DSTXBYTE; Send the DS2761 Current Register MSB address (0x0E) CALL DSRXBYTE; Read the DS2761 Current Register MSB MOVFIO , W MOVWF PICMSB; Put the Current MSB into file PICMSB CALL DSRXBYTE; Read the DS2761 Current Register LSB MOVF IOBYTE, W MOVWF PICLSB; Put the Current LSB into file PICLSB CALL OW_RESET NOPDPULSE:; Add some error pr ocessing here! SLEEP; Put PIC to sleep; ---------------------------------------- ----------------- end

ZGAR Vape Pods 1.0

ZGAR Vape Pods 1.0


ZGAR electronic cigarette uses high-tech R&D, food grade disposable pods and high-quality raw material. A new design of gradient our disposable vape is impressive.We equip with breathing lights in the vape pen and pods.


Our team has very high requirements for product quality, taste allocation and packaging design. Designers only use Hong Kong designers, e-cigarette liquid only imports from the United States, materials are food grade, and assembly factory wants medical grade without ground workshop.


We offer best price, high quality Pod System Vape,Pods Systems Touch Screen,Empty Pod System, Pod Vape System,Disposable Pod device,Vape Pods to all over the world.



ZGAR Vape 1.0 Pods,ZGAR Vape Pods 1.0 ,Pod Systems,Atomizer, E-cigarette, Empty Pod Vape Manufacturer and Supplier in China

Zgar International (M) SDN BHD , https://www.zgarpods.com

Posted on