CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

PIC16LF1579 Pull-Up Anomaly

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
MotoDan



Joined: 30 Dec 2011
Posts: 55

View user's profile Send private message

PIC16LF1579 Pull-Up Anomaly
PostPosted: Thu Mar 05, 2020 4:31 pm     Reply with quote

I just discovered a possible issue with the programmable weak pull-ups. I've only tested this on the PIC16LF1579, but I suspect it might also pertain to other similar parts.

The problem was found when I noticed one of my inputs was going high with no external signal was applied. The pin was RB5.

I isolated the code until I determined the cause which turned out to be the application of the internal pull-ups on Port C.

The RB5 pull-up is applied as soon as the port_c_pullups(0xff) statement is executed. Turning off Port C pull-ups does not remove the pull-up on RB5.

The only way I can remove the RB5 pull-up is to execute a port_b_pullups(0x00) statement either before or after the port_c_pullups() statement.

I first noticed this while using PCM 5.080 which has since been updated to the latest 5.093. The same problem exists with either version compiler.

Here's the test program used to demonstrate the issue:

Code:

#include <16LF1579.h>
#use delay(clock=4000000)
main()
{
   while(1)
   {
   delay_ms(1000);
   port_c_pullups(0xFF);      //adds a pull-up on RB5
   delay_ms(1000);
   port_c_pullups(0x00);      //does not remove RB5 pull-up
   delay_ms(1000);
   port_b_pullups(0x00);      //removes RB5 pull-up
                               //RB5 pull-up does not occur once the above is executed   
   }
}


And the associated listing output:

Code:

CCS PCM C Compiler, Version 5.093, 50212               05-Mar-20 15:50

               ROM used:   70 words (1%)
                           Largest free fragment is 2048
               RAM used:   6 (1%) at main() level
                           18 (2%) worst case
               Stack used: 0 locations
               Stack size: 16

0000:  MOVLP  00
0001:  GOTO   019
0002:  NOP
.................... #include <16LF1579.h>
.................... //////////// Standard Header file for the PIC16LF1579 device ////////////////
.................... ///////////////////////////////////////////////////////////////////////////
.................... ////        (C) Copyright 1996, 2014 Custom Computer Services          ////
.................... //// This source code may only be used by licensed users of the CCS C  ////
.................... //// compiler.  This source code may only be distributed to other      ////
.................... //// licensed users of the CCS C compiler.  No other use, reproduction ////
.................... //// or distribution is permitted without written permission.          ////
.................... //// Derivative programs created using this software in object code    ////
.................... //// form are not restricted in any way.                               ////
.................... ///////////////////////////////////////////////////////////////////////////
.................... #device PIC16LF1579
....................
.................... #list
....................
.................... #use delay(clock=4000000)
0003:  MOVLW  20
0004:  MOVWF  05
0005:  MOVLW  02
0006:  MOVWF  04
0007:  MOVF   00,W
0008:  BTFSC  03.2
0009:  GOTO   018
000A:  MOVLW  01
000B:  MOVWF  78
000C:  CLRF   77
000D:  DECFSZ 77,F
000E:  GOTO   00D
000F:  DECFSZ 78,F
0010:  GOTO   00C
0011:  MOVLW  4A
0012:  MOVWF  77
0013:  DECFSZ 77,F
0014:  GOTO   013
0015:  GOTO   016
0016:  DECFSZ 00,F
0017:  GOTO   00A
0018:  RETURN
.................... main()
0019:  MOVLB  03
001A:  CLRF   0C
001B:  CLRF   0D
001C:  CLRF   0E
001D:  MOVLB  02
001E:  CLRF   12
001F:  CLRF   11
0020:  CLRF   14
0021:  CLRF   13
.................... {
....................    while(1)
....................    {
....................    delay_ms(1000);
0022:  MOVLW  04
0023:  MOVLB  00
0024:  MOVWF  21
0025:  MOVLW  FA
0026:  MOVWF  22
0027:  CALL   003
0028:  DECFSZ 21,F
0029:  GOTO   025
....................    port_c_pullups(0xFF);      //adds a pull-up on RB5
002A:  MOVLW  FF
002B:  MOVLB  04
002C:  MOVWF  0E
002D:  MOVLB  01
002E:  BCF    15.7
....................    delay_ms(1000);
002F:  MOVLW  04
0030:  MOVLB  00
0031:  MOVWF  21
0032:  MOVLW  FA
0033:  MOVWF  22
0034:  CALL   003
0035:  DECFSZ 21,F
0036:  GOTO   032
....................    port_c_pullups(0x00);      //does not remove RB5 pull-up
0037:  MOVLB  04
0038:  CLRF   0E
....................    delay_ms(1000);
0039:  MOVLW  04
003A:  MOVLB  00
003B:  MOVWF  21
003C:  MOVLW  FA
003D:  MOVWF  22
003E:  CALL   003
003F:  DECFSZ 21,F
0040:  GOTO   03C
....................    port_b_pullups(0x00);      //removes RB5 pull-up
0041:  MOVLB  04
0042:  CLRF   0D
0043:  MOVLB  02
0044:  GOTO   022
....................                      //RB5 pull-up does not occur once the above is executed   
....................    }
.................... }


The pull-up on RB5 only occurs once - despite the looping.

My current work-around is to simply place a port_b_pullups(0x00) statement in my initialization routine.

I have not tested the other Port B pins yet since my circuit only uses RB5 as an input.

Is this a possible bug or am I missing something?
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Fri Mar 06, 2020 1:36 am     Reply with quote

This is just about making an incorrect assumption.

There is a single master weak pull up 'enable' bit. Once this is turned on
all pullups that are enabled in the individual registers are turned 'on'.

Now the individual enables all wake up set 'on' (read the data sheet).
So as soon as you enable any pull up, all the other pull ups will be turned
on 'by default'. You have to set all three registers (for Port A, B & C), to
values that you actually want.
MotoDan



Joined: 30 Dec 2011
Posts: 55

View user's profile Send private message

PostPosted: Fri Mar 06, 2020 10:48 am     Reply with quote

Thanks Ttelmah. I see where ALL of the individual port pin pull-up bits are set to '1' by default so ANY change to the pull-ups will result in all others being turned on.

Cheers
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Fri Mar 06, 2020 11:39 am     Reply with quote

Exactly.
Having just the single 'master enable', leads to the effect you were seeing.
Definitely worth remembering to setup all the ports.....
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group