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

PIC18F14K22 RA0-RA3 not working

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



Joined: 16 Jul 2014
Posts: 7

View user's profile Send private message

PIC18F14K22 RA0-RA3 not working
PostPosted: Wed Jul 23, 2014 11:24 am     Reply with quote

I have all inputs of port A as digital inputs from switches. RA0 is a Ramp Up switch, RA1 is Ramp Down. RA2 and 3 are jumpers for calibration, RA4 and RA5 are from a rotary switch which selects a milliamp output range.

RA4 and RA5 are working. However, I can't get RA0- RA3 to do anything. I have two lines to try and disable the analog functionality of these pins (setup_adc(ADC_OFF); and setup_adc_ports(NO_ANALOGS); I have a fuse #fuses NOMCLR to get rid of the Master Clear pin so I can use it for I/O. I defined the pins, but nothing works. I am using Timer0 for a loop counter interrupt counter 100 counts per second for a one-second loop. I've checked the lines with a voltmeter going into RA0 and RA1 from my pushbutton switches and they are being held low through a pull-down resistor (10K) and when pressed, the lines go to 3.3v. Everything is running on 3.3v. I'm confused. I'm sure I'm missing something simple, but I don't see it. I have not set up the TRISA port because it looks to be configured correctly on power up going by the documentation. All other pins on all other ports are working. These are the only four I'm having trouble with. Any ideas?

here is what I have at the start of MAIN()...
Code:

   setup_adc_ports(NO_ANALOGS);
   setup_adc(ADC_OFF);
   
   setup_timer_0(T0_DIV_2|T0_DIV_4);//timer overflow in 131ms
   setup_wdt(WDT_ON);
   setup_timer_1(T1_DISABLED);
   setup_timer_2(T2_DISABLED,0,1);
   setup_timer_3(T3_DISABLED);
   setup_comparator(NC_NC_NC_NC);
   enable_interrupts(INT_TIMER0);
   enable_interrupts(GLOBAL);
   setup_oscillator(OSC_8MHZ|OSC_INTRC|OSC_PLL_OFF);
temtronic



Joined: 01 Jul 2010
Posts: 9274
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Jul 23, 2014 1:09 pm     Reply with quote

stuff I'd do....

1) get rid of the WDT, NOT needed until product is going out the door(if ever)...

2) cut/test the '1 Hz LED ' program,confirming it'll run at 3V and board/PIC is good

3) get rid of timers until simple I/O works(if pin high, turn on LED test)

4) disable ALL interrupts,again until simple I/O test works.

5) normally I tie inputs high, use switches to ground inputs

gotta start with the basics, confirming at every step.

hth
jay
davidb_csi



Joined: 16 Jul 2014
Posts: 7

View user's profile Send private message

PostPosted: Wed Jul 23, 2014 1:29 pm     Reply with quote

Jay,
Thanks for the reply.

1. I know the PIC is good. I have several of them. Use them on another product. The program is running. I have an LCD display and a 16-bit A/D converter working along with 9 other digital inputs from a rotary switch that are all working (Rc0 - Rc6, Ra4 and Ra5). They are connected the same way, with resistors tied to ground and switching to 3.3v. That is basically my entire circuit except for the two pushbuttons and two jumpers that are not functioning on Ra0-Ra3.

2. On my other product that uses this same PIC, I use RA0-RA2 for three analog inputs. That product has been working for a long time. I am also thinking of trying its setup to see if those inputs will work as analog inputs. I could use them that way if I have to.

3. I will also check my PCB artwork one more time. This should not be this hard for a simple project.

4. I don't have an LED on the board that I can use for a test. I will have to rig one up.

5. Right now, the program that is running simply examines the switches on the rotary switch and if it has changed positions it changes to the correct display and current output. I was going to use the Up/Dwn pushbuttons to ramp Up/Dwn from those set positions. I might also disable the rotary switch subroutine and only use the two pushbuttons to set a couple of outputs if pressed just in case my other routine is somehow overriding the pushbuttons.
davidb_csi



Joined: 16 Jul 2014
Posts: 7

View user's profile Send private message

PostPosted: Wed Jul 23, 2014 1:31 pm     Reply with quote

Sorry, my compiler version is PCWHD 5.026.
Markdem



Joined: 24 Jun 2005
Posts: 206

View user's profile Send private message Send e-mail

PostPosted: Wed Jul 23, 2014 5:24 pm     Reply with quote

PIN_A3 is also MCLR. To use it as IO you will need to have the NOMCLR fuse set. As you have not posted your fuses, I am not sure if this is the issue.

Other thing I would do is get rid of setup_comparator(NC_NC_NC_NC);. I know it make no sense as you are basically turning it off but I have had a simular problem in the past.

Have Fun
temtronic



Joined: 01 Jul 2010
Posts: 9274
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Jul 23, 2014 6:03 pm     Reply with quote

I just downloaded the datasheet and those pins have pullups on them. Any chance that they are enabled( maybe a default setting)? If so with your 'pull down' resistors it could result in 'odd' things happening.
I've always used pullups for switches with small C on the contacts for a bit of debounce.

hth
jay
davidb_csi



Joined: 16 Jul 2014
Posts: 7

View user's profile Send private message

problem solved
PostPosted: Thu Jul 24, 2014 2:45 pm     Reply with quote

Well, I knew it would be simple when I found it. I had already disabled the comparator like Markdem suggested. I had used this PIC in the past and so I started with that original configuration. However on that original configuration I had used the first three RA0 - RA2 as analog inputs so I had to delete all the configurations for that setup. I backed up and simplified my code even though I didn't think my interrupt or Timer0 setup was affecting anything. I got it working without any interrupts or timers and by only writing a small test code for those switches that I was having trouble with. I kept the LCD display routine in so I could display values when I pressed buttons. It worked! However, I still was not sure exactly what was causing my problem so I started adding in routines I had commented out. I added the Timer0 and Interrupt back in and they still worked. Then I added in one other subroutine that I suspected was causing the problem. It also adjusts the same variable that my pushbuttons are. With it back in place, the buttons quit working (apparently). I hate to admit my error but I will just to finish this post properly and I have to thank everyone for their suggestions. Backing up and going a step at a time got me to find my mistake. My other subroutine controls a rotary switch that selects a value depending on its position. My intention was to only update the value ( output to my D/A chip) from that rotary switch when it changes position or on power-up. I found that it was updating on changing position, but I had a flag that I set on power-up to update the value from the rotary switch and after it gets cleared it only looks at the switch when it changes position. I forgot to clear the %#! flag so that it was continually writing over my changes that the pushbuttons were trying to make. It took me a while to find it since I do not have a port on my board to connect anything for online debugging. It was a good exercise in troubleshooting code though!
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