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

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

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

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

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

<pre>
    - [ ] Implement `ddx_fine` clang builtin,
- [ ] Link `ddx_fine` clang builtin with `hlsl_intrinsics.h`
- [ ] Add sema checks for `ddx_fine` to `CheckHLSLBuiltinFunctionCall` in `SemaChecking.cpp`
- [ ] Add codegen for `ddx_fine` to `EmitHLSLBuiltinExpr` in `CGBuiltin.cpp`
- [ ] Add codegen tests to `clang/test/CodeGenHLSL/builtins/ddx_fine.hlsl`
- [ ] Add sema tests to `clang/test/SemaHLSL/BuiltIns/ddx_fine-errors.hlsl`
- [ ] Create the `int_dx_ddx_fine` intrinsic in `IntrinsicsDirectX.td`
- [ ] Create the `DXILOpMapping` of `int_dx_ddx_fine` to  `85` in `DXIL.td`
- [ ] Create the  `ddx_fine.ll` and `ddx_fine_errors.ll` tests in `llvm/test/CodeGen/DirectX/`
- [ ] Create the `int_spv_ddx_fine` intrinsic in `IntrinsicsSPIRV.td`
- [ ] In SPIRVInstructionSelector.cpp create the `ddx_fine` lowering and map  it to `int_spv_ddx_fine` in `SPIRVInstructionSelector::selectIntrinsic`.
- [ ] Create SPIR-V backend test case in `llvm/test/CodeGen/SPIRV/hlsl-intrinsics/ddx_fine.ll`

## DirectX

| DXIL Opcode | DXIL OpName | Shader Model | Shader Stages |
| ----------- | ----------- | ------------ | ------------- |
| 85 | DerivFineX | 6.0 | ('library', 'pixel', 'compute', 'amplification', 'mesh', 'node') |

## SPIR-V

# [OpDPdxFine](https://registry.khronos.org/SPIR-V/specs/unified1/SPIRV.html#OpDPdxFine):

## Description:
  
Result is the partial derivative of *P* with respect to the window *x*
coordinate.Uses local differencing based on the value of *P* for the
current fragment and its immediate neighbor(s).  
  
*Result Type* must be a scalar or vector of [*floating-point
type*](https://registry.khronos.org/SPIR-V/specs/unified1/SPIRV.html#Floating) using the IEEE 754 encoding. The component width must
be 32 bits.  
  
The type of *P* must be the same as *Result Type*. *P* is the value to
take the derivative of.  
  
This instruction is only valid in the **Fragment** [Execution
Model](https://registry.khronos.org/SPIR-V/specs/unified1/SPIRV.html#Execution_Model).

[Capability](https://registry.khronos.org/SPIR-V/specs/unified1/SPIRV.html#Capability):  
**DerivativeControl**

<table>
<colgroup>
<col style="width: 20%" />
<col style="width: 20%" />
<col style="width: 20%" />
<col style="width: 20%" />
<col style="width: 20%" />
</colgroup>
<thead>
<tr>
<th>Word Count</th>
<th>Opcode</th>
<th>Results</th>
<th>Operands</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td class="tableblock halign-left valign-top"><p>4</p></td>
<td class="tableblock halign-left valign-top"><p>210</p></td>
<td
class="tableblock halign-left valign-top"><p><em>&lt;id&gt;</em><br />
<em>Result Type</em></p></td>
<td class="tableblock halign-left valign-top"><p><a
href="#ResultId"><em>Result &lt;id&gt;</em></a></p></td>
<td
class="tableblock halign-left valign-top"><p><em>&lt;id&gt;</em><br />
<em>P</em></p></td>
</tr>
</tbody>
</table>



## Test Case(s)

 
 ### Example 1
```hlsl
//dxc ddx_fine_test.hlsl -T lib_6_8 -enable-16bit-types -O0

export float4 fn(float4 p1) {
    return ddx_fine(p1);
}
```
## HLSL:

Computes a high precision partial derivative with respect to the screen-space x-coordinate.

## Syntax

``` syntax
float ddx_fine(
  in float value
);
```

## Parameters

<dl> <dt>

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

Type: **float**

The input value.

</dd> </dl>

## Return value

Type: **float**

The high precision partial derivative of *value*.

## Remarks

The following overloaded versions are also available:

``` syntax
float2 ddx_fine(float2 value);
float3 ddx_fine(float3 value);
float4 ddx_fine(float4 value);
```

### 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/eJzUWVtz4yry_zTkhZJLRvHtwQ-OHZ-Tqpn_pE7mPztvKSTaFhsEKkCJs59-q0GWpbGTzO6e2YsrFYum-fWVppG5c3KvAZZkckMmmyve-NLY5Y7bvxmtrnIjXpcJJZMbSiYbelfVCirQnpJpKsThcSc1kGlKC8X1nuaNVF5qwtYkXZ1WfZL66d0F9EX6EjlK5dSj1N5K7WThRiWZpgOolRDUQcVpUULx5OjO2B-RvUHKGud___Tw6SaK2Da68NLoNVcKuaRGrgeoeOCUej8q6vqSuMII2IN-W9RtJX1P0u2hticJ699a8kfwHpx3LWJwDmFbpBG2XRsBv4FGGYRtW585wrZHXUbotzdd9Q4y2t_CBjXvBrAJWGusu4i-tsA9UF8CwkrtH8Xhse-bLoqtI-66qG6khcJ_H3nxPujm-92nL_VnXtdS7xHS7N6Q5Q3Fmfnk5Hdc_L6EfjBHMSm4Fn3qY2t_nIxujOhKPVdn8SFs25pG2PZjf7n6-Scd9nB_98e3C8bcaRqm7rTztgnp_QAKCm8sZhstBjL7spR5ASv1Plhc8ZpS6dsMuaxa2CxvyCLZimQrF0ad0mSaji45AEGSbzTnxRNoEZxKC-7gA8cG2YRtMRWTU4Ho7wHV5ij-sYywjB6jEWmzNcWkoF9q3HK0N_4_XsXxQ8kFWPrZCFB9woPne3BIaYGS04d-MD4nJD2g-SQqAlY-b6WG72E4HaXhm7A5YTMlc8vtK2EzwpA2q-UB1GlYmKpuPJwIvKqV3MmCY5RO5ApceRppI-KSxVGdzm8xRh0JQ_il3tyLA2pIJhvC5qX3tcPAsy1hWwt76bx9HT2V1mjjRsbu26AlGDVXQ4hVo-VOghgfAzoqfaUIy3robIGogyiCK6ysgy1hilKSrv4A1yhPpQvpXXPrJVdUoB-5l88QigVb3RO2iqeLBdQiZDmueJFamBdkORCGqIUxVkjNPYz-34GjyhQIKHc7sKAL3Cw5dyCo0QHgmatmIAXPB18CQjXW4hm5s3wfDkvcZRKLR1WBkLgNNMh9mRtL2NwRthgFm8I_wo62fX2tAYGrxnmaA-XUFVxxS42lz2HnBfGTG8JWO2W4l3qf1EZqT9KVj4t_RbS2rSxMncahY9Afd7e3t3Q2uaagCyPwPKVfS6CYnEajE16k8GUwhqSrHGjGaC6965mO_Kh336tH41GEw33KHT1z0ahjb_MhBscbdAR_iqsHuTGQKrGsd2UNMYxWrwgiBdalUEAZRmbbRjSO0Pe3ByiakJvpKtSNX-HxTshjFMEWo3aLTG7WvOa5VNK__grJPfSwM48pSthq0_lzbbS3RkVyq1i29jxXQLLbOCqM2lvT1H0Cdf4VWTaEsZAdKIClhE0IYxQN-F9mJmx7ZrQvgYvTyPYmSHb7F2MFXZtG-7g8EHvz8eS6PBc3hHtrIViuxRuzZ1Qc2cFoqDZeCi4aIbCtdy56J8Q_V6Z4oiVXcq8TBTsfdtVeJ97UhLEoHf1zHSXVJ33En4LLxum7yFiu_1lskq2hwm82VZ5kN1IQNt3jUxQUJ7N1bgeJEcj9AjZg_hVOINmak3RVWtjF5YRlUYE70TH21frIIsK2_CN1_1Oevf85f54n-SCtkdArYOmwJ_mKbeuaO2jP7zgZjpTIgUy3B2zEgI5xdprGv3CXStvqLA4F7S4b2POGqxZNvlIl88fp45wmoFGLZDzNpU_wcHQ0-dK2uXCojfU0nP3XdKcJm7fP9Tj2dTfhkKPUgm-s7mQRNg8c6E_sQzd9DU9WhpvhsRtbxy7TUU5LuS9pbaGQDs_LC83XpY7LFRZAJ67mBdBD0uu3hs3nq_b80JKOOlF3pAYD-4YEC6Uma0ZWaZwNp39APFrYt62TdM8tr8CDdd2ZJRTJbik--FPg2SoChgN_TSY3UofvTZcpgTssE92yuLNXbeMQFOsfkNjrSF03rbajToVwpWnh8Fn1FAlq_xFj2Rn5U6I-DlnsuY6Wjn4QWXH75E5wO6OUecHWzzyDVYYLEPQZLII7yi1Qrpyh_JlLFXfR6v2Isn5IW0qrSxvDQMzO2LJLbNdnbNc_sF3MCDT1s9SyaqrBVfBot3R0175GwibRNTXuP-h6xJNXXFxd4Wo3GhSQH6-Z_-In4HWKdBfL5M_8DPFOl1cyuRmYMrnUge6lL5t8VBi813-WhTXO7PzGhLbzReqMEbbNlckx2SNVgHvypk6cLdo6GS7ymQjFk21FJsbjZG95XcrCJRbiFQ0SV01GlcDShzcuzHmww1gEf72CO3lvEJxQRP7xcMe6bHatLHdK9y7m38B6OATxvzcqvl3YmIpLHR5_A1OBt69hcI_3-_DUFt3zuHaPl2jDQZ98il0vfYYPg8c4OJyR3_HbsYxDrAHvl9bJTffCiB7f0Lp_VxYdTik0fK2UHMPuYjZdqPMDG_5LN8G52sfz5EosM7HIFvwKluMZG48ni1maXZXL2XzBxWwMfMem80yI3RwWYsx3s-n19WxejK_kkqXsOp2Np-PFZJJmo0JMrsWMs_l8N2V5zsh1ChWXaqTUc4W3zSvpXAPLxSJdzK8Uz0G58FsDYxV4njf70I6uCWPtO0GSrbrXqO1MfEV9xna8xR4njCfZ6sg72VzZJSqR5M3eketUSefdSS0vvYLl6QeNC29JEapLy6vGquU7UW3fXAaJtTV_hcITtg3GYzij_c9L9vcAAAD__xHjg-c">