<html><head></head><body>Hi,<br><br>The respective structure layouts will in practice match in any real-life ABI, so accessing the scalar members will work.<br><br>Whether it works for the pointer values though... In my understanding, that is an open area of academic research on programming language. In other words, people do not know and we cannot rely on compilers to get this right until (maybe) a future version of ISO C clarifies it.<br><br>If you are bored, search for articles on C pointer provenance.<br><br><div class="gmail_quote">Le 26 avril 2019 10:47:37 GMT+03:00, Thomas Guillem <thomas@gllm.fr> a écrit :<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
<pre class="k9mail">Question following my remark on the "[PATCH 00/17] RFC Split block_t into 2 different data containers" thread:<br><br> "- Code duplication between data.c and frame.c and also between data_helper.h and frame_helper.h: This code is far from trivial and should not be duplicated. We don't want to fix 2 files each time we need to fix a bug. The only way I see to solve this issue is to include vlc_data_t from vlc_frame_t and have generic vlc_data_t functions working with vlc_frame_t."<br><br>I wonder if it is possible to include vlc_data_t from vlc_frame_t without renaming all variables (in order to avoid a s/frame->p_buffer/frame->data.p_buffer/ change). Actually, it is possible in C by using anonymous unions and structs but is it allowed ?<br><br>cf. <a href="https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#Type-punning">https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#Type-punning</a><br><br>PS:  ISO C++ prohibits anonymous structs so we will have to rename all C++ code that touch vlc_frame_t<br><br>Here is a sample to show what I would to do in VLC:<br><br>#include <stdlib.h><br>#include <stdio.h><br>#include <assert.h><br>#include <stdint.h><br>#include <inttypes.h><br><br>#define DATA_MEMBERS \<br>    uint8_t *buf; \<br>    size_t size; \<br>    size_t maxsize; \<br>    void *start; \<br><br>struct data {<br>    DATA_MEMBERS<br>    struct data *next;<br>};<br><br>struct frame<br>{<br>    union<br>    {<br>        struct data d;<br>#ifndef __cplusplus<br>        /* ISO C++ prohibits anonymous structs*/<br>        struct {<br>            DATA_MEMBERS<br>            struct frame *next;<br>        };<br>#endif<br>    };<br><br>    int64_t pts;<br>    int64_t dts;<br>};<br><br><br>static void data_do_something(struct data *data)<br>{<br>    data->buf += 10;<br>    data->size -= 10;<br>}<br><br>static inline void frame_do_something(struct frame *frame)<br>{<br>    data_do_something(&frame->d);<br>}<br><br>static void frame_do_specific_thing(struct frame *frame)<br>{<br>    frame->buf -= 10;<br>    frame->size += 10;<br>}<br><br>static void frame_print(struct frame *frame)<br>{<br>    fprintf(stderr, "frame: data: %p %zu/%zu vs "<br>            "%p %zu/%zu, pts: %" PRId64 "\n",<br>            frame->d.buf, frame->d.size, frame->d.maxsize,<br>            frame->buf, frame->size, frame->maxsize, frame->pts);<br>}<br><br><br>int main(void)<br>{<br>    struct frame frame;<br>    frame.d.size = frame.d.maxsize = 42;<br>    frame.d.start = malloc(frame.d.size);<br>    frame.d.buf = (uint8_t *) frame.d.start;<br>    frame.d.next = NULL;<br>    assert(frame.d.buf);<br>    frame.pts = frame.dts = 72;<br><br>    frame_print(&frame);<br>    frame_do_something(&frame);<br>    frame_print(&frame);<br>    frame_do_specific_thing(&frame);<br>    frame_print(&frame);<br><br>    frame.next = &frame;<br>    frame.d.next = &frame.d;<br><br>    free(frame.d.start);<br>    return 0;<br>}<hr>vlc-devel mailing list<br>To unsubscribe or modify your subscription options:<br><a href="https://mailman.videolan.org/listinfo/vlc-devel">https://mailman.videolan.org/listinfo/vlc-devel</a></pre></blockquote></div><br>-- <br>Envoyé de mon appareil Android avec Courriel K-9 Mail. Veuillez excuser ma brièveté.</body></html>