X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=src%2Fgallium%2Fdrivers%2Fsvga%2Fsvga_state_rss.c;h=fb56b3d36baf29718170638fbfca91f502a625af;hb=52381a7ffba908410f7a53855f082401fca7293a;hp=51d36b751b82c01622333e990c02e95d1492e657;hpb=ff605091579a0dfbb6a6b3ea0e46d6fed28a278b;p=mesa.git diff --git a/src/gallium/drivers/svga/svga_state_rss.c b/src/gallium/drivers/svga/svga_state_rss.c index 51d36b751b8..fb56b3d36ba 100644 --- a/src/gallium/drivers/svga/svga_state_rss.c +++ b/src/gallium/drivers/svga/svga_state_rss.c @@ -221,11 +221,18 @@ emit_rss(struct svga_context *svga, unsigned dirty) EMIT_RS( svga, curr->scissortestenable, SCISSORTESTENABLE, fail ); EMIT_RS( svga, curr->multisampleantialias, MULTISAMPLEANTIALIAS, fail ); EMIT_RS( svga, curr->lastpixel, LASTPIXEL, fail ); - EMIT_RS( svga, curr->linepattern, LINEPATTERN, fail ); EMIT_RS_FLOAT( svga, curr->pointsize, POINTSIZE, fail ); EMIT_RS_FLOAT( svga, point_size_min, POINTSIZEMIN, fail ); EMIT_RS_FLOAT( svga, screen->maxPointSize, POINTSIZEMAX, fail ); EMIT_RS( svga, curr->pointsprite, POINTSPRITEENABLE, fail); + + /* Emit line state, when the device understands it */ + if (screen->haveLineStipple) + EMIT_RS( svga, curr->linepattern, LINEPATTERN, fail ); + if (screen->haveLineSmooth) + EMIT_RS( svga, curr->antialiasedlineenable, ANTIALIASEDLINEENABLE, fail ); + if (screen->maxLineWidth > 1.0F) + EMIT_RS_FLOAT( svga, curr->linewidth, LINEWIDTH, fail ); } if (dirty & (SVGA_NEW_RAST | SVGA_NEW_FRAME_BUFFER | SVGA_NEW_NEED_PIPELINE))