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

rs232 LED BLINK pıc-to-pıc communication
Goto page 1, 2, 3, 4, 5, 6  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

rs232 LED BLINK pıc-to-pıc communication
PostPosted: Fri Mar 10, 2023 10:49 am     Reply with quote

2xpıc16f877a

tx
Code:
#include <16F877A.h>
#fuses  PUT, HS, NOWDT, NOLVP, NOBROWNOUT
#use delay(clock=20000000)

#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, bits=8, parity=N, errors)

void main()
{   
   set_tris_d(0x00);
   output_d(0x00);
   output_high(pin_D1);
   delay_ms(1000);
   output_low(pin_D1);
   delay_ms(1000);
   output_high(pin_D1);

   while(true)
   {
      putc('g');
      delay_ms(1000);
      putc('y');
      delay_ms(1000);
      putc('r');
      delay_ms(1000);
   }
}



rx
Code:
#include <16f877a.h>
#fuses  PUT, HS, NOWDT, NOLVP, NOBROWNOUT
#use delay(clock=20000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, bits=8, parity=N, errors)


void main()

    setup_adc(adc_off);
   set_tris_d(0x00);
   output_d(0x00);
   output_high(pin_D1);
   delay_ms(1000);
   output_low(pin_D1);
   delay_ms(1000);
   output_high(pin_D1);
   

   char data;

while(true)
   {
   while(true)
          {
             data = getc();
             switch(data){
             case 'g':output_high(PIN_A1);
                      output_low(PIN_A2);
                      output_low(PIN_A3);
             break;
             case 'y':output_low(PIN_A1);
                      output_high(PIN_A2);
                      output_low(PIN_A3);

             break;
             case 'r':output_low(PIN_A1);
                      output_low(PIN_A2);
                      output_high(PIN_A3);

             break;
              default:output_low(PIN_A1);
                      output_low(PIN_A2);
                      output_low(PIN_A3);
             break;

                           }
           }
    }
}


I would like to ask you, here leds blink but issue is it is not reliable. I track the tx, seems always high. I wonder what causes that led to not going to run properly? There is no exact frequency.

Another point is: when just receiver pic has power supply, leds blink fast as flash except A1 led. Smile
What can I do for stable running?
PrinceNai



Joined: 31 Oct 2016
Posts: 482
Location: Montenegro

View user's profile Send private message

PostPosted: Fri Mar 10, 2023 11:58 am     Reply with quote

Why are you not using RDA interrupt on the RX side? It is so much easier and also failsafe.
Ttelmah



Joined: 11 Mar 2010
Posts: 19619

View user's profile Send private message

PostPosted: Fri Mar 10, 2023 12:28 pm     Reply with quote

\if the LED's are flashing when the serial is not connected, I'd be very
suspicious that you have something fundamentally wrong with the wiring,
and the chip is resetting.
1) have you got all the supply and ground pins connected on the chips?.
2) Have you got good HF decoupling capacitors close to the chip supply
pins?.
3) have all the LED connections got suitable current limiting resistors
to them?.
4) How is the MCLR wired?.
5) What is your supply?.
With the serial pulled low (so master not powered), the slave should
be continuously executing the default option, but this will only lead to
a flash, if doing this is causing a reset.
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

PostPosted: Sat Mar 11, 2023 12:39 am     Reply with quote

Ttelmah wrote:
\if the LED's are flashing when the serial is not connected, I'd be very
suspicious that you have something fundamentally wrong with the wiring,
and the chip is resetting.
1) have you got all the supply and ground pins connected on the chips?.
2) Have you got good HF decoupling capacitors close to the chip supply
pins?.
3) have all the LED connections got suitable current limiting resistors
to them?.
4) How is the MCLR wired?.
5) What is your supply?.
With the serial pulled low (so master not powered), the slave should
be continuously executing the default option, but this will only lead to
a flash, if doing this is causing a reset.


1) Yes
2) I have one 100nF cap connected both Vdd
3) No, I just connected directly
4)10k pull-up resistor
5) DC 5V
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

PostPosted: Sat Mar 11, 2023 1:08 am     Reply with quote

PrinceNai wrote:
Why are you not using RDA interrupt on the RX side? It is so much easier and also failsafe.


Do I just need to take this into the rda function?
Code:
switch(data){
             case 'g':output_high(PIN_A1);
                      output_low(PIN_A2);
                      output_low(PIN_A3);
             break;
             case 'y':output_low(PIN_A1);
                      output_high(PIN_A2);
                      output_low(PIN_A3);

             break;
             case 'r':output_low(PIN_A1);
                      output_low(PIN_A2);
                      output_high(PIN_A3);

             break;
              default:output_low(PIN_A1);
                      output_low(PIN_A2);
                      output_low(PIN_A3);
             break;
temtronic



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

View user's profile Send private message

PostPosted: Sat Mar 11, 2023 6:20 am     Reply with quote

!!! #3 Q&A....LEDS !!
You NEED a current limiting resistor between the LEDS and the PIC !! Something like 1k, 680r, 470r, 330r or 270r. The actual value depends on type of LED(red,yel,grn and current (say 5ma ). VDD-vLED/.005= r value, VDD is 5, vLED (red ) is 1.6 so roughly... 5-1.6=3.4, 3.4/.005 is 680r.

re: RDA
The serial interrupt service routine ( ISR) should only be used to capture theh incoming serial data and store in a 'buffer'. ISRs need to need small, short and quick so no PRINTing, 'math' or 'complicated' logic trees.You get the data, store it and set a 'flag',then exit. In main() you test that 'flag' and do 'something'.
Historically 'buffers' were twice as large as the length of incoming data and some binary size (8,16,32, 1024 bytes). 'Size' allows for already received data to be used and still receive more data, 'binary' allows FAST access to the buffer, say for sorting or parsing.

CCS supplies an generic example of an ISR called 'SISR.C', it's located in the examples folder.

also to make code reading easier, you can use #DEFINE myname pinnumber.

#define grnled pin_a3;
so output_high(grnled); helps is 2 ways
1st.it SHOWS you that something should happen to the GREEN LED.
2nd,you only need to change one line of code(the define) to change the pin usage
3rd, it really,really helps others as to what an I/O pin is for !

I'm sure others can explain better... lucky me, I have 10 inches(25 sillymeters) of snow to 'relocate'.......
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

PostPosted: Sat Mar 11, 2023 6:24 am     Reply with quote

receiver
Code:
#include <16f877a.h>
#fuses  PUT, HS, NOWDT, NOLVP, NOBROWNOUT
#use delay(clock=20000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, bits=8, parity=N, errors)
#use standard_io(A)
#use standard_io(B)
void main()

    setup_adc(adc_off);
   set_tris_d(0x00);
   output_d(0x00);
   output_high(pin_D1);
   delay_ms(1000);
   output_low(pin_D1);
   delay_ms(1000);
   output_high(pin_D1);
   
   char data;
   
while(true)
   {
 
             data=getc();
             if(data=='g')
                 {
                   output_high(pin_A1);
                   output_low(pin_A2);
                   output_low(pin_B1);

                 }
             
                 else   if(data=='r')
                 {
                   output_low(pin_A1);
                   output_high(pin_A2);
                   output_low(pin_B1);

                 }
                    else if(data=='b')
                 {
                   output_low(pin_A1);
                   output_low(pin_A2);
                   output_high(pin_B1);

                 }
             
 
    }
}


transmitter
Code:
#include <16F877A.h>
#fuses  PUT, HS, NOWDT, NOLVP, NOBROWNOUT
#use delay(clock=20000000)

#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, bits=8, parity=N, errors)
#define button1 pin_b1
#define button2 pin_b2
#define button3 pin_b4
void main()
{   
   set_tris_d(0x00);
   output_d(0x00);
   output_high(pin_D1);
   delay_ms(1000);
   output_low(pin_D1);
   delay_ms(1000);
   output_high(pin_D1);

   while(true)
   {
     if(input(button1)){
      putc('g');
                  }
   if(input(button2)){
      putc('r');
                  }
       if(input(button3)){
      putc('b');
                  }
     
   }
}


Greetings,
I also added push button for each led.It worked well but when I pressed long button3, pin_b1 led is flashing with other two led.Why? For other two leds do not occur such thing

(I have resistors here for leds)
Ttelmah



Joined: 11 Mar 2010
Posts: 19619

View user's profile Send private message

PostPosted: Sat Mar 11, 2023 7:35 am     Reply with quote

You need to add the current limiting resistors. What is happening is the
LED's have different forward voltages according to their colour. Certain
combinations have a low enough voltage, that they are making the chip
reset when you turn them on. Result disaster.....

Understand that an LED, once the voltage gets above it;s Vf, is effectively
a short. You can never directly connect this to a power source without
smething to limit the current flowing.
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

PostPosted: Sat Mar 11, 2023 9:00 am     Reply with quote

Thank you for clear explanation,
yet what is the problem above?

My current limiting resistors OK
Ttelmah



Joined: 11 Mar 2010
Posts: 19619

View user's profile Send private message

PostPosted: Sun Mar 12, 2023 3:12 am     Reply with quote

Seriously. Hardware.

Now one 0.1uF is not enough. You have two chips, with two pairs of Vdd/Vss
pins, each needs a 0.1uF capacitor within 12mm of these pins, so 4*0.1uF.
You say you have a 5v supply, but have given no details of this. It may
well have it's own internal capacitor, but if this is a distance from the board,
another larger capacitor is needed at the board. How is this generated, and
connected?.
Then the layout of the supply lines. The ground lines need to be laid out
radially from a single point, using good thick wire.
How far apart are the processors, how are the connections done?.
Now you say 'current limiting resistors are OK'. what size are these, how
have you connected these?. The fact that you omitted these originally tells
us you do not really understand how things need to be wired, so tell us
everything about how the boards are built and wired.
temtronic



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

View user's profile Send private message

PostPosted: Sun Mar 12, 2023 10:01 am     Reply with quote

could be a transmitter problem.....
depending on the signal conditioning of the 'buttons'.
mdemuth



Joined: 16 Apr 2007
Posts: 71
Location: Stuttgart, Germany

View user's profile Send private message Visit poster's website

PostPosted: Mon Mar 13, 2023 1:01 am     Reply with quote

Your receiver should check first if there is something in the UART and then take out the character:

Code:

while (!kbhit())   // wait for character
  {
  delay_us(20); 
  counter++;
  if (bit_test(counter,7)) output_high(LED); // blinking LED indicates that we are in this loop
  else output_low(LED);
  }
rx_char = getc();      // put received character into buffer
// Now you can check what has been received
Ttelmah



Joined: 11 Mar 2010
Posts: 19619

View user's profile Send private message

PostPosted: Mon Mar 13, 2023 3:36 am     Reply with quote

Honestly, I'd say he needs to start with the 'slave' unit, and run just a basic
flash an LED program. However on all three LED's, with a pattern, so he can
see if the unit resets at any point. Once this is running correctly, the same
with the master unit. Then have this with buttons to control the LED's on
this. Again using patterns, so he can see that the unit responds correctly
to the buttons. Only once both are running on their own, then start testing
with a communication link.
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

PostPosted: Mon Mar 13, 2023 8:12 am     Reply with quote

Ttelmah wrote:
Seriously. Hardware.

Now one 0.1uF is not enough. You have two chips, with two pairs of Vdd/Vss
pins, each needs a 0.1uF capacitor within 12mm of these pins, so 4*0.1uF.
You say you have a 5v supply, but have given no details of this. It may
well have it's own internal capacitor, but if this is a distance from the board,
another larger capacitor is needed at the board. How is this generated, and
connected?.
Then the layout of the supply lines. The ground lines need to be laid out
radially from a single point, using good thick wire.
How far apart are the processors, how are the connections done?.
Now you say 'current limiting resistors are OK'. what size are these, how
have you connected these?. The fact that you omitted these originally tells
us you do not really understand how things need to be wired, so tell us
everything about how the boards are built and wired.


That is true, you are right sir.

2 Supply voltage seperate for each pic 5V DC <700mA,

tx (push buttons) side //////////// rx (leds) side
pin_C6/TX connected with //////////// pin_C7/RX pin

Leds have 390 ohm resistors.
Khansokhua



Joined: 06 Nov 2021
Posts: 92

View user's profile Send private message

PostPosted: Tue Mar 14, 2023 8:51 am     Reply with quote

Greetings,

here I changed program into this and it is working smoothly.No more multiple blink.So what was the problem? What would you say about that? I send 8 bit data and it prevents another action?

Code:
#include <16f877a.h>
#fuses  PUT, HS, NOWDT, NOLVP, NOBROWNOUT
#use delay(clock=20000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, bits=8, parity=N, errors)

#use standard_io(B)
void main()


   char data;
   
while(1)
   {
 
             data=getc();
             if(data==0b00000010)
                 {
                   output_high(pin_B1);
                   output_low(pin_B2);
                   output_low(pin_B3);

                 }
             
                  if(data==0b00000100)
                 {
                   output_low(pin_B1);
                   output_high(pin_B2);
                   output_low(pin_B3);

                 }
                   if(data==0b00001000)
                 {
                   output_low(pin_B1);
                   output_low(pin_B2);
                   output_high(pin_B3);

                 }
             
 
    }
}
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2, 3, 4, 5, 6  Next
Page 1 of 6

 
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