| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
|
| |
It replaces tu_cs_reserve_space_assert and can be called at any
time to sanity check tu_cs.
|
|
|
|
|
|
| |
Error checking tu_cs_begin/tu_cs_end is too tedious for the callers.
Move tu_cs_add_bo and tu_cs_reserve_entry to tu_cs_reserve_space
such that tu_cs_begin/tu_cs_end never fails.
|
|
|
|
|
| |
We will drop size parameter from tu_cs_begin shortly, such that
tu_cs_begin never fails.
|
|
|
|
|
| |
We will stop calling tu_cs_reserve_entry in tu_cs_end shortly, such
that tu_cs_end never fails.
|
|
|
|
|
| |
Add tu_cs_get_offset, tu_cs_get_size, tu_cs_get_space, and
tu_cs_is_empty.
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
We need the current color/depth/stencil attachments and the current
render area to compute the tiling config.
We compute the tiling config at the beginning of each subpass for
the moment. We should change that when the driver can reorder/merge
subpasses.
It is very common that the render area is the entire framebuffer.
We might want to optimize for the case and compute the tiling config
in tu_framebuffer ctor.
|
|
|
|
| |
Set it to tile alignments, 32x32 on 6xx.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Being the first commit that emits meaningful command packets, there
are many things included in this commit
- tu6_emit_xxx are low-level helpers that emit command packets
without boundary checks
- tu6_xxx are high-level helpers that emit command packets with
boundary checks
- cmdbuf->cs is a pointer to the current CS, so that we can use the
helpers above to emit to other CS
- use cmd as the variable name of tu_cmd_buffer
- there is a per-cmdbuf scratch bo for CP_EVENT_WRITE writeback
- there is a per-cmdbuf debug marker, using scratch reg 7 or 6
depending on whether the cmdbuf is primary or secondary
(olv, after rebase) REG_A6XX_SP_UNKNOWN_AB20 is renamed
|
|
|
|
|
|
|
|
|
|
|
| |
They are used like
tu_cs_reserve_space(...);
tu_cs_emit(...);
...;
tu_cs_reserve_space_assert();
to make sure we reserved enough space at the beginning.
|
|
|
|
|
| |
Reviewed-by: Chia-I Wu <[email protected]>
Reviewed-by: Bas Nieuwenhuizen <[email protected]>
|
| |
|
| |
|
| |
|
| |
|
|
|
|
| |
tu_bo_list_merge adds an entire list to the current list.
|
|
|
|
|
|
|
|
|
| |
Build drm_msm_gem_submit_bo array directly in tu_bo_list. We might
change this again, but this is good enough for now.
There are other issues as well, such as not using
VkAllocationCallbacks and sloppy error checking. We should revisit
this in the near future. Same to tu_cs.
|
| |
|
|
|
|
| |
This allows the fast path (size check) to be inlined.
|
|
|
|
|
| |
This allows us to assert that there is no dangling command in
tu_cs_begin, rather than discarding them silently.
|
|
|
|
| |
Add comments and error checking.
|
|
|
|
| |
Refactor BO allocation code out of tu_cs_begin. Add error checking.
|
| |
|
| |
|
|
|
|
|
| |
The offset we get from MSM_INFO_GET_OFFSET is an offset into the drm fd
for the purpose of mmaping the buffer.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This adds a radv-style check_space functions + emit functions.
Also puts them in a header as a bunch of inlines, so
(1) we can use them from meta code.
(2) they are inline for performance as these are common and small.
Did not put them in tu_private.h as a bunch of inlines only
clutters up that huge headerfile.
Precise error propagation for memory allocation failures is still
todo.
|
|
|
|
|
|
|
| |
This creates a new fd on each queue submit. I do not go with
DRM_IOCTL_MSM_WAIT_FENCE solely because the path is marked legacy.
Otherwise, we can use the fence id rather than requesting a fence
fd until external fences are supported and enabled.
|
| |
|
|
|
|
| |
Add tu_drm_submitqueue_new and tu_drm_submitqueue_close.
|
|
|
|
| |
Add tu_drm_get_gpu_id and tu_drm_get_gmem_size.
|
|
|
|
| |
Remove libfreedreno_drm dep and unused fd_device.
|
|
|
|
|
| |
The recent change to msm_drm.h changed the APIs in an incompatible
way.
|
|
|
|
| |
It really is too long.
|
| |
|
| |
|
| |
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
./deqp-vk -n dEQP-VK.info.*
Writing test log into TestResults.qpa
dEQP Core unknown (0xcafebabe) starting..
target implementation = 'Surfaceless'
WARNING: tu is not a conformant vulkan implementation, testing use only.
WARNING: tu is not a conformant vulkan implementation, testing use only.
Test case 'dEQP-VK.info.build'..
Pass (Not validated)
Test case 'dEQP-VK.info.device'..
Pass (Not validated)
Test case 'dEQP-VK.info.platform'..
Pass (Not validated)
Test case 'dEQP-VK.info.memory_limits'..
Pass (Pass)
DONE!
Test run totals:
Passed: 4/4 (100.0%)
Failed: 0/4 (0.0%)
Not supported: 0/4 (0.0%)
Warnings: 0/4 (0.0%)
|
| |
|
|
|
|
|
| |
Just to get some tests to not skip. This is neither complete
nor completely correct.
|
|
|
|
| |
Add and apply .clang-format.
|
| |
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
| |
Al this figuring out new errors is why I don't like reinventing the
wheel.
|