<table border="1" cellspacing="0" cellpadding="8">
    <tr>
        <th>Issue</th>
        <td>
            <a href=https://github.com/llvm/llvm-project/issues/99146>99146</a>
        </td>
    </tr>

    <tr>
        <th>Summary</th>
        <td>
            Implement the `ProcessQuadTessFactorsMax` HLSL Function
        </td>
    </tr>

    <tr>
      <th>Labels</th>
      <td>
            metabug,
            backend:DirectX,
            HLSL,
            bot:HLSL
      </td>
    </tr>

    <tr>
      <th>Assignees</th>
      <td>
      </td>
    </tr>

    <tr>
      <th>Reporter</th>
      <td>
          farzonl
      </td>
    </tr>
</table>

<pre>
    - [ ] Implement `ProcessQuadTessFactorsMax` clang builtin,
- [ ] Link `ProcessQuadTessFactorsMax` clang builtin with `hlsl_intrinsics.h`
- [ ] Add sema checks for `ProcessQuadTessFactorsMax` to `CheckHLSLBuiltinFunctionCall` in `SemaChecking.cpp`
- [ ] Add codegen for `ProcessQuadTessFactorsMax` to `EmitHLSLBuiltinExpr` in `CGBuiltin.cpp`
- [ ] Add codegen tests to `clang/test/CodeGenHLSL/builtins/ProcessQuadTessFactorsMax.hlsl`
- [ ] Add sema tests to `clang/test/SemaHLSL/BuiltIns/ProcessQuadTessFactorsMax-errors.hlsl`
- [ ] Create the `int_dx_ProcessQuadTessFactorsMax` intrinsic in `IntrinsicsDirectX.td`
- [ ] Create the `DXILOpMapping` of `int_dx_ProcessQuadTessFactorsMax` to  `106` in `DXIL.td`
- [ ] Create the  `ProcessQuadTessFactorsMax.ll` and `ProcessQuadTessFactorsMax_errors.ll` tests in `llvm/test/CodeGen/DirectX/`

## DirectX

| DXIL Opcode | DXIL OpName | Shader Model | Shader Stages |
| ----------- | ----------- | ------------ | ------------- |
| 106 | StorePatchConstant | 6.0 | ('hull',) |

## SPIR-V

There is no support for `ProcessQuadTessFactorsMax` when targeting SPIR-V.

## Test Case(s)

 
 ### Example 1
```hlsl
//dxc ProcessQuadTessFactorsMax_test.hlsl -T hs_6_8 -enable-16bit-types -O0

struct HSPerPatchData
{
        float edges[ 3 ] : SV_TessFactor;
        float inside : SV_InsideTessFactor;
};
struct PSSceneIn {
        float4 pos : SV_Position;
        float2 tex : TEXCOORD0;
        float3 norm : NORMAL;
};
struct HSPerVertexData {
        PSSceneIn v;
};

export HSPerPatchData fn( const InputPatch< PSSceneIn, 3 > points ) {
        HSPerPatchData d;
        float4 edgeFactor;
        float2 insideFactor;float4 p1;
float p2;
float4 p3;
float2 p4;
float2 p5;
ProcessQuadTessFactorsMax(p1, p2, p3, p4, p5);

        d.edges[0]=edgeFactor.x;
        d.edges[1]=edgeFactor.y;
        d.edges[2]=edgeFactor.z + edgeFactor.w;
        d.inside = insideFactor.x + insideFactor.y;
        return d;
}

[domain("tri")]
[outputtopology("triangle_cw")]
[patchconstantfunc("fn")]
[outputcontrolpoints(3)]
[partitioning("pow2")]
HSPerVertexData main( const uint id : SV_OutputControlPointID,const InputPatch< PSSceneIn, 3 > points ) {

        HSPerVertexData v;
        v.v = points[ id ];
        return v;
}
```
## HLSL:

Generates the corrected tessellation factors for a quad patch.

## Syntax

``` syntax
void ProcessQuadTessFactorsMax(
  in  float4 RawEdgeFactors,
  in  float InsideScale,
  out float4 RoundedEdgeTessFactors,
  out float2 RoundedInsideTessFactors,
  out float2 UnroundedInsideTessFactors
);
```

## Parameters

<dl> <dt>

*RawEdgeFactors* \[in\]
</dt> <dd>

Type: **float4**

The edge tessellation factors, passed into the tessellator stage.

</dd> <dt>

*InsideScale* \[in\]
</dt> <dd>

Type: **float**

The scale factor applied to the UV tessellation factors computed by the tessellation stage. The allowable range for InsideScale is 0.0 to 1.0.

</dd> <dt>

*RoundedEdgeTessFactors* \[out\]
</dt> <dd>

Type: **float4**

The rounded edge-tessellation factors calculated by the tessellator stage.

</dd> <dt>

*RoundedInsideTessFactors* \[out\]
</dt> <dd>

Type: **float2**

The rounded tessellation factors calculated by the tessellator stage for inside edges.

</dd> <dt>

*UnroundedInsideTessFactors* \[out\]
</dt> <dd>

Type: **float2**

The tessellation factors calculated by the tessellator stage for inside edges.

</dd> </dl>

## Return value

This function does not return a value.

## Remarks

Generates the corrected tessellation factors for a quad patch, computing the inside tessellation factors as the maximum of the edge tessellation factors. The inside tess factors will be identical values determined by the maximum of all four edges scaled by InsideScale. The result is then rounded based on the partitioning mode, but the unrounded results are available using the *UnroundedInsideTessFactors* parameter.

### Minimum Shader Model

This function is supported in the following shader models.



| Shader Model                                                                | Supported |
|-----------------------------------------------------------------------------|-----------|
| [Shader Model 5](https://github.com/MicrosoftDocs/win32/blob/docs/desktop-src//direct3dhlsl/d3d11-graphics-reference-sm5.md) and higher shader models | yes       |



 

This function is supported in the following types of shaders:



| Vertex | Hull | Domain | Geometry | Pixel | Compute |
|--------|------|--------|----------|-------|---------|
|        | x    |        |          |       |         |



 

## See also

<dl> <dt>

[Intrinsic Functions](https://github.com/MicrosoftDocs/win32/blob/docs/desktop-src//direct3dhlsl/dx-graphics-hlsl-intrinsic-functions.md)
</dt> <dt>

[Shader Model 5](https://github.com/MicrosoftDocs/win32/blob/docs/desktop-src//direct3dhlsl/d3d11-graphics-reference-sm5.md)
</dt> </dl>
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzMWV9z2joW_zTKiwbGyEDggQcCoc1Mc5MtuZ2-ZYR1AG1lySvJCbmffudItrETQtvb3p1lEmLJR-fP7_x09CfcObnTADMyuiKj5QUv_d7Y2Zbbv4xWFxsjXmY9SkZXlIyW9CYvFOSgPSXj5N6aDJz7V8nFAzi34pk31t3yAxknNFNc7-imlMpLTdiCJPOjmk9Sf_s5DfRZ-j0O2SunHqX2VmonM9ffk3HS0T0XgjrIOc32kH1zdGvsd015gyILHPDx0_rTVbS5KnXmpdELrhRKSY1Sa8h5kJR618-K4pT9zAjYgf4J29e59C3T14fCHk0uPlTd37PnwXlXaQzwEbbCPsJWCyPgA2i0QdiqQtURtnrXuT5C_S66Z0whQpWd4PfNeTs9sNZYd9LcwgL3QP0e0I7U_lEcHs_C2VCjwu6mocpSWsj8174X560sv958uitueVFIvUOVZvujxr2hKDpIxsfkobrzNs9SpB-5x7U4K_ZYgRilY3KifaWe8jc0IGxVwUHYKrqGPywlLKX1m9h3uaAYAr0rkGW01f6D57G93nMBlt4aAardsfZ8Bw57KkW944d-p_22o9dSNEjG0ZA3Fu65z_YLo53nWJguF3TcT8JfwiaEXe5LpQi7xCLEprWSJtr1_c3n3pfY9bAHC1Q6qg11ZVEY639oDj_vcfJxuwMv9a5S2e-YeQDn6YI7IGziCJvGlzT8BgkUuj5wLLB0gG_HSfwJ8wL1rAhbiUNG3ycBJjnMI9p7oHv3OH6c0B5ovlHQG4w30vf8SwGO9u6qjDtvy8zTj-t7sAHGJfc8YHwVBKZbZbinIHbgkLlp4C5J53T95fFonKQdcZxvSJUodhNab4Qvl_GhcuF-vc5Aw42mXdtDWhhXq7o3TmJF7tpj1MMhiDxcf13c3X1eJl2BlGpj8yDxx93n2_mn0y4EFL6A9XBAGI6OHH17ejWSJHM4BJp0IaRbTdiEZkhKeqOL0odXJF0cAyVsgXim17QwUntHIzsrm6_0iW5Ew5CSU-CzCv3mXY3iIMrFDBWs1RrSIm01GS2G3eYoNt-fAmxSDDCcgoXvNHwPw_cIuV5jRZKp6NdkSshoSdLlMZD-oQnlKDV4I_VyQoq9kfqLEnbVQqn_3BrWEHTZQat_CIM6XUdrFnxpdZOJy2UV0-hKmJzjJmdCGPNWEsYw6NEyvjWlL0rvTWGU2b00UlzvFDxmz6-kC0x5VhWzbamzOAD5dEJrZrS3RkUCETZJu6qsD9MF17GgpTDPrK3nNeOrMCrellJ7KkU9-e6CxUW0eI8Wb5aELf4-xxuatzx4auB-6j-FBFWxja6CK6Pl63w8dfJRF81j4Q07kTSam38ADZZ7cGHhzYzFlQ4ELpgOlOKIFt1GYofKz-l_Si5oyEq3oK9ftOeHqqs2S13d-2SkeL9SYzqSOaVSkwUj8yR-V7PxM3--bnjr4t75pCiNpXWdcQW1mCl9V5kptQCBClsunJZmtfTrkv2u_J_avjcCgapnfjsrDYD33PIcPETZZE7ShVBIFXzwJL2upeevAZlTMlqQ0ZXU4e8yDsbV0dfjRTP-4aUAZDBhqCqiEp-bNT-UiZMcCCWMOwcCN5YmsKaRM5Y63OH0G__RBXEyhE6mftX_1-47VFu5THlRKImUjt7--eU0uTOTFyVSf_PSjQqFYlgUdXOlzDNuIKjlegdhUrSCwc1S0g8730E_-REk3iNkDQpS7PdktaJmyG7vNAhcZaXip2D4meS-P2t-OSj2XlB_N56QwGr9C6vnjwR4Zpr_AyH-w6Hhs2pFF4rR52ox4aqE2hPp6La6AqDCAJ4KPK1WHR5F-6-U5Nx-c79hqcG6E2conidQQRXXydE82sj5QeZljudVf66oxYndUtgoepZK0Q1QKUB7mXEVo3RUYJ3OpT6i3zLGlaJbU9oIeqxGQa5VJ6JNC65UHmuGxxNTzeUNxwJrdFDc3rXQ3Ahc2eim9OFlWROxUuUot0D5E5cq1KjS1Xh9l7VFvfx0cohpvJU6hNY-1p7ihHT1ITEsD8Hs1mC9RCdcHI0RqIaJzZG6c2T-xU_Q1zjSHJJ7v_PT1Xc8iJPRVSeUERYANtl7XzjcdYVD6076fbnpZyYnbHUrM2uc2fqlyRxhq2epU0bYaqPMBqdm7BXgvnlT9JzNqoNvuJRIRTgNs5VIxWDQ21le7GXmeha2YEFn0HP5qJ8L3GZyLehe7vZgu7kIeL2AO6LXSU7cZP10uuPB2mwrW67Zch5zHre5wfzHUsWbkmU4OoTHD2By8PYlNO7lobpLWcSF-m1em8dTfd1Gu_uYuxZ9DvVDq4--bbS7z-BW75ABtw_OnN_eja6aKzpa37i6_xWLDkcKYVevuT3s1Wl3kU0nFrVODP-nk-Ct2_XqdyFmqZimU34Bs8ElGwzGyWA8udjPgMF4PNkOh4OUwSZj48kl3_LpaDCdjodbARdyxhI2TC4HY5YkbDjpD7fpeMOmPJ0I2CSbCRkmkHOp-ko95X1jdxfSuRJm0-lgOL5QfAPKhX83MJaD55tyF86kC8LYhmffQAuSzpvryepNvFCuxYwn6bzuGi0v7Axt9TblzpFhoqTz7mjdS69gdvzXRXXPe_ZGD3U3dLworZqdyWZ1xRpcKKz5N2SesFUIGtMY436asf8GAAD__0jCw_8">