View previous topic :: View next topic |
Author |
Message |
Marttyn
Joined: 06 Mar 2015 Posts: 28 Location: Spain
|
How to know if I'm using serial com? |
Posted: Wed Jan 29, 2020 11:55 am |
|
|
Hi!
I have created a library for my own usage. There i place very common functions i use often.
One of this functions send some information through serial port.
I got used to using conditional compiling to "enable/disable" parts of the code.
In this time i need to disable this part of the code when I'm using the library but the main program is not using RS232 communication. Otherwise, if i leave the code, then i get an error saying that i should use #use RS232 first. Even when I'm not using this function in the program.
So i need some way to verify if the program is using RS232, so this function is enabled by conditional compiling or not.
I couldn't find any way to achieve this. If i just could know if some constant is defined only when RS232 is used...
I DON'T WANT to create my own DEBUG constant to enable this. Hope there is already one.
Thanks for your help! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Wed Jan 29, 2020 12:53 pm |
|
|
RS232_ERRORS is created when you use a UART. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
Re: How to know if I'm using serial com? |
Posted: Wed Jan 29, 2020 4:21 pm |
|
|
Marttyn wrote: |
So i need some way to verify if the program is using RS232, so this
function is enabled by conditional compiling or not.
I couldn't find any way to achieve this. If i just could know if some
constant is defined only when RS232 is used...
|
What do you mean by "when RS232 is used" ?
Do you mean:
1. You want a way to tell at runtime, if your program has a
#use rs232() statement in it ?
or
2. You want a way to tell at runtime, if your program has putc(), getc(),
or printf() in it ? |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9295 Location: Greensville,Ontario
|
|
Posted: Wed Jan 29, 2020 6:39 pm |
|
|
Adding on to PCM P's questions....
3)What about a 'conditional' print ? IE...main() never prints except for an ERROR message ? Say the program is a greenhouse controller, all is well until it gets real cold, that triggers a message to be sent, using serial to PC. As long as the greenhouse is warm, no serial transissions, so PRINTs are never used.
We really need a small example to better understand what you need to accomplish. I know English isn't everyone's best language, I've been fighting with it for 66 years !! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Wed Jan 29, 2020 11:23 pm |
|
|
Agreed.
I must admit I read it that he wanted to know if the RS232
declarations were present, not if the I/O was actually called.
Strikes that if he is adding a debug include, then this should simply
have the RS232 declarations inside it. |
|
|
Marttyn
Joined: 06 Mar 2015 Posts: 28 Location: Spain
|
|
Posted: Thu Jan 30, 2020 3:42 am |
|
|
Thanks for your replies!
I want to know if #use RS232 was used, at compile time, not at runtime.
Lets imagine this:
Code: |
int Add(int a, int b){
long result = a + b;
#ifdef RS232
//only print this to COM port if its in use
printf("%u + %u = %Lu", a, b, result);
#endif
return (result);
}
|
So, when COM port is open, it will output the printf and also the internal result. But if its not, then only the result.
Of course, "RS232" is not a real define... (i think).
What i need is a define created by the compiler only when #use RS232 is used.
I could use this instead:
Code: |
#define DEBUG
#ifdef DEBUG
#use rs232(uart1, baud=115200)
#endif
int Add(int a, int b){
long result = a + b;
#ifdef DEBUG
//only print this to COM port if its in use
printf("%u + %u = %Lu", a, b, result);
#endif
return (result);
}
|
But i just don't want to have extra defines, or additional coding. Just use the functions when i need them, without other worries.
There must be a way to find out if serial is open. Compiler should have some available define... |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Thu Jan 30, 2020 4:15 am |
|
|
At the end of the day, just use a #define. That is what it is for...
Simple answer is 'no'. Reason is that the code does not exist at the
pre-compile stage where things like #if apply.
The compilation is a layered structure. The macro definitions and tests
are done _before_ the code is actually compiled, so at this point there
is no ability to test what is going to happen 'later' during the compile.
#USE RS232, is a compiler directive applied at compile time, not a
pre processor directive. |
|
|
Marttyn
Joined: 06 Mar 2015 Posts: 28 Location: Spain
|
|
Posted: Thu Jan 30, 2020 4:28 am |
|
|
Make sense i guess...
I thought that while at precompile time, if "#use RS232" was found, maybe a #define was created, or some flag was set, that could be checked still at precompile time.
header.h
Code: |
#define IM_USING_RS232
#use rs232(uart1, baud=115200)
|
library.c
Code: | int Add(int a, int b){
long result = a + b;
#ifdef IM_USING_RS232
//only print this to COM port if its in use
printf("%u + %u = %Lu", a, b, result);
#endif
return (result);
} |
Looks redundant to me. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Thu Jan 30, 2020 4:31 am |
|
|
You can go one step 'further':
Put a '#ifdef IM_USING_RS232' before the #use rs232, then you
only have to make the single change of defining this to automatically
add the #use rs232, and the code that uses it. |
|
|
Marttyn
Joined: 06 Mar 2015 Posts: 28 Location: Spain
|
|
Posted: Thu Jan 30, 2020 4:38 am |
|
|
Ttelmah wrote: | You can go one step 'further':
Put a '#ifdef IM_USING_RS232' before the #use rs232, then you
only have to make the single change of defining this to automatically
add the #use rs232, and the code that uses it. |
Keep in mind that my library is one for all. That means that, some programs use some of the included functions, and other programs use others.
When a program calls the add(a, b) function, this program may use, and others may not use the RS232.
So adding a extra #ifdef as you suggest, would just need additional changes to the main program, and its really not needed. As the program that is already using RS232 should not "not compile" that depending on the IM_USING_RS232 define. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Jan 30, 2020 4:55 am |
|
|
I believe I found a way to do it.
Compile this code, with and without commenting the #use rs232() line.
Then look at the compiler build messages in the MPLAB output window.
You will get a warning message, and it will tell you if the #use rs232() line
is there or not. Also, in main(), it will put in printf() if #use rs232() is there.
Code: |
#include <16F1847.h>
#fuses INTRC_IO, NOWDT, PUT, BROWNOUT
#use delay(clock=4M)
#use rs232(UART1, baud=9600, ERRORS)
// This will show it in the Build window at compile-time.
#if definedinc(RS232_ERRORS)
#warning We have RS232
#else
#warning We don't have it.
#endif
//=====================================
void main()
{
// This will put printf code into the program
// if the #use rs232() statement is there.
#if(definedinc(RS232_ERRORS))
printf("Hello there\n\r");
#endif
while(TRUE);
} |
|
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Thu Jan 30, 2020 5:02 am |
|
|
It will only work if you have 'errors' in your RS232 declaration. Now you
should always have this, but 'caveat'.
I had actually tried exactly this earlier, but on a PIC24, was not getting
the nice simple behaviour required. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Jan 30, 2020 5:11 am |
|
|
I agree.
I made a refined version. This one acts like the O.P. actually wanted.
Code: |
#include <16F1847.h>
#fuses INTRC_IO, NOWDT, PUT, BROWNOUT
#use delay(clock=4M)
#use rs232(UART1, baud=9600, ERRORS)
#define RS232 definedinc(RS232_ERRORS)
// This will show it in the Build window at compile-time.
#if RS232
#warning We have serial.
#else
#warning We don't have it.
#endif
//=====================================
void main()
{
// This will put printf code into the program
// if the #use rs232() statement is there.
#if(RS232)
printf("Hello there\r");
#endif
while(TRUE);
}
|
|
|
|
Marttyn
Joined: 06 Mar 2015 Posts: 28 Location: Spain
|
|
Posted: Thu Jan 30, 2020 5:26 am |
|
|
Great! A nice approach!
But, to avoid to use ERRORS check this:
Code: | #if definedinc(STDOUT) |
The first two simple test ive made worked fine... But dont know if it will work on all the circumstances... |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Jan 30, 2020 5:40 am |
|
|
I added your refinement and it works in this test program:
Code: | #include <16F1847.h>
#fuses INTRC_IO, NOWDT, PUT, BROWNOUT
#use delay(clock=4M)
#use rs232(UART1, baud=9600, ERRORS)
#define RS232 definedinc(STDOUT)
// This will show it in the Build window at compile-time.
#if RS232
#warning We have serial.
#else
#warning We don't have serial.
#endif
//=====================================
void main()
{
// This will put printf code into the program
// if the #use rs232() statement is there.
#if(RS232)
printf("Hello there\r");
#endif
while(TRUE);
}
|
|
|
|
|