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

26K22 pullup on E3 -> Compiler error 5.016

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



Joined: 09 Mar 2010
Posts: 314
Location: Denmark

View user's profile Send private message

26K22 pullup on E3 -> Compiler error 5.016
PostPosted: Thu Dec 12, 2013 7:00 am     Reply with quote

Hi

Compiler 5.016

Is this looking right?
I dont understand the asm. code, register F86.6? is not existing in the chip 26K22? And the RBPU = 0 is High therefore no pullup at all.

Is there error in the compile??

//Only for test, therefore no sw or other thing!
Code:
#include <18F26K22.h>

void main(void) {
 port_b_pullups(0x00);//no pull up on port b
 port_e_pullups(0x08);//pullup on port e pin_e3!!! It can only be input! If no pullup it will float:-((((
}


List code:
Code:
0001E:  CLRF   WPUB
00020:  BSF    INTCON2.RBPU
....................  port_e_pullups(0x08);//pullup on port e pin_e3!!! It can only be input! If no pullup it will float:-(((( 
00022:  BCF    F86.6



This is from the Datasheet:
Code:
10.6.3 RE3 WEAK PULL-UP
The port RE3 pin has an individually controlled weak
internal pull-up. When set, the WPUE3 (TRISE<7>) bit
enables the RE3 pin pull-up. The RBPU bit of the
INTCON2 register controls pull-ups on both PORTB
and PORTE. When RBPU = 0, the weak pull-ups
become active on all pins which have the WPUE3 or
WPUBx bits set. When set, the RBPU bit disables all
weak pull-ups. The pull-ups are disabled on a Poweron
Reset. When the RE3 port pin is configured as
MCLR, (CONFIG3H<7>, MCLRE=1 and
CONFIG4L<2>, LVP=0), or configured for Low Voltage
Programming, (MCLRE=x and LVP=1), the pull-up is
always enabled and the WPUE3 bit has no effect


Last edited by hmmpic on Thu Dec 12, 2013 9:45 am; edited 1 time in total
Ttelmah



Joined: 11 Mar 2010
Posts: 19518

View user's profile Send private message

PostPosted: Thu Dec 12, 2013 9:14 am     Reply with quote

Yes. Report it to CCS, and just bodge round temporarily with:
Code:

#include <18F26K22.h>
#BIT RBPU=getenv("BIT:RBPU")

void main(void) {
 port_b_pullups(0x00);//no pull up on port b
 port_e_pullups(0x08);//pullup on port e pin_e3!!! It can only be input! If no pullup it will float:-((((
 RBPU=0;
}   


On most chips, RBPU, only controls the port B pullups (hence the 'B' in it's name). So the compiler when it sees all the pull up bits on port B set to '0', turns this bit off. On this chip it also controls the port E pullups, so needs to be on if any bit is set here, but the compiler hasn't got this sorted.

Hurrah!. A really nice sized test program. Smile

Best Wishes
hmmpic



Joined: 09 Mar 2010
Posts: 314
Location: Denmark

View user's profile Send private message

PostPosted: Thu Dec 12, 2013 9:47 am     Reply with quote

Hi

Just sent a support mail to CCS.

Thanks for testing, too:-)
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