[Mesa-dev] [Intel-gfx] [PATCH] i965: Revert absolute mode for constant buffer pointers.

Jason Ekstrand jason at jlekstrand.net
Wed Oct 25 17:53:08 UTC 2017


On Wed, Oct 25, 2017 at 10:31 AM, Kenneth Graunke <kenneth at whitecape.org>
wrote:

> On Wednesday, October 25, 2017 7:33:41 AM PDT Jason Ekstrand wrote:
> > On October 25, 2017 06:05:16 Joonas Lahtinen wrote:
> [snip]
> > > There indeed seems to be quite a lot of missing registers from the i915
> > > driver where the context is initialized. (Psst. You can read that as:
> > > "all the 33 non-privileged registers we could quickly list, are
> > > missing").
> >
> > We probably don't need *all* of them initialized.  For instance, the
> > initial values of the ALU registers or the indirect draw parameter
> > registers will probably never matter.  However, if you want to just
> > initialized them all, that's fine.
>
> I agree - I think we can cut down the list substantially, if you like.
> Here's my breakdown of Skylake's non-privileged register list:
>
> Cache_Mode_0               0x7000
> Cache_Mode_1               0x7004
> GT_MODE                    0x7008
> L3_Config                  0x7034
> TD_CTL                     0xE400
> TD_CTL2                    0xE404
> L3SQCREG4                  0xB118
> NOPID                      0x2094
> INSTPM                     0x20C0
>
>    Should be initialized by the kernel.  Several of these can severely
>    break unsuspecting userspace, and we'd like to be able to rely on a
>    default value.
>
> IA_VERTICES_COUNT          0x2310
> IA_PRIMITIVES_COUNT        0x2318
> VS_INVOCATION_COUNT        0x2320
> HS_INVOCATION_COUNT        0x2300
> DS_INVOCATION_COUNT        0x2308
> GS_INVOCATION_COUNT        0x2328
> GS_PRIMITIVES_COUNT        0x2330
> SO_NUM_PRIMS_WRITTEN0      0x5200
> SO_NUM_PRIMS_WRITTEN1      0x5208
> SO_NUM_PRIMS_WRITTEN2      0x5210
> SO_NUM_PRIMS_WRITTEN3      0x5218
> SO_PRIM_STORAGE_NEEDED0    0x5240
> SO_PRIM_STORAGE_NEEDED1    0x5248
> SO_PRIM_STORAGE_NEEDED2    0x5250
> SO_PRIM_STORAGE_NEEDED3    0x5258
> CL_INVOCATION_COUNT        0x2338
> CL_PRIMITIVES_COUNT        0x2340
> PS_INVOCATION_COUNT_0      0x22C8
> PS_DEPTH_COUNT_0           0x22D8
> PS_INVOCATION_COUNT_1      0x22F0
> PS_DEPTH_COUNT_1           0x22F8
> PS_INVOCATION_COUNT_2      0x2448
> PS_DEPTH_COUNT_2           0x2450
> GPGPU_THREADS_DISPATCHED   0x2290
>
>    The kernel can skip these if you like.  Statistics registers just count
>    things, and userspace always calculates (end counter - start counter)
>    deltas, so the initial value doesn't really matter.
>
> SO_WRITE_OFFSET0           0x5280
> SO_WRITE_OFFSET1           0x5284
> SO_WRITE_OFFSET2           0x5288
> SO_WRITE_OFFSET3           0x528C
> GPUGPU_DISPATCHDIMX        0x2500
> GPUGPU_DISPATCHDIMY        0x2504
> GPUGPU_DISPATCHDIMZ        0x2508
> MI_PREDICATE_SRC0          0x2400
> MI_PREDICATE_SRC0          0x2404
> MI_PREDICATE_SRC1          0x2408
> MI_PREDICATE_SRC1          0x240C
> MI_PREDICATE_DATA          0x2410
> MI_PREDICATE_DATA          0x2414
> MI_PREDICATE_RESULT        0x2418
> MI_PREDICATE_RESULT_1      0x241C
> MI_PREDICATE_RESULT_2      0x23BC
> 3DPRIM_END_OFFSET          0x2420
> 3DPRIM_START_VERTEX        0x2430
> 3DPRIM_VERTEX_COUNT        0x2434
> 3DPRIM_INSTANCE_COUNT      0x2438
> 3DPRIM_START_INSTANCE      0x243C
> 3DPRIM_BASE_VERTEX         0x2440
>
>    The kernel can skip these if you like, IMO.  These registers are only
>    used when enabling an optional feature - stream out (SO_WRITE_*),
>    indirect compute dispatch (GPGPU_*), predicated draws (MI_PREDICATE_*),
>    indirect draws (3DPRIM_*).  Userspace has to explicitly opt in to each
>    of these features by enabling a flag, so there isn't a cross-context
>    contamination problem.  If userspace opts in to these features, it can
>    be responsible for programming the registers correctly.
>
> CS_GPR (1-16)              0x2600
>
>    The kernel can skip these if you like.  They're temporary storage when
>    using the MI_MATH instruction.  Example usage: load values into CS_GPR1
>    and CS_GPR2, add them, store the result in CS_GPR3.  Store to memory.
>
>    Nobody should be doing math on register values without setting them.
>    That's clearly a userspace bug.
>
> BB_OFFSET                  0x2158
>

This is used for indirect BATCH_BUFFER_START which is a thing on SKL+ I
believe (I didn't look at the docs).


> OA_CTX_CONTROL             0x2360
> OACTXID                    0x2364
> OA CONTROL                 0x2B00
> PERF_CNT_1_DW0             0x91b8
> PERF_CNT_1_DW1             0x91bc
> PERF_CNT_2_DW0             0x91c0
> PERF_CNT_2_DW1             0x91c4
>
>    I don't know about these.
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20171025/b6bef908/attachment.html>


More information about the mesa-dev mailing list