[lttng-dev] UST check pointer/de-reference order
Mathieu Desnoyers
mathieu.desnoyers at efficios.com
Tue Jun 5 11:19:05 EDT 2012
* Oestman, Fredrik (Fredrik_Oestman at mentor.com) wrote:
> I stumbled across some code where pointers are de-referenced and then checked for NULL.
>
> Cheers,
merged into master and stable-2.0, thanks!
Mathieu
>
> Fredrik Östman
>
>
> diff --git a/liblttng-ust-ctl/ustctl.c b/liblttng-ust-ctl/ustctl.c
> index 9789413..80aed04 100644
> --- a/liblttng-ust-ctl/ustctl.c
> +++ b/liblttng-ust-ctl/ustctl.c
> @@ -732,7 +732,7 @@ void ustctl_unmap_channel(struct lttng_ust_shm_handle *handle)
> struct lttng_ust_lib_ring_buffer *ustctl_open_stream_read(struct lttng_ust_shm_handle *handle,
> int cpu)
> {
> - struct channel *chan = handle->shadow_chan;
> + struct channel *chan;
> int *shm_fd, *wait_fd;
> uint64_t *memory_map_size;
> struct lttng_ust_lib_ring_buffer *buf;
> @@ -741,6 +741,7 @@ struct lttng_ust_lib_ring_buffer *ustctl_open_stream_read(struct lttng_ust_shm_h
> if (!handle)
> return NULL;
>
> + chan = handle->shadow_chan;
> buf = channel_get_ring_buffer(&chan->backend.config,
> chan, cpu, handle, &shm_fd, &wait_fd, &memory_map_size);
> if (!buf)
> @@ -784,11 +785,12 @@ int ustctl_get_mmap_len(struct lttng_ust_shm_handle *handle,
> unsigned long *len)
> {
> unsigned long mmap_buf_len;
> - struct channel *chan = handle->shadow_chan;
> + struct channel *chan;
>
> if (!handle || !buf || !len)
> return -EINVAL;
>
> + chan = handle->shadow_chan;
> if (chan->backend.config.output != RING_BUFFER_MMAP)
> return -EINVAL;
> mmap_buf_len = chan->backend.buf_size;
> @@ -805,11 +807,12 @@ int ustctl_get_max_subbuf_size(struct lttng_ust_shm_handle *handle,
> struct lttng_ust_lib_ring_buffer *buf,
> unsigned long *len)
> {
> - struct channel *chan = handle->shadow_chan;
> + struct channel *chan;
>
> if (!handle || !buf || !len)
> return -EINVAL;
>
> + chan = handle->shadow_chan;
> *len = chan->backend.subbuf_size;
> return 0;
> }
> @@ -823,12 +826,13 @@ int ustctl_get_max_subbuf_size(struct lttng_ust_shm_handle *handle,
> int ustctl_get_mmap_read_offset(struct lttng_ust_shm_handle *handle,
> struct lttng_ust_lib_ring_buffer *buf, unsigned long *off)
> {
> - struct channel *chan = handle->shadow_chan;
> + struct channel *chan;
> unsigned long sb_bindex;
>
> if (!handle || !buf || !off)
> return -EINVAL;
>
> + chan = handle->shadow_chan;
> if (chan->backend.config.output != RING_BUFFER_MMAP)
> return -EINVAL;
> sb_bindex = subbuffer_id_get_index(&chan->backend.config,
> @@ -841,11 +845,12 @@ int ustctl_get_mmap_read_offset(struct lttng_ust_shm_handle *handle,
> int ustctl_get_subbuf_size(struct lttng_ust_shm_handle *handle,
> struct lttng_ust_lib_ring_buffer *buf, unsigned long *len)
> {
> - struct channel *chan = handle->shadow_chan;
> + struct channel *chan;
>
> if (!handle || !buf || !len)
> return -EINVAL;
>
> + chan = handle->shadow_chan;
> *len = lib_ring_buffer_get_read_data_size(&chan->backend.config, buf,
> handle);
> return 0;
> @@ -855,11 +860,12 @@ int ustctl_get_subbuf_size(struct lttng_ust_shm_handle *handle,
> int ustctl_get_padded_subbuf_size(struct lttng_ust_shm_handle *handle,
> struct lttng_ust_lib_ring_buffer *buf, unsigned long *len)
> {
> - struct channel *chan = handle->shadow_chan;
> + struct channel *chan;
>
> if (!handle || !buf || !len)
> return -EINVAL;
>
> + chan = handle->shadow_chan;
> *len = lib_ring_buffer_get_read_data_size(&chan->backend.config, buf,
> handle);
> *len = PAGE_ALIGN(*len);
>
> _______________________________________________
> lttng-dev mailing list
> lttng-dev at lists.lttng.org
> http://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list