• Show log

    Commit

  • Hash : b8d5a423
    Author : Charlie Lao
    Date : 2023-08-21T14:43:42

    Add static_assert(std::is_trivially_copyable<LinkedUniform>(),"")
    
    Since we are using memcpy for LinkedUniform, it is desirable to utilize
    compile time assertion to ensure that in future if anyone modifies POD
    struct (and the class of data members of POD struct) and made it that no
    longer memcopy-able, we would immediately caught at compile time.
    std::is_trivially_copyable<>is exactly for this reason. In order to make
    this work, the POD struct and any data it uses can not have user defined
    copy constructor. The problem is that right now ANGLE is using
    clang_use_chrome_plugins=true, and chrome-style generates warnings if
    the complex struct (has more than 10 data members) does not define a
    copy constructor, and that warning causes build failure with -Werror. So
    clang_use_chrome_plugins=true and std::is_trivially_copyable have this
    conflicting requirements that I can not apply both. This has been raised
    to compiler team, but before we get a solution from them, if we have to
    make a choice, I think the better choice is to disable
    clang_use_chrome_plugins and apply std::is_trivially_copyable, since the
    later is more critical to ensure safety, while chrome-style is mostly
    trying to minimize the code size, but won't affect
    correctness/robustness. This CL sets clang_use_chrome_plugins to false,
    and removes the copy constructor and copy assignment operator from
    BitSetT and LinkedUniform and added static assertion
    is_trivially_copyable for LinkedUniform. Same thing applied to
    ProgramInput as well.
    
    In future once we have a better solution from compile team, we can
    re-enable clang_use_chrome_plugins and disable only for structs that
    requires is_trivially_copyable assertion.
    
    Bug: b/275102061
    Change-Id: If33415ea61deda568d855a7dd6a4fd6042058be5
    Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/4799342
    Reviewed-by: Roman Lavrov <romanl@google.com>
    Reviewed-by: Shahbaz Youssefi <syoussefi@chromium.org>
    Commit-Queue: Charlie Lao <cclao@google.com>
    

  • Properties

  • Git HTTP https://git.kmx.io/kc3-lang/angle.git
    Git SSH git@git.kmx.io:kc3-lang/angle.git
    Public access ? public
    Description

    A conformant OpenGL ES implementation for Windows, Mac, Linux, iOS and Android.

    Homepage

    Github

    Users
    thodg_m kc3_lang_org thodg_w www_kmx_io thodg thodg_l
    Tags