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

16F1936 misunderstandings with pins on port C

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



Joined: 21 Sep 2010
Posts: 159

View user's profile Send private message

16F1936 misunderstandings with pins on port C
PostPosted: Sun Jul 01, 2012 7:44 am     Reply with quote

Hello
I have PIC16F1963 with compiler version PCWHD 4.130, MPLAB V8.66 and programmer PICkit3.
Problem is next: when I want to to make all pins "output high" I have some pins in logical 1 and some pins logical 0.
C0 is 1
C1 is 0
C2 is 1
C3 is 1
C4 is 1
C5 is 1
C6 is 0
C7 is 1

Hardware powered with 4.47V (err+/-1%)
and on every output I have 1K load to GND.

My code example is:
Code:

   output_high(PIN_C0);
   output_high(PIN_C1);
   output_high(PIN_C2);
   output_high(PIN_C3);
   output_high(PIN_C4);
   output_high(PIN_C5);
   output_high(PIN_C6);
   output_high(PIN_C7);

I try with:
Code:
output_c(0b11111111);

but results are the same.

I changed PIC with another, but results are the same.

Regards
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 8:40 am     Reply with quote

You're only showing us part of your code.

All the pins have other functions besides general purpose I/O. Check with the data sheet that these are turned off.

Also check that status of TRISC and LATC, and that you have not got S/C to GND on pins C1 and C6.

Mike
nailuy



Joined: 21 Sep 2010
Posts: 159

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 9:49 am     Reply with quote

Now I post my code
Code:
#include <16F1936.h>
#device *=16
#device adc=8

#FUSES WDT                      //Watch Dog Timer
#FUSES INTRC_IO                 //Internal RC Osc, no CLKOUT
#FUSES WDT_NOSL                 //Watch Dog Timer, disabled during SLEEP
#FUSES PUT                      //Power Up Timer
#FUSES NOMCLR                   //Master Clear pin used for I/O
#FUSES PROTECT                  //Code protected from reads
#FUSES CPD                      //Data EEPROM Code Protected
#FUSES WRT                      //Program Memory Write Protected
#FUSES PLL_SW                   //4X HW PLL disabled, 4X PLL enabled/disabled in software
#FUSES BORV27                   //Brownout reset at 2.7V
#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O

#use delay(int=8M)

#use rs232(baud=9600,parity=N,xmit=PIN_B7,rcv=PIN_B6,bits=8,stream=PORT1,stop=1,ERRORS)
#use fast_io(C)
#define IC3_SD       PIN_C1
#define IC3_IN       PIN_C0
#define IC4_SD       PIN_C7
#define IC4_IN       PIN_C6
#define IC5_SD       PIN_C3
#define IC5_IN       PIN_C2
#define NEON         PIN_C4
#define MOTOR        PIN_C5

#RESERVE  0x020:0x076      //stack0.1 cu 87 byti
#RESERVE  0x07B:0x07F      //stack0.2 cu 5 byti
// 0x077-0x07A 4 byti rezervati de compilator
#RESERVE  0x0A0:0x0EF      //stack1 cu 80 byti
#RESERVE  0x120:0x16F      //stack2 cu 80 byti
#RESERVE  0x1A0:0x1EF      //stack3 cu 80 byti
#RESERVE  0x220:0x26F      //stack4 cu 80 byti
#RESERVE  0x2A0:0x2EF      //stack5 cu 80 byti
//#RESERVE  0x320:0x320      //stack6 cu 16 byti
//restu stack 7-31 cu 0 byti

int8 V_PR1=0,V_PR2=0;      //vitezele de rulare progrm
#BYTE V_PR1 = 0x07B        //
#BYTE V_PR2 = 0x07C
int8 T0=0;                 //valoare timer 0
int8 TIMER1_LED=0;         //timer led la spam
int8 BLOC1_TIMER1=0;       //blocheaza timerul 1

int1 BUTON=0;


void main()
{
   setup_adc_ports(sAN13);
   setup_adc(ADC_CLOCK_DIV_32);
   
   setup_lcd(LCD_DISABLED);
   
   setup_wdt(WDT_ON);
   setup_wdt(WDT_2S);      //

   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_128|RTCC_8_bit);      //13.1 ms overflow
   setup_timer_1(T1_INTERNAL|T1_DIV_BY_1);      //65.5 ms overflow
   setup_timer_2(T2_DIV_BY_16,255,1);      //4.0 ms overflow, 4.0 ms interrupt
   setup_timer_4(T4_DISABLED,0,1);
   setup_timer_6(T6_DISABLED,0,1);

   setup_ccp2(CCP_PWM|CCP_SHUTDOWN_AC_H|CCP_SHUTDOWN_BD_H);
   setup_ccp3(CCP_PWM|CCP_SHUTDOWN_AC_H|CCP_SHUTDOWN_BD_H);
   setup_ccp5(CCP_PWM);
   set_pwm2_duty((int16)0);
   set_pwm3_duty((int16)0);
   set_pwm5_duty((int16)0);
   setup_comparator(NC_NC_NC_NC);// This device COMP currently not supported by the PICWizard
   setup_oscillator(OSC_8MHZ|OSC_TIMER1|OSC_PLL_OFF,0);
   
   port_E_pullups(0xFF);
   SET_TRIS_C(0x00);        //tot canalul C este iesire
//   output_c(0b11111111); //
   output_high(PIN_C0);
   output_high(PIN_C1);
   output_high(PIN_C2);
   output_high(PIN_C3);
   output_high(PIN_C4);
   output_high(PIN_C5);
   output_high(PIN_C6);
   output_high(PIN_C7);

delay_ms(100);
for(;;)
{
restart_wdt();
//SLEEP();
//   output_high(PIN_C0);
//   output_high(PIN_C1);
//   output_high(PIN_C2);
//   output_high(PIN_C3);
//   output_high(PIN_C4);
//   output_high(PIN_C5);
//   output_high(PIN_C6);
//   output_high(PIN_C7);

}

Regards
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 11:20 am     Reply with quote

I don't have a PIC16F1936 to try.

However you are making several fundamental errors.

(1) You should not need to use fast_io. Most of the time the CCS compilers take care of this for you.
(2) Without fast_io you then don't need to write to TRISC.

You are setting up RS232. RC6 is the USART TX. Could be a source of conflict.
You are also setting up CCP2 which uses RC1 as CCP2/P2A. Could be another problem.

Have you checked the status of the TRISC and LATC registers?

You've got a problem with PORTC. So get rid of all the other stuff and concentrate on the problem in hand. Work on the KISS principle.

Mike

PS Page 143 of the data sheet gives a summary of all the registers associated with PORTC. It's fairly formidable.
nailuy



Joined: 21 Sep 2010
Posts: 159

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 12:21 pm     Reply with quote

Dear Mike
I have another problem like logical problems.
I will try with PCW 4.084 and simulate.
On paper and when I read code work's fine... In my mind.
#1 I use fast_io because I need speed in normal mode. I have speed 47Hz and in fast mode I have speed 98Hz.
I try without fast mode and results are the same...
#2 RC6 USART TX is not active /declared so it must not be a conflict
CCP2 is compare/capture so is for input signal or PWM output, in my case is use for output mode so again is no conflict. Of course I try in normal mode but not works.
This pin's works fine as input or output, high or low.
I'm starting to think this could be a bug.
temtronic



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

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 1:58 pm     Reply with quote

If you say you're still having a problem setting/resetting pins on port C, go back to basics.
Get rid of all the timers,pwm,rs232,LCd,etc.
Use standard I/O NOT fast I/O so the compiler handles the ddrs.
Write a simple program to toggle portc.0 that has an LED and 1Kr on it,at say 1/2second rate. Confirm that works. Then copy the program, edit to use portC.1.compile,test,confirm.Do this for all 8 pins on the port.

Once you've confirmed all pins toggle then you know there's nothing wrong with the basic code.Build upon that until you fail, then go back one step and compare the programs to see what is different.That will show you the problem area.

hth jay
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 2:20 pm     Reply with quote

Quote:
Of course I try in normal mode but not works.
This does not help, it's too vague, you're making us guess. You need to tell us what is/isn't happening.

Temtronic and I are saying the same thing, (albeit in different ways).

Get PORTC to work correctly first, then progress.

Quote:
I'm starting to think this could be a bug.
Yes, it's possible. At this stage you can't prove it. You must simplify.

Mike
nailuy



Joined: 21 Sep 2010
Posts: 159

View user's profile Send private message

PostPosted: Sun Jul 01, 2012 3:31 pm     Reply with quote

At this moment I have 2 problems:
first
with port C and I will try like I said with older version...
second
logical programming.
Before to post here I check in normal mode with simplest way.
I need 3-4 day's and after that I will post solution/decision that I find.
At this moment in my opinion is bug and solution is with change device.
Best wishes....
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PostPosted: Mon Jul 02, 2012 3:42 am     Reply with quote

RC1 is the output of CCP2 in PWM mode, and RC6 is the output of CPP3 in PWM mode. You are using both in PWM mode, these will override the use of the bits as general IO.

Try not setting the CCPs as PWMs and tell us what happens to your outputs.

Also be aware that just because an output is at the logic level you expect, that doesn't guarantee its doing what you expect... Put another way, if the PWMs are overriding RC1 and RC6, then if they happened to have been high rather than low, you would not necessarily have noticed anything was wrong.

RF Developer
nailuy



Joined: 21 Sep 2010
Posts: 159

View user's profile Send private message

PostPosted: Mon Jul 02, 2012 9:07 am     Reply with quote

Yes Developer
This was the problem.
I disabled all CCP and now works well.
(I test the wizards and was my fault of configuration , by clicking on it).
Thank you.
PS: You saved my 2 days of work + other 3 days to develop new hardware.
Regards
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