[lttng-dev] [PATCH lttng-tools] Fix: Dereference after NULL check in consumer
Jérémie Galarneau
jeremie.galarneau at efficios.com
Wed May 18 19:22:20 UTC 2016
Merged, thanks!
Jérémie
On Tue, May 17, 2016 at 11:46 AM, Mathieu Desnoyers
<mathieu.desnoyers at efficios.com> wrote:
> Dereference after NULL check in consumer discarded events/lost packets
> commands.
>
> Found by Coverity:
>
> CID 1040158 (#1 of 2): Dereference after null check (FORWARD_NULL)24.
> var_deref_op: Dereferencing null pointer channel.
>
> CID 1040158 (#2 of 2): Dereference after null check (FORWARD_NULL)24.
> var_deref_op: Dereferencing null pointer channel.
>
> Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers at efficios.com>
> ---
> src/common/kernel-consumer/kernel-consumer.c | 24 ++++++++++++------------
> 1 file changed, 12 insertions(+), 12 deletions(-)
>
> diff --git a/src/common/kernel-consumer/kernel-consumer.c b/src/common/kernel-consumer/kernel-consumer.c
> index 9e35404..3216903 100644
> --- a/src/common/kernel-consumer/kernel-consumer.c
> +++ b/src/common/kernel-consumer/kernel-consumer.c
> @@ -969,18 +969,18 @@ int lttng_kconsumer_recv_cmd(struct lttng_consumer_local_data *ctx,
> uint64_t id = msg.u.discarded_events.session_id;
> uint64_t key = msg.u.discarded_events.channel_key;
>
> + DBG("Kernel consumer discarded events command for session id %"
> + PRIu64 ", channel key %" PRIu64, id, key);
> +
> channel = consumer_find_channel(key);
> if (!channel) {
> ERR("Kernel consumer discarded events channel %"
> PRIu64 " not found", key);
> - ret_code = LTTCOMM_CONSUMERD_CHAN_NOT_FOUND;
> + ret = 0;
> + } else {
> + ret = channel->discarded_events;
> }
>
> - DBG("Kernel consumer discarded events command for session id %"
> - PRIu64 ", channel key %" PRIu64, id, key);
> -
> - ret = channel->discarded_events;
> -
> health_code_update();
>
> /* Send back returned value to session daemon */
> @@ -999,18 +999,18 @@ int lttng_kconsumer_recv_cmd(struct lttng_consumer_local_data *ctx,
> uint64_t id = msg.u.lost_packets.session_id;
> uint64_t key = msg.u.lost_packets.channel_key;
>
> + DBG("Kernel consumer lost packets command for session id %"
> + PRIu64 ", channel key %" PRIu64, id, key);
> +
> channel = consumer_find_channel(key);
> if (!channel) {
> ERR("Kernel consumer lost packets channel %"
> PRIu64 " not found", key);
> - ret_code = LTTCOMM_CONSUMERD_CHAN_NOT_FOUND;
> + ret = 0;
> + } else {
> + ret = channel->lost_packets;
> }
>
> - DBG("Kernel consumer lost packets command for session id %"
> - PRIu64 ", channel key %" PRIu64, id, key);
> -
> - ret = channel->lost_packets;
> -
> health_code_update();
>
> /* Send back returned value to session daemon */
> --
> 2.1.4
>
--
Jérémie Galarneau
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list