On Fri, Feb 24, 2023 at 02:47:39PM +0100, Richard Biener wrote:
> * vec.h (vec<T, A, vl_embed>::m_vecdata): Remove.
> (vec<T, A, vl_embed>::m_vecpfx): Align as T to avoid
> changing alignment of vec<T, A, vl_embed> and simplifying
> address.
> (vec<T, A, vl_embed>::address): Compute as this + 1.
> (vec<T, A, vl_embed>::embedded_size): Use sizeof the
> vector instead of the offset of the m_vecdata member.
> (auto_vec<T, N>::m_data): Turn storage into
> uninitialized unsigned char.
> (auto_vec<T, N>::auto_vec): Allow allocation of one
> stack member. Initialize m_vec in a special way to
> avoid later stringop overflow diagnostics.
> * vec.cc (test_auto_alias): New.
> (vec_cc_tests): Call it.
> @@ -1559,8 +1560,14 @@ class auto_vec : public vec<T, va_heap>
> public:
> auto_vec ()
> {
> - m_auto.embedded_init (MAX (N, 2), 0, 1);
> - this->m_vec = &m_auto;
> + m_auto.embedded_init (N, 0, 1);
> + /* ??? Instead of initializing m_vec from &m_auto directly use an
> + expression that avoids refering to a specific member of 'this'
> + to derail the -Wstringop-overflow diagnostic code, avoiding
> + the impression that data accesses are supposed to be to the
> + m_auto memmber storage. */
s/memmber/member/
> + size_t off = (char *) &m_auto - (char *) this;
> + this->m_vec = (vec<T, va_heap, vl_embed> *) ((char *) this + off);
> }
>
> auto_vec (size_t s CXX_MEM_STAT_INFO)
> @@ -1571,7 +1578,7 @@ public:
> return;
> }
>
> - m_auto.embedded_init (MAX (N, 2), 0, 1);
> + m_auto.embedded_init (N, 0, 1);
> this->m_vec = &m_auto;
Don't we need the above 2 lines here as well (perhaps with a shorter comment
just referencing the earlier comment)?
Otherwise LGTM, thanks.
Jakub