if (ctx->vertex_elements == NULL || ctx->vertex_elements->num_elements == 0)
return; /* Nothing to do */
- if (!(ctx->prim_hwsupport & (1 << info->mode))) {
- struct primconvert_context *primconvert = ctx->primconvert;
- util_primconvert_save_rasterizer_state(primconvert, ctx->rasterizer);
- util_primconvert_draw_vbo(primconvert, info, drawid_offset, indirect, draws, num_draws);
- return;
- }
-
int prims = u_decomposed_prims_for_vertices(info->mode, draws[0].count);
if (unlikely(prims <= 0)) {
DBG("Invalid draw primitive mode=%i or no primitives to be drawn", info->mode);
case PIPE_CAP_MAX_VARYINGS:
return screen->specs.max_varyings;
+ case PIPE_CAP_SUPPORTED_PRIM_MODES:
+ case PIPE_CAP_SUPPORTED_PRIM_MODES_WITH_RESTART: {
+ /* Generate the bitmask of supported draw primitives. */
+ uint32_t modes = 1 << PIPE_PRIM_POINTS |
+ 1 << PIPE_PRIM_LINES |
+ 1 << PIPE_PRIM_LINE_STRIP |
+ 1 << PIPE_PRIM_TRIANGLES |
+ 1 << PIPE_PRIM_TRIANGLE_FAN;
+
+ /* TODO: The bug relates only to indexed draws, but here we signal
+ * that there is no support for triangle strips at all. This should
+ * be refined.
+ */
+ if (VIV_FEATURE(screen, chipMinorFeatures2, BUG_FIXES8))
+ modes |= 1 << PIPE_PRIM_TRIANGLE_STRIP;
+
+ if (VIV_FEATURE(screen, chipMinorFeatures2, LINE_LOOP))
+ modes |= 1 << PIPE_PRIM_LINE_LOOP;
+
+ return modes;
+ }
+
case PIPE_CAP_PCI_GROUP:
case PIPE_CAP_PCI_BUS:
case PIPE_CAP_PCI_DEVICE: