1. 27 Jul, 2017 2 commits
  2. 26 Jul, 2017 3 commits
    • Merge pull request #997 from LoopDawg/clipcull-semantic · f1f5058a
      John Kessenich authored
      HLSL: handle multiple clip/cull semantic IDs
    • HLSL: handle multiple clip/cull semantic IDs · 307b6507
      LoopDawg authored
      HLSL allows several variables to be declared.  There are packing rules involved:
      e.g, a float3 and a float1 can be packed into a single array[4], while for a
      float3 and another float3, the second one will skip the third array entry to
      avoid straddling
      
      This is implements that ability.  Because there can be multiple variables involved,
      and the final output array will often be a different type altogether (to fuse
      the values into a single destination), a new variable is synthesized, unlike the prior
      clip/cull support which used the declared variable.  The new variable name is
      taken from one of the declared ones, so the old tests are unchanged.
      
      Several new tests are added to test various packing scenarios.
      
      Only two semantic IDs are supported: 0, and 1, per HLSL rules.  This is
      encapsulated in
      
           static const int maxClipCullRegs = 2;
      
      and the algorithm (probably :) ) generalizes to larger values, although there
      are a few issues around how HLSL would pack (e.g, would 4 scalars be packed into
      a single HLSL float4 out reg?  Probably, and this algorithm assumes so).
  3. 25 Jul, 2017 2 commits
  4. 23 Jul, 2017 2 commits
  5. 21 Jul, 2017 2 commits
  6. 20 Jul, 2017 1 commit
  7. 18 Jul, 2017 4 commits
  8. 16 Jul, 2017 3 commits
  9. 15 Jul, 2017 1 commit
  10. 14 Jul, 2017 2 commits
  11. 13 Jul, 2017 3 commits
  12. 12 Jul, 2017 1 commit
  13. 11 Jul, 2017 1 commit
    • WIP: HLSL: support global const initializers from non-constant rvalues · 0fca0baf
      LoopDawg authored
      Semantic test left over from other source languages is removed, since this is permitted by HLSL.
      Also, to support the functionality, a targeted test is performed for this case and it is
      turned into a EvqGlobal qualifier to create an AST initialization segment when needed.
      
      Constness is now propagated up aggregate chains during initializer construction.  This
      handles hierarchical cases such as the distinction between:
      
          static const float2 a[2] = { { 1, 2 }, { 3, 4} };
      
      vs
      
          static const float2 a[2] = { { 1, 2 }, { cbuffer_member, 4} };
      
      The first of which can use a first class constant initalization, and the second cannot.
  14. 07 Jul, 2017 1 commit
  15. 06 Jul, 2017 4 commits
  16. 05 Jul, 2017 4 commits
  17. 04 Jul, 2017 4 commits