-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Crash in MQTTAsync_connect() call when MQTT trying to connect initially #1539
Comments
What does few connect tries mean? There are some operations to release and initialize SSL resources in MQTTAsync_connect. If you need to reconnect, I think you should use MQTTAsync_reconnect. |
few connect tries mean, there was no internet connection MQTT will try to connect for the first time which will be initial connection only and when the internet is available at that this issue is occurring and MQTTAsync_connect being used for this scenario, If connection happened and then disconnect then we can use MQTTAsync_reconnect |
I've encountered a similar problem before. I modified the code related to initializing SSL: only initializing the SSL resource once and removing the free operation. It may not be the best solution, but the test results are good so far. |
it would be helpful if you can share the code patch or code snippet of the modified code to resolve this issue |
|
MQTTAsync_reconnect is intended to be used when using automatic reconnect. I'll take a look at this. |
It looks like if you set an SSL option like private key on the first connect and then don't on a later connect it could cause this. I'll fix this up. Does this sound like your situation? |
Actually looking again, I'm not sure how it can. A client version and a client library trace along with a more detailed scenario could help. |
Its very rarely reproducible and i have shared whatever logs i have in the initial coredump, MQTT Paho client version is PAHO MQTT Version: 1.3.13 in which we faced this issue. |
What about some more details of your scenario?
|
Are you using automatic reconnect? Or the connectiionLost callback and a call to connect?
Do you always wait for the onFailure callback before calling connect again?
Are the SSL options the same on each connect call or do you vary them ?
Are there multiple threads involved?
|
Describe the bug
When MQTT trying to connect for the first time after few connect tries, its crashed due to double free of memory in MQTTAsync_connect() call in MQTTAsync.c File
its crashing while trying to free private key
" if (m->c->sslopts->privateKey)
free((void*)m->c->sslopts->privateKey);
"
Issue is not reproducible Every time it Occurs once in a while
To Reproduce
Take a library trace as outlined in the README, and/or have a program or describe the steps to reproduce the behavior:
Expected behavior
A clear and concise description of what you expected to happen.
Screenshots
If applicable, add screenshots to help explain your problem.
Log files Line number may be changed to due to our local patch
#3 0x0000007f924b555c in malloc_printerr (str=str@entry=0x7f9256a798 "free(): double free detected in tcache 2") at malloc.c:5389
No locals.
#4 0x0000007f924b74e0 in _int_free (av=0x7f925aba28 <main_arena>, p=0x55c8d3ef90, have_lock=0) at malloc.c:4232
tmp =
e = 0x55c8d3efa0
tc_idx = 1
size = 48
fb =
nextchunk =
nextsize =
nextinuse =
prevsize =
bck =
fwd =
PRETTY_FUNCTION = "_int_free"
#5 0x0000007f929af840 in MQTTAsync_connect (handle=0x55c8db1e20, options=options@entry=0x55c8d418d8) at /usr/src/debug/paho-mqtt-c/1.3.13-r0/git/src/MQTTAsync.c:755
m = 0x55c8db1e20
rc = 0
conn =
thread_id =
locked =
#6 0x0000007f9359c7c8 in mqtt::async_client::connect (this=this@entry=0x55c8d417a0, opts=..., userContext=userContext@entry=0x0, cb=...) at /usr/src/debug/paho-mqtt-cpp/1.3.2-r0/git/src/async_client.cpp:486
tmpTok = Python Exception <class 'gdb.error'> value has been optimized out:
** Environment (please complete the following information):**
Additional context
Add any other context about the problem here.
The text was updated successfully, but these errors were encountered: