Using the MDF with C++
Re: Using the MDF with C++
Hi
The get_atarted file I left as a .c file. All I did was rename the app-main function so I could move it to Lee.cpp to prove that the main could exist in a .CPP file. The class doesn't wrap the get_started funxtions I included it to prove that you can define classes there and therefore use c++.
In theory, if you can get this to compile, you can now do whatever c++ you want in the lee.cpp files even calling the functions from get-started e.g. call app-main1 from app-main1 in lee.cpp to run the example.
I built it on Ubuntu with compiler version 5.2.0 and crosstool 1.22.0-73 - it displays both when you run make from the command line.
The get_atarted file I left as a .c file. All I did was rename the app-main function so I could move it to Lee.cpp to prove that the main could exist in a .CPP file. The class doesn't wrap the get_started funxtions I included it to prove that you can define classes there and therefore use c++.
In theory, if you can get this to compile, you can now do whatever c++ you want in the lee.cpp files even calling the functions from get-started e.g. call app-main1 from app-main1 in lee.cpp to run the example.
I built it on Ubuntu with compiler version 5.2.0 and crosstool 1.22.0-73 - it displays both when you run make from the command line.
Re: Using the MDF with C++
Thanks again Lee for your help, I've renamed get_started.cpp back to get_started.c, and - this is getting ridiculous now - it compiles, but the linker can't find app_main... I guess the linker is ignoring the lee.o file.
Both lee.cpp and get_started.c are compiled.
I have no idea what's going on, I've written plenty of projects with Arduino libraries and have never had so much trouble!
I'm using crosstool 1.22.0-80, and compiler 5.2.0.
Code: Select all
$ make
[snip]
Generating libwpa_supplicant.a.sections_info
Generating libxtensa-debug-module.a.sections_info
Generating esp32.common.ld
LD build/get-started.elf
/Users/elijah/esp/get-started/build/esp32/libesp32.a(cpu_start.o):(.literal.main_task+0x10): undefined reference to `app_main'
/Users/elijah/esp/get-started/build/esp32/libesp32.a(cpu_start.o): In function `main_task':
/Users/elijah/esp/esp-mdf/esp-idf/components/esp32/cpu_start.c:503: undefined reference to `app_main'
collect2: error: ld returned 1 exit status
Code: Select all
CC build/main/get_started.o
CXX build/main/lee.o
/Users/elijah/esp/get-started/main/lee.cpp: In constructor 'LeeTest::LeeTest()':
/Users/elijah/esp/get-started/main/lee.cpp:6:5: warning: unused variable 'i' [-Wunused-variable]
int i =0;
^
AR build/main/libmain.a
I'm using crosstool 1.22.0-80, and compiler 5.2.0.
Code: Select all
Toolchain path: /Users/elijah/esp/xtensa-esp32-elf/bin/xtensa-esp32-elf-gcc
Toolchain version: crosstool-ng-1.22.0-80-g6c4433a
Compiler version: 5.2.0
Re: Using the MDF with C++
Do you have app_main1() defined in get_started.h and in get_started.c? You should then have app_main() defined in lee.cpp only
Re: Using the MDF with C++
A couple of other thoughts....
1. you did put the lee files and the get_started.h in the main directory with the get_started.c file?
2. you could try a "make clean" and then do a "make"
1. you did put the lee files and the get_started.h in the main directory with the get_started.c file?
2. you could try a "make clean" and then do a "make"
Re: Using the MDF with C++
Yup.
Yes, all in the same folder, and I've tried make clean too... I've attached the entire get-started folder, perhaps you could try compiling it your end?
Thanks again!
- Attachments
-
- get-started.zip
- (65.68 KiB) Downloaded 712 times
Re: Using the MDF with C++
I've posted a comment on the Github issue relating to this, as I still feel the examples should compile as C++ without having to include the functions through a class.
Re: Using the MDF with C++
I've managed to fix the example code so that it'll compile with C++!
The erroring lines (81-85 and 376-381) are actually structs of type sockaddr_in and mwifi_config_t. C supports designated initializers whereas C++ does not, and apparently even when compiled with 'extern "C"' around them, they're still not supported by the C++ compiler. Designated initializers are a C99 thing, presumably the C++ compiler doesn't support C99. The error resulting from this is:
Not sure how these are anything but trivial, but still.
Each of these is fixed by simply changing 81-85 from this...
to this:
and 376-381 from this...
to this:
Also app_main needs to be wrapped within extern "C"...
...and of course rename the [nnn]_example.c to [nnn]_example.cpp.
Hope that helps someone at some point! I'll update the Github issue with a pull request too.
Thanks again Lee for your help with this!
The erroring lines (81-85 and 376-381) are actually structs of type sockaddr_in and mwifi_config_t. C supports designated initializers whereas C++ does not, and apparently even when compiled with 'extern "C"' around them, they're still not supported by the C++ compiler. Designated initializers are a C99 thing, presumably the C++ compiler doesn't support C99. The error resulting from this is:
Code: Select all
Sorry, unimplemented: non-trivial designated initializers not supported
Each of these is fixed by simply changing 81-85 from this...
Code: Select all
struct sockaddr_in server_addr = {
.sin_family = AF_INET,
.sin_port = htons(port),
.sin_addr.s_addr = inet_addr(ip),
};
Code: Select all
struct sockaddr_in server_addr;
server_addr.sin_family = AF_INET,
server_addr.sin_port = htons(port),
server_addr.sin_addr.s_addr = inet_addr(ip),
Code: Select all
mwifi_config_t config = {
.router_ssid = CONFIG_ROUTER_SSID,
.router_password = CONFIG_ROUTER_PASSWORD,
.mesh_id = CONFIG_MESH_ID,
.mesh_password = CONFIG_MESH_PASSWORD,
};
Code: Select all
mwifi_config_t config;
strncpy(config.router_ssid, CONFIG_ROUTER_SSID, 32);
strncpy(config.router_password, CONFIG_ROUTER_PASSWORD, 64);
memcpy(config.mesh_id, CONFIG_MESH_ID, 8);
strncpy(config.mesh_password, CONFIG_MESH_PASSWORD, 64);
Code: Select all
extern "C" {
void app_main();
}
Hope that helps someone at some point! I'll update the Github issue with a pull request too.
Thanks again Lee for your help with this!
Re: Using the MDF with C++
Seems odd thought that mine compiles fine without the changes. In terms of what I did, I didn't wrap app-main in a class just merely implemented it in the CPP file rather than the .c file in the example. I will take a look at the folder you sent over the weekend.
Re: Using the MDF with C++
Hi,
I have looked at this again and seems like I must have missed the error as I have the same as you now. So... have fixed it in the attached files. The issue was that the CPP compiler was compiling app_main and mangling the name. Thus when it came to linking it was looking for app_main but got the mangled version. Putting extern "C" wrappers around it fixes that. The other trouble was that app_main1 was referenced from a .c file and a .cpp file. When from a .cpp file it will mangle the name but from a .c file it will not. Hence.... the extern "C" wrappers and the #defines to change behaviour when needed.
You may need to do a "make clean" or delete the build directories.
Hope this works for you...
thanks
Lee.
I have looked at this again and seems like I must have missed the error as I have the same as you now. So... have fixed it in the attached files. The issue was that the CPP compiler was compiling app_main and mangling the name. Thus when it came to linking it was looking for app_main but got the mangled version. Putting extern "C" wrappers around it fixes that. The other trouble was that app_main1 was referenced from a .c file and a .cpp file. When from a .cpp file it will mangle the name but from a .c file it will not. Hence.... the extern "C" wrappers and the #defines to change behaviour when needed.
You may need to do a "make clean" or delete the build directories.
Hope this works for you...
thanks
Lee.
- Attachments
-
- main.zip
- (6.79 KiB) Downloaded 645 times
Re: Using the MDF with C++
hi
this issue still continue.
i use the mqtt_example in C++ and have many errors in mdf_mem.h
mostly a bad convertion form void to char or to int
this not compile for C++
mdebug_cmd.c:317:16: warning: assignment from incompatible pointer type [-Wincompatible-pointer-types]
packet = MDF_CALLOC(1, sizeof(mdebug_coredump_packet_t));
^
In file included from /home/cowscan/esp/esp-mdf/components/mcommon/include/mdf_common.h:59:0,
from /home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp:43:
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp: In function 'void node_read_task(void*)':
/home/cowscan/esp/esp-mdf/components/mcommon/include/mdf_mem.h:89:12: error: invalid conversion from 'void*' to 'char*' [-fpermissive]
ptr; \
^
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp:185:21: note: in expansion of macro 'MDF_MALLOC'
char *data = MDF_MALLOC(MWIFI_PAYLOAD_LEN);
^
CC build/mcommon/mdf_mem.o
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp: In function 'mdf_err_t event_loop_cb(mdf_event_loop_t, void*)':
/home/cowscan/esp/esp-mdf/components/mcommon/include/mdf_mem.h:89:12: error: invalid conversion from 'void*' to 'uint8_t* {aka unsigned char*}' [-fpermissive]
ptr; \
^
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp:349:41: note: in expansion of macro 'MDF_MALLOC'
node_list.change_list = MDF_MALLOC(node_list.change_num * sizeof(mesh_addr_t));
thanks in any update to use MDF in c++
this issue still continue.
i use the mqtt_example in C++ and have many errors in mdf_mem.h
mostly a bad convertion form void to char or to int
this not compile for C++
mdebug_cmd.c:317:16: warning: assignment from incompatible pointer type [-Wincompatible-pointer-types]
packet = MDF_CALLOC(1, sizeof(mdebug_coredump_packet_t));
^
In file included from /home/cowscan/esp/esp-mdf/components/mcommon/include/mdf_common.h:59:0,
from /home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp:43:
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp: In function 'void node_read_task(void*)':
/home/cowscan/esp/esp-mdf/components/mcommon/include/mdf_mem.h:89:12: error: invalid conversion from 'void*' to 'char*' [-fpermissive]
ptr; \
^
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp:185:21: note: in expansion of macro 'MDF_MALLOC'
char *data = MDF_MALLOC(MWIFI_PAYLOAD_LEN);
^
CC build/mcommon/mdf_mem.o
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp: In function 'mdf_err_t event_loop_cb(mdf_event_loop_t, void*)':
/home/cowscan/esp/esp-mdf/components/mcommon/include/mdf_mem.h:89:12: error: invalid conversion from 'void*' to 'uint8_t* {aka unsigned char*}' [-fpermissive]
ptr; \
^
/home/cowscan/esp/esp-mdf/MPU-driver/cowscan/main/cowscan.cpp:349:41: note: in expansion of macro 'MDF_MALLOC'
node_list.change_list = MDF_MALLOC(node_list.change_num * sizeof(mesh_addr_t));
thanks in any update to use MDF in c++
Who is online
Users browsing this forum: No registered users and 16 guests