From 9fe6988efcb1c065d1515dd081956531370e1a6c Mon Sep 17 00:00:00 2001 From: Noel Graf Date: Mon, 11 Apr 2022 15:27:55 +0200 Subject: [PATCH 1/4] Fixed some conversion errors that occur when the -Wc++-compat compiler flag is enabled. --- include/mqtt.h | 2 +- src/mqtt.c | 226 +++++++++++++++++++++++++------------------------ 2 files changed, 115 insertions(+), 113 deletions(-) diff --git a/include/mqtt.h b/include/mqtt.h index 93cc73c..db9fa49 100644 --- a/include/mqtt.h +++ b/include/mqtt.h @@ -283,7 +283,7 @@ uint16_t __mqtt_unpack_uint16(const uint8_t *buf); ssize_t __mqtt_pack_str(uint8_t *buf, const char* str); /** @brief A macro to get the MQTT string length from a c-string. */ -#define __mqtt_packed_cstrlen(x) (2 + strlen(x)) +#define __mqtt_packed_cstrlen(x) (2 + (unsigned int)strlen(x)) /* RESPONSES */ diff --git a/src/mqtt.c b/src/mqtt.c index 97ebc66..fac85af 100644 --- a/src/mqtt.c +++ b/src/mqtt.c @@ -59,11 +59,11 @@ enum MQTTErrors mqtt_sync(struct mqtt_client *client) { } /* Call receive */ - err = __mqtt_recv(client); + err = (enum MQTTErrors)__mqtt_recv(client); if (err != MQTT_OK) return err; /* Call send */ - err = __mqtt_send(client); + err = (enum MQTTErrors)__mqtt_send(client); /* mqtt_reconnect will essentially be a disconnect if there is no callback */ if (reconnecting && client->reconnect_callback != NULL) { @@ -202,23 +202,23 @@ void mqtt_reinit(struct mqtt_client* client, } \ tmp = pack_call; \ if (tmp < 0) { \ - client->error = tmp; \ + client->error = (enum MQTTErrors)tmp; \ if (release) MQTT_PAL_MUTEX_UNLOCK(&client->mutex); \ - return tmp; \ + return (enum MQTTErrors)tmp; \ } else if (tmp == 0) { \ mqtt_mq_clean(&client->mq); \ tmp = pack_call; \ if (tmp < 0) { \ - client->error = tmp; \ + client->error = (enum MQTTErrors)tmp; \ if (release) MQTT_PAL_MUTEX_UNLOCK(&client->mutex); \ - return tmp; \ + return (enum MQTTErrors)tmp; \ } else if(tmp == 0) { \ client->error = MQTT_ERROR_SEND_BUFFER_IS_FULL; \ if (release) MQTT_PAL_MUTEX_UNLOCK(&client->mutex); \ - return MQTT_ERROR_SEND_BUFFER_IS_FULL; \ + return (enum MQTTErrors)MQTT_ERROR_SEND_BUFFER_IS_FULL; \ } \ } \ - msg = mqtt_mq_register(&client->mq, tmp); \ + msg = mqtt_mq_register(&client->mq, (size_t)tmp); \ enum MQTTErrors mqtt_connect(struct mqtt_client *client, @@ -548,11 +548,11 @@ ssize_t __mqtt_send(struct mqtt_client *client) { ssize_t tmp = mqtt_pal_sendall(client->socketfd, msg->start + client->send_offset, msg->size - client->send_offset, 0); if (tmp < 0) { - client->error = tmp; + client->error = (enum MQTTErrors)tmp; MQTT_PAL_MUTEX_UNLOCK(&client->mutex); return tmp; } else { - client->send_offset += tmp; + client->send_offset += (unsigned long)tmp; if(client->send_offset < msg->size) { /* partial sent. Await additional calls */ break; @@ -626,7 +626,7 @@ ssize_t __mqtt_send(struct mqtt_client *client) if (MQTT_PAL_TIME() > keep_alive_timeout) { ssize_t rv = __mqtt_ping(client); if (rv != MQTT_OK) { - client->error = rv; + client->error = (enum MQTTErrors)rv; MQTT_PAL_MUTEX_UNLOCK(&client->mutex); return rv; } @@ -652,19 +652,19 @@ ssize_t __mqtt_recv(struct mqtt_client *client) rv = mqtt_pal_recvall(client->socketfd, client->recv_buffer.curr, client->recv_buffer.curr_sz, 0); if (rv < 0) { /* an error occurred */ - client->error = rv; + client->error = (enum MQTTErrors)rv; MQTT_PAL_MUTEX_UNLOCK(&client->mutex); return rv; } else { client->recv_buffer.curr += rv; - client->recv_buffer.curr_sz -= rv; + client->recv_buffer.curr_sz -= (unsigned long)rv; } /* attempt to parse */ - consumed = mqtt_unpack_response(&response, client->recv_buffer.mem_start, client->recv_buffer.curr - client->recv_buffer.mem_start); + consumed = mqtt_unpack_response(&response, client->recv_buffer.mem_start, (size_t) (client->recv_buffer.curr - client->recv_buffer.mem_start)); if (consumed < 0) { - client->error = consumed; + client->error = (enum MQTTErrors)consumed; MQTT_PAL_MUTEX_UNLOCK(&client->mutex); return consumed; } else if (consumed == 0) { @@ -739,7 +739,7 @@ ssize_t __mqtt_recv(struct mqtt_client *client) if (response.decoded.publish.qos_level == 1) { rv = __mqtt_puback(client, response.decoded.publish.packet_id); if (rv != MQTT_OK) { - client->error = rv; + client->error = (enum MQTTErrors)rv; mqtt_recv_ret = rv; break; } @@ -751,7 +751,7 @@ ssize_t __mqtt_recv(struct mqtt_client *client) rv = __mqtt_pubrec(client, response.decoded.publish.packet_id); if (rv != MQTT_OK) { - client->error = rv; + client->error = (enum MQTTErrors)rv; mqtt_recv_ret = rv; break; } @@ -789,7 +789,7 @@ ssize_t __mqtt_recv(struct mqtt_client *client) /* stage PUBREL */ rv = __mqtt_pubrel(client, response.decoded.pubrec.packet_id); if (rv != MQTT_OK) { - client->error = rv; + client->error = (enum MQTTErrors)rv; mqtt_recv_ret = rv; break; } @@ -808,7 +808,7 @@ ssize_t __mqtt_recv(struct mqtt_client *client) /* stage PUBCOMP */ rv = __mqtt_pubcomp(client, response.decoded.pubrec.packet_id); if (rv != MQTT_OK) { - client->error = rv; + client->error = (enum MQTTErrors)rv; mqtt_recv_ret = rv; break; } @@ -876,10 +876,10 @@ ssize_t __mqtt_recv(struct mqtt_client *client) /* we've handled the response, now clean the buffer */ void* dest = (unsigned char*)client->recv_buffer.mem_start; void* src = (unsigned char*)client->recv_buffer.mem_start + consumed; - size_t n = client->recv_buffer.curr - client->recv_buffer.mem_start - consumed; + size_t n = (size_t) (client->recv_buffer.curr - client->recv_buffer.mem_start - consumed); memmove(dest, src, n); client->recv_buffer.curr -= consumed; - client->recv_buffer.curr_sz += consumed; + client->recv_buffer.curr_sz += (unsigned long)consumed; } } @@ -892,65 +892,67 @@ ssize_t __mqtt_recv(struct mqtt_client *client) #define MQTT_BITFIELD_RULE_VIOLOATION(bitfield, rule_value, rule_mask) ((bitfield ^ rule_value) & rule_mask) -struct { +struct mqtt_fixed_header_rules_s{ const uint8_t control_type_is_valid[16]; const uint8_t required_flags[16]; const uint8_t mask_required_flags[16]; -} mqtt_fixed_header_rules = { - { /* boolean value, true if type is valid */ - 0x00, /* MQTT_CONTROL_RESERVED */ - 0x01, /* MQTT_CONTROL_CONNECT */ - 0x01, /* MQTT_CONTROL_CONNACK */ - 0x01, /* MQTT_CONTROL_PUBLISH */ - 0x01, /* MQTT_CONTROL_PUBACK */ - 0x01, /* MQTT_CONTROL_PUBREC */ - 0x01, /* MQTT_CONTROL_PUBREL */ - 0x01, /* MQTT_CONTROL_PUBCOMP */ - 0x01, /* MQTT_CONTROL_SUBSCRIBE */ - 0x01, /* MQTT_CONTROL_SUBACK */ - 0x01, /* MQTT_CONTROL_UNSUBSCRIBE */ - 0x01, /* MQTT_CONTROL_UNSUBACK */ - 0x01, /* MQTT_CONTROL_PINGREQ */ - 0x01, /* MQTT_CONTROL_PINGRESP */ - 0x01, /* MQTT_CONTROL_DISCONNECT */ - 0x00 /* MQTT_CONTROL_RESERVED */ - }, - { /* flags that must be set for the associated control type */ - 0x00, /* MQTT_CONTROL_RESERVED */ - 0x00, /* MQTT_CONTROL_CONNECT */ - 0x00, /* MQTT_CONTROL_CONNACK */ - 0x00, /* MQTT_CONTROL_PUBLISH */ - 0x00, /* MQTT_CONTROL_PUBACK */ - 0x00, /* MQTT_CONTROL_PUBREC */ - 0x02, /* MQTT_CONTROL_PUBREL */ - 0x00, /* MQTT_CONTROL_PUBCOMP */ - 0x02, /* MQTT_CONTROL_SUBSCRIBE */ - 0x00, /* MQTT_CONTROL_SUBACK */ - 0x02, /* MQTT_CONTROL_UNSUBSCRIBE */ - 0x00, /* MQTT_CONTROL_UNSUBACK */ - 0x00, /* MQTT_CONTROL_PINGREQ */ - 0x00, /* MQTT_CONTROL_PINGRESP */ - 0x00, /* MQTT_CONTROL_DISCONNECT */ - 0x00 /* MQTT_CONTROL_RESERVED */ - }, - { /* mask of flags that must be specific values for the associated control type*/ - 0x00, /* MQTT_CONTROL_RESERVED */ - 0x0F, /* MQTT_CONTROL_CONNECT */ - 0x0F, /* MQTT_CONTROL_CONNACK */ - 0x00, /* MQTT_CONTROL_PUBLISH */ - 0x0F, /* MQTT_CONTROL_PUBACK */ - 0x0F, /* MQTT_CONTROL_PUBREC */ - 0x0F, /* MQTT_CONTROL_PUBREL */ - 0x0F, /* MQTT_CONTROL_PUBCOMP */ - 0x0F, /* MQTT_CONTROL_SUBSCRIBE */ - 0x0F, /* MQTT_CONTROL_SUBACK */ - 0x0F, /* MQTT_CONTROL_UNSUBSCRIBE */ - 0x0F, /* MQTT_CONTROL_UNSUBACK */ - 0x0F, /* MQTT_CONTROL_PINGREQ */ - 0x0F, /* MQTT_CONTROL_PINGRESP */ - 0x0F, /* MQTT_CONTROL_DISCONNECT */ - 0x00 /* MQTT_CONTROL_RESERVED */ - } +} ; + +struct mqtt_fixed_header_rules_s mqtt_fixed_header_rules ={ + { /* boolean value, true if type is valid */ + 0x00, /* MQTT_CONTROL_RESERVED */ + 0x01, /* MQTT_CONTROL_CONNECT */ + 0x01, /* MQTT_CONTROL_CONNACK */ + 0x01, /* MQTT_CONTROL_PUBLISH */ + 0x01, /* MQTT_CONTROL_PUBACK */ + 0x01, /* MQTT_CONTROL_PUBREC */ + 0x01, /* MQTT_CONTROL_PUBREL */ + 0x01, /* MQTT_CONTROL_PUBCOMP */ + 0x01, /* MQTT_CONTROL_SUBSCRIBE */ + 0x01, /* MQTT_CONTROL_SUBACK */ + 0x01, /* MQTT_CONTROL_UNSUBSCRIBE */ + 0x01, /* MQTT_CONTROL_UNSUBACK */ + 0x01, /* MQTT_CONTROL_PINGREQ */ + 0x01, /* MQTT_CONTROL_PINGRESP */ + 0x01, /* MQTT_CONTROL_DISCONNECT */ + 0x00 /* MQTT_CONTROL_RESERVED */ + }, + { /* flags that must be set for the associated control type */ + 0x00, /* MQTT_CONTROL_RESERVED */ + 0x00, /* MQTT_CONTROL_CONNECT */ + 0x00, /* MQTT_CONTROL_CONNACK */ + 0x00, /* MQTT_CONTROL_PUBLISH */ + 0x00, /* MQTT_CONTROL_PUBACK */ + 0x00, /* MQTT_CONTROL_PUBREC */ + 0x02, /* MQTT_CONTROL_PUBREL */ + 0x00, /* MQTT_CONTROL_PUBCOMP */ + 0x02, /* MQTT_CONTROL_SUBSCRIBE */ + 0x00, /* MQTT_CONTROL_SUBACK */ + 0x02, /* MQTT_CONTROL_UNSUBSCRIBE */ + 0x00, /* MQTT_CONTROL_UNSUBACK */ + 0x00, /* MQTT_CONTROL_PINGREQ */ + 0x00, /* MQTT_CONTROL_PINGRESP */ + 0x00, /* MQTT_CONTROL_DISCONNECT */ + 0x00 /* MQTT_CONTROL_RESERVED */ + }, + { /* mask of flags that must be specific values for the associated control type*/ + 0x00, /* MQTT_CONTROL_RESERVED */ + 0x0F, /* MQTT_CONTROL_CONNECT */ + 0x0F, /* MQTT_CONTROL_CONNACK */ + 0x00, /* MQTT_CONTROL_PUBLISH */ + 0x0F, /* MQTT_CONTROL_PUBACK */ + 0x0F, /* MQTT_CONTROL_PUBREC */ + 0x0F, /* MQTT_CONTROL_PUBREL */ + 0x0F, /* MQTT_CONTROL_PUBCOMP */ + 0x0F, /* MQTT_CONTROL_SUBSCRIBE */ + 0x0F, /* MQTT_CONTROL_SUBACK */ + 0x0F, /* MQTT_CONTROL_UNSUBSCRIBE */ + 0x0F, /* MQTT_CONTROL_UNSUBACK */ + 0x0F, /* MQTT_CONTROL_PINGREQ */ + 0x0F, /* MQTT_CONTROL_PINGRESP */ + 0x0F, /* MQTT_CONTROL_DISCONNECT */ + 0x00 /* MQTT_CONTROL_RESERVED */ + } }; static ssize_t mqtt_fixed_header_rule_violation(const struct mqtt_fixed_header *fixed_header) { @@ -960,7 +962,7 @@ static ssize_t mqtt_fixed_header_rule_violation(const struct mqtt_fixed_header * uint8_t mask_required_flags; /* get value and rules */ - control_type = fixed_header->control_type; + control_type = (uint8_t)fixed_header->control_type; control_flags = fixed_header->control_flags; required_flags = mqtt_fixed_header_rules.required_flags[control_type]; mask_required_flags = mqtt_fixed_header_rules.mask_required_flags[control_type]; @@ -994,8 +996,8 @@ ssize_t mqtt_unpack_fixed_header(struct mqtt_response *response, const uint8_t * if (bufsz == 0) return 0; /* parse control type and flags */ - fixed_header->control_type = *buf >> 4; - fixed_header->control_flags = *buf & 0x0F; + fixed_header->control_type = (enum MQTTControlPacketType) (*buf >> 4); + fixed_header->control_flags = (uint8_t) (*buf & 0x0F); /* parse remaining size */ fixed_header->remaining_length = 0; @@ -1013,7 +1015,7 @@ ssize_t mqtt_unpack_fixed_header(struct mqtt_response *response, const uint8_t * if (bufsz == 0) return 0; /* parse next byte*/ - fixed_header->remaining_length += (*buf & 0x7F) << lshift; + fixed_header->remaining_length += (uint32_t) ((*buf & 0x7F) << lshift); lshift += 7; } while(*buf & 0x80); /* while continue bit is set */ @@ -1056,8 +1058,8 @@ ssize_t mqtt_pack_fixed_header(uint8_t *buf, size_t bufsz, const struct mqtt_fix if (bufsz == 0) return 0; /* pack control type and flags */ - *buf = (((uint8_t) fixed_header->control_type) << 4) & 0xF0; - *buf |= ((uint8_t) fixed_header->control_flags) & 0x0F; + *buf = (uint8_t)((((uint8_t) fixed_header->control_type) << 4) & 0xF0); + *buf = (uint8_t)(*buf | (((uint8_t) fixed_header->control_flags) & 0x0F)); remaining_length = fixed_header->remaining_length; @@ -1111,7 +1113,7 @@ ssize_t mqtt_pack_connection_request(uint8_t* buf, size_t bufsz, fixed_header.control_flags = 0x00; /* calculate remaining length and build connect_flags at the same time */ - connect_flags = connect_flags & ~MQTT_CONNECT_RESERVED; + connect_flags = (uint8_t) (connect_flags & ~MQTT_CONNECT_RESERVED); remaining_length = 10; /* size of variable header */ if (client_id == NULL) { @@ -1144,9 +1146,9 @@ ssize_t mqtt_pack_connection_request(uint8_t* buf, size_t bufsz, } } else { /* there is no will so set all will flags to zero */ - connect_flags &= ~MQTT_CONNECT_WILL_FLAG; - connect_flags &= ~0x18; - connect_flags &= ~MQTT_CONNECT_WILL_RETAIN; + connect_flags &= (uint8_t)~MQTT_CONNECT_WILL_FLAG; + connect_flags &= (uint8_t)~0x18; + connect_flags &= (uint8_t)~MQTT_CONNECT_WILL_RETAIN; } if (user_name != NULL) { @@ -1154,7 +1156,7 @@ ssize_t mqtt_pack_connection_request(uint8_t* buf, size_t bufsz, connect_flags |= MQTT_CONNECT_USER_NAME; remaining_length += __mqtt_packed_cstrlen(user_name); } else { - connect_flags &= ~MQTT_CONNECT_USER_NAME; + connect_flags &= (uint8_t)~MQTT_CONNECT_USER_NAME; } if (password != NULL) { @@ -1162,11 +1164,11 @@ ssize_t mqtt_pack_connection_request(uint8_t* buf, size_t bufsz, connect_flags |= MQTT_CONNECT_PASSWORD; remaining_length += __mqtt_packed_cstrlen(password); } else { - connect_flags &= ~MQTT_CONNECT_PASSWORD; + connect_flags &= (uint8_t)~MQTT_CONNECT_PASSWORD; } /* fixed header length is now calculated*/ - fixed_header.remaining_length = remaining_length; + fixed_header.remaining_length = (uint32_t)remaining_length; /* pack fixed header and perform error checks */ rv = mqtt_pack_fixed_header(buf, bufsz, &fixed_header); @@ -1175,7 +1177,7 @@ ssize_t mqtt_pack_connection_request(uint8_t* buf, size_t bufsz, return rv; } buf += rv; - bufsz -= rv; + bufsz -= (size_t)rv; /* check that the buffer has enough space to fit the remaining length */ if (bufsz < fixed_header.remaining_length) { @@ -1293,14 +1295,14 @@ ssize_t mqtt_pack_publish_request(uint8_t *buf, size_t bufsz, /* force dup to 0 if qos is 0 [Spec MQTT-3.3.1-2] */ if (inspected_qos == 0) { - publish_flags &= ~MQTT_PUBLISH_DUP; + publish_flags &= (uint8_t)~MQTT_PUBLISH_DUP; } /* make sure that qos is not 3 [Spec MQTT-3.3.1-4] */ if (inspected_qos == 3) { return MQTT_ERROR_PUBLISH_FORBIDDEN_QOS; } - fixed_header.control_flags = publish_flags; + fixed_header.control_flags = publish_flags & 0x7; /* pack fixed header */ rv = mqtt_pack_fixed_header(buf, bufsz, &fixed_header); @@ -1309,7 +1311,7 @@ ssize_t mqtt_pack_publish_request(uint8_t *buf, size_t bufsz, return rv; } buf += rv; - bufsz -= rv; + bufsz -= (size_t)rv; /* check that buffer is big enough */ if (bufsz < remaining_length) { @@ -1397,7 +1399,7 @@ ssize_t mqtt_pack_pubxxx_request(uint8_t *buf, size_t bufsz, return rv; } buf += rv; - bufsz -= rv; + bufsz -= (size_t)rv; if (bufsz < fixed_header.remaining_length) { return 0; @@ -1503,7 +1505,7 @@ ssize_t mqtt_pack_subscribe_request(uint8_t *buf, size_t bufsz, unsigned int pac return rv; } buf += rv; - bufsz -= rv; + bufsz -= (unsigned long)rv; /* check that the buffer has enough space */ if (bufsz < fixed_header.remaining_length) { @@ -1512,7 +1514,7 @@ ssize_t mqtt_pack_subscribe_request(uint8_t *buf, size_t bufsz, unsigned int pac /* pack variable header */ - buf += __mqtt_pack_uint16(buf, packet_id); + buf += __mqtt_pack_uint16(buf, (uint16_t)packet_id); /* pack payload */ @@ -1582,7 +1584,7 @@ ssize_t mqtt_pack_unsubscribe_request(uint8_t *buf, size_t bufsz, unsigned int p return rv; } buf += rv; - bufsz -= rv; + bufsz -= (unsigned long)rv; /* check that the buffer has enough space */ if (bufsz < fixed_header.remaining_length) { @@ -1590,7 +1592,7 @@ ssize_t mqtt_pack_unsubscribe_request(uint8_t *buf, size_t bufsz, unsigned int p } /* pack variable header */ - buf += __mqtt_pack_uint16(buf, packet_id); + buf += __mqtt_pack_uint16(buf, (uint16_t)packet_id); /* pack payload */ @@ -1607,10 +1609,10 @@ void mqtt_mq_init(struct mqtt_message_queue *mq, void *buf, size_t bufsz) if(buf != NULL) { mq->mem_start = buf; - mq->mem_end = (unsigned char*)buf + bufsz; - mq->curr = buf; - mq->queue_tail = mq->mem_end; - mq->curr_sz = mqtt_mq_currsz(mq); + mq->mem_end = (uint8_t *)buf + bufsz; + mq->curr = (uint8_t *)buf; + mq->queue_tail = (struct mqtt_queued_message *)mq->mem_end; + mq->curr_sz = (size_t) (mqtt_mq_currsz(mq)); } } @@ -1624,7 +1626,7 @@ struct mqtt_queued_message* mqtt_mq_register(struct mqtt_message_queue *mq, size /* move curr and recalculate curr_sz */ mq->curr += nbytes; - mq->curr_sz = mqtt_mq_currsz(mq); + mq->curr_sz = (size_t) (mqtt_mq_currsz(mq)); return mq->queue_tail; } @@ -1638,9 +1640,9 @@ void mqtt_mq_clean(struct mqtt_message_queue *mq) { /* check if everything can be removed */ if (new_head < mq->queue_tail) { - mq->curr = mq->mem_start; - mq->queue_tail = mq->mem_end; - mq->curr_sz = mqtt_mq_currsz(mq); + mq->curr = (uint8_t *)mq->mem_start; + mq->queue_tail = (struct mqtt_queued_message *)mq->mem_end; + mq->curr_sz = (size_t) (mqtt_mq_currsz(mq)); return; } else if (new_head == mqtt_mq_get(mq, 0)) { /* do nothing */ @@ -1649,8 +1651,8 @@ void mqtt_mq_clean(struct mqtt_message_queue *mq) { /* move buffered data */ { - size_t n = mq->curr - new_head->start; - size_t removing = new_head->start - (uint8_t*) mq->mem_start; + size_t n = (size_t) (mq->curr - new_head->start); + size_t removing = (size_t) (new_head->start - (uint8_t*) mq->mem_start); memmove(mq->mem_start, new_head->start, n); mq->curr = (unsigned char*)mq->mem_start + n; @@ -1658,7 +1660,7 @@ void mqtt_mq_clean(struct mqtt_message_queue *mq) { /* move queue */ { ssize_t new_tail_idx = new_head - mq->queue_tail; - memmove(mqtt_mq_get(mq, new_tail_idx), mq->queue_tail, sizeof(struct mqtt_queued_message) * (new_tail_idx + 1)); + memmove(mqtt_mq_get(mq, new_tail_idx), mq->queue_tail, sizeof(struct mqtt_queued_message) * (size_t) ((new_tail_idx + 1))); mq->queue_tail = mqtt_mq_get(mq, new_tail_idx); { @@ -1672,7 +1674,7 @@ void mqtt_mq_clean(struct mqtt_message_queue *mq) { } /* get curr_sz */ - mq->curr_sz = mqtt_mq_currsz(mq); + mq->curr_sz = (size_t) (mqtt_mq_currsz(mq)); } struct mqtt_queued_message* mqtt_mq_find(struct mqtt_message_queue *mq, enum MQTTControlPacketType control_type, uint16_t *packet_id) @@ -1755,7 +1757,7 @@ ssize_t __mqtt_pack_str(uint8_t *buf, const char* str) { /* pack string */ for(; i < length; ++i) { - *(buf++) = str[i]; + *(buf++) = (uint8_t)str[i]; } /* return number of bytes consumed */ From 7321d60d63d1fed28028bedab46bd0fb2f5115bb Mon Sep 17 00:00:00 2001 From: Noel Graf Date: Thu, 12 May 2022 11:48:51 +0200 Subject: [PATCH 2/4] Some conversion errors in the template files that occur with certain compiler flags have been fixed. --- examples/templates/mbedtls_sockets.h | 5 +++++ examples/templates/openssl_sockets.h | 29 +++++++++++++++++++++++----- examples/templates/posix_sockets.h | 2 ++ 3 files changed, 31 insertions(+), 5 deletions(-) diff --git a/examples/templates/mbedtls_sockets.h b/examples/templates/mbedtls_sockets.h index 56b4c18..207615c 100644 --- a/examples/templates/mbedtls_sockets.h +++ b/examples/templates/mbedtls_sockets.h @@ -52,6 +52,11 @@ void cert_verify_failed(uint32_t rv) { /* A template for opening a non-blocking mbed TLS connection. */ +void open_nb_socket(struct mbedtls_context *ctx, + const char *hostname, + const char *port, + const char *ca_file); + void open_nb_socket(struct mbedtls_context *ctx, const char *hostname, const char *port, diff --git a/examples/templates/openssl_sockets.h b/examples/templates/openssl_sockets.h index 09548b5..325b59d 100644 --- a/examples/templates/openssl_sockets.h +++ b/examples/templates/openssl_sockets.h @@ -5,9 +5,20 @@ #include #include +#include + /* A template for opening a non-blocking OpenSSL connection. */ +void open_nb_socket(BIO** bio, + SSL_CTX** ssl_ctx, + const char* addr, + const char* port, + const char* ca_file, + const char* ca_path, + const char* cert_file, + const char* key_file); + void open_nb_socket(BIO** bio, SSL_CTX** ssl_ctx, const char* addr, @@ -42,18 +53,26 @@ void open_nb_socket(BIO** bio, } /* open BIO socket */ + char * addr_copy = (char*)malloc(strlen(addr) + 1); + strcpy(addr_copy,addr); + char * port_copy = (char*)malloc(strlen(port) + 1); + strcpy(port_copy,port); + *bio = BIO_new_ssl_connect(*ssl_ctx); BIO_get_ssl(*bio, &ssl); SSL_set_mode(ssl, SSL_MODE_AUTO_RETRY); - BIO_set_conn_hostname(*bio, addr); + BIO_set_conn_hostname(*bio, addr_copy); BIO_set_nbio(*bio, 1); - BIO_set_conn_port(*bio, port); + BIO_set_conn_port(*bio, port_copy); + + free(addr_copy); + free(port_copy); /* wait for connect with 10 second timeout */ - int start_time = time(NULL); - int do_connect_rv = BIO_do_connect(*bio); + int start_time = (int)time(NULL); + int do_connect_rv = (int)BIO_do_connect(*bio); while(do_connect_rv <= 0 && BIO_should_retry(*bio) && (int)time(NULL) - start_time < 10) { - do_connect_rv = BIO_do_connect(*bio); + do_connect_rv = (int)BIO_do_connect(*bio); } if (do_connect_rv <= 0) { printf("error: %s\n", ERR_reason_error_string(ERR_get_error())); diff --git a/examples/templates/posix_sockets.h b/examples/templates/posix_sockets.h index a296c7e..8de9990 100644 --- a/examples/templates/posix_sockets.h +++ b/examples/templates/posix_sockets.h @@ -17,6 +17,8 @@ /* A template for opening a non-blocking POSIX socket. */ +int open_nb_socket(const char* addr, const char* port); + int open_nb_socket(const char* addr, const char* port) { struct addrinfo hints = {0}; From 753821d9530d2c024c55d3359a23b95ec3db67c1 Mon Sep 17 00:00:00 2001 From: Noel Graf Date: Thu, 12 May 2022 12:26:29 +0200 Subject: [PATCH 3/4] Some conversion errors in the mqtt_pal.c that occur with certain compiler flags have been fixed. --- src/mqtt_pal.c | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/mqtt_pal.c b/src/mqtt_pal.c index d26328f..0a59c96 100644 --- a/src/mqtt_pal.c +++ b/src/mqtt_pal.c @@ -299,7 +299,7 @@ ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int ssize_t mqtt_pal_sendall(mqtt_pal_socket_handle fd, const void* buf, size_t len, int flags) { size_t sent = 0; while(sent < len) { - int tmp = BIO_write(fd, (const char*)buf + sent, len - sent); + int tmp = BIO_write(fd, (const char*)buf + sent, (int)(len - sent)); if (tmp > 0) { sent += (size_t) tmp; } else if (tmp <= 0 && !BIO_should_retry(fd)) { @@ -307,19 +307,19 @@ ssize_t mqtt_pal_sendall(mqtt_pal_socket_handle fd, const void* buf, size_t len, } } - return sent; + return (ssize_t)sent; } ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int flags) { - const char* const start = buf; - char* bufptr = buf; + const char* const start = (const char*)buf; + char* bufptr = (char*)buf; int rv; do { - rv = BIO_read(fd, bufptr, bufsz); + rv = BIO_read(fd, bufptr, (int)bufsz); if (rv > 0) { /* successfully read bytes from the socket */ bufptr += rv; - bufsz -= rv; + bufsz -= (unsigned long)rv; } else if (!BIO_should_retry(fd)) { /* an error occurred that wasn't "nothing to read". */ return MQTT_ERROR_SOCKET_ERROR; @@ -337,7 +337,7 @@ ssize_t mqtt_pal_sendall(mqtt_pal_socket_handle fd, const void* buf, size_t len, enum MQTTErrors error = 0; size_t sent = 0; while(sent < len) { - ssize_t rv = send(fd, buf + sent, len - sent, flags); + ssize_t rv = send(fd, (const char*)buf + sent, len - sent, flags); if (rv < 0) { if (errno == EAGAIN) { /* should call send later again */ @@ -356,7 +356,7 @@ ssize_t mqtt_pal_sendall(mqtt_pal_socket_handle fd, const void* buf, size_t len, if (sent == 0) { return error; } - return sent; + return (ssize_t)sent; } ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int flags) { @@ -384,12 +384,12 @@ ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int break; } buf = (char*)buf + rv; - bufsz -= rv; + bufsz -= (unsigned long)rv; } while (bufsz > 0); if (buf == start) { return error; } - return buf - start; + return (char*)buf - (const char*)start; } #elif defined(_MSC_VER) || defined(WIN32) From ad25f16be21ac79306435bdf319dc8289bc85265 Mon Sep 17 00:00:00 2001 From: Noel Graf Date: Mon, 23 May 2022 00:41:02 +0200 Subject: [PATCH 4/4] Fix conversion error that occurs when mbedtls is used as crypto backend. --- examples/templates/mbedtls_sockets.h | 17 ++++++++++------- src/mqtt_pal.c | 10 +++++----- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/examples/templates/mbedtls_sockets.h b/examples/templates/mbedtls_sockets.h index 207615c..ddbbd05 100644 --- a/examples/templates/mbedtls_sockets.h +++ b/examples/templates/mbedtls_sockets.h @@ -35,6 +35,14 @@ struct mbedtls_context { mbedtls_ctr_drbg_context ctr_drbg; }; +void failed(const char *fn, int rv); +void cert_verify_failed(uint32_t rv); +void open_nb_socket(struct mbedtls_context *ctx, + const char *hostname, + const char *port, + const char *ca_file); + + void failed(const char *fn, int rv) { char buf[100]; mbedtls_strerror(rv, buf, sizeof(buf)); @@ -52,11 +60,6 @@ void cert_verify_failed(uint32_t rv) { /* A template for opening a non-blocking mbed TLS connection. */ -void open_nb_socket(struct mbedtls_context *ctx, - const char *hostname, - const char *port, - const char *ca_file); - void open_nb_socket(struct mbedtls_context *ctx, const char *hostname, const char *port, @@ -129,7 +132,7 @@ void open_nb_socket(struct mbedtls_context *ctx, } else { break; } - rv = mbedtls_net_poll(net_ctx, want, -1); + rv = mbedtls_net_poll(net_ctx, want, (uint32_t)-1); if (rv < 0) { failed("mbedtls_net_poll", rv); } @@ -140,7 +143,7 @@ void open_nb_socket(struct mbedtls_context *ctx, uint32_t result = mbedtls_ssl_get_verify_result(ssl_ctx); if (result != 0) { if (result == (uint32_t)-1) { - failed("mbedtls_ssl_get_verify_result", result); + failed("mbedtls_ssl_get_verify_result", (int)result); } else { cert_verify_failed(result); } diff --git a/src/mqtt_pal.c b/src/mqtt_pal.c index 0a59c96..27e8149 100644 --- a/src/mqtt_pal.c +++ b/src/mqtt_pal.c @@ -51,7 +51,7 @@ ssize_t mqtt_pal_sendall(mqtt_pal_socket_handle fd, const void* buf, size_t len, enum MQTTErrors error = 0; size_t sent = 0; while(sent < len) { - int rv = mbedtls_ssl_write(fd, buf + sent, len - sent); + int rv = mbedtls_ssl_write(fd, (const unsigned char*)buf + sent, len - sent); if (rv < 0) { if (rv == MBEDTLS_ERR_SSL_WANT_READ || rv == MBEDTLS_ERR_SSL_WANT_WRITE @@ -79,7 +79,7 @@ ssize_t mqtt_pal_sendall(mqtt_pal_socket_handle fd, const void* buf, size_t len, if (sent == 0) { return error; } - return sent; + return (ssize_t)sent; } ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int flags) { @@ -87,7 +87,7 @@ ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int enum MQTTErrors error = 0; int rv; do { - rv = mbedtls_ssl_read(fd, buf, bufsz); + rv = mbedtls_ssl_read(fd, (unsigned char*)buf, bufsz); if (rv == 0) { /* * Note: mbedtls_ssl_read returns 0 when the underlying @@ -116,12 +116,12 @@ ssize_t mqtt_pal_recvall(mqtt_pal_socket_handle fd, void* buf, size_t bufsz, int break; } buf = (char*)buf + rv; - bufsz -= rv; + bufsz -= (unsigned long)rv; } while (bufsz > 0); if (buf == start) { return error; } - return buf - start; + return (const char *)buf - (const char*)start; } #elif defined(MQTT_USE_WOLFSSL)