<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Jul 31, 2018 at 1:17 PM, Chad Versace <span dir="ltr"><<a href="mailto:chadversary@chromium.org" target="_blank">chadversary@chromium.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">In commit cf54bd5e8, dri_sw_winsys.c began using <sys/shm.h> to support<br>
the new functions putImageShm, getImageShm in DRI_SWRastLoader. But<br>
Android began supporting System V shared memory only in Oreo. Nougat has<br>
no shm headers.<br>
<br>
Fix the build by ifdef'ing out the shm code on Nougat. </blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Fixes: cf54bd5e8 "drisw: use shared memory when possible"<br>
Cc: Marc-André Lureau <<a href="mailto:marcandre.lureau@gmail.com">marcandre.lureau@gmail.com</a>><br>
Cc: Dave Airlie <<a href="mailto:airlied@redhat.com">airlied@redhat.com</a>><br>
---<br>
<br>
Dave, is this what you had in mind?<br></blockquote><div><br></div><div>Yeah that seems a lot more acceptable.</div><div><br></div><div>Reviewed-by: Dave Airlie <<a href="mailto:airlied@redhat.com">airlied@redhat.com</a>><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
I considered putting a check in <a href="http://configure.ac" rel="noreferrer" target="_blank">configure.ac</a> for HAVE_SHM, but decided<br>
against it because (1) another Autoconf check would slow down everyone's<br>
build for a niche case that only a few people care about, and (2) it<br>
only affected this file.<br>
<br>
src/gallium/winsys/sw/dri/dri_<wbr>sw_winsys.c | 11 +++++++++++<br>
1 file changed, 11 insertions(+)<br>
<br>
diff --git a/src/gallium/winsys/sw/dri/<wbr>dri_sw_winsys.c b/src/gallium/winsys/sw/dri/<wbr>dri_sw_winsys.c<br>
index 40007200a5d..d519bcfedd3 100644<br>
--- a/src/gallium/winsys/sw/dri/<wbr>dri_sw_winsys.c<br>
+++ b/src/gallium/winsys/sw/dri/<wbr>dri_sw_winsys.c<br>
@@ -26,8 +26,12 @@<br>
*<br>
******************************<wbr>******************************<wbr>**************/<br>
<br>
+#if !defined(ANDROID) || ANDROID_API_LEVEL >= 26<br>
+/* Android's libc began supporting shm in Oreo */<br>
+#define HAVE_SHM<br>
#include <sys/ipc.h><br>
#include <sys/shm.h><br>
+#endif<br>
<br>
#include "pipe/p_compiler.h"<br>
#include "pipe/p_format.h"<br>
@@ -83,6 +87,7 @@ dri_sw_is_displaytarget_<wbr>format_supported( struct sw_winsys *ws,<br>
return TRUE;<br>
}<br>
<br>
+#ifdef HAVE_SHM<br>
static char *<br>
alloc_shm(struct dri_sw_displaytarget *dri_sw_dt, unsigned size)<br>
{<br>
@@ -101,6 +106,7 @@ alloc_shm(struct dri_sw_displaytarget *dri_sw_dt, unsigned size)<br>
<br>
return addr;<br>
}<br>
+#endif<br>
<br>
static struct sw_displaytarget *<br>
dri_sw_displaytarget_create(<wbr>struct sw_winsys *winsys,<br>
@@ -131,8 +137,11 @@ dri_sw_displaytarget_create(<wbr>struct sw_winsys *winsys,<br>
size = dri_sw_dt->stride * nblocksy;<br>
<br>
dri_sw_dt->shmid = -1;<br>
+<br>
+#ifdef HAVE_SHM<br>
if (ws->lf->put_image_shm)<br>
dri_sw_dt->data = alloc_shm(dri_sw_dt, size);<br>
+#endif<br>
<br>
if(!dri_sw_dt->data)<br>
dri_sw_dt->data = align_malloc(size, alignment);<br>
@@ -156,8 +165,10 @@ dri_sw_displaytarget_destroy(<wbr>struct sw_winsys *ws,<br>
struct dri_sw_displaytarget *dri_sw_dt = dri_sw_displaytarget(dt);<br>
<br>
if (dri_sw_dt->shmid >= 0) {<br>
+#ifdef HAVE_SHM<br>
shmdt(dri_sw_dt->data);<br>
shmctl(dri_sw_dt->shmid, IPC_RMID, 0);<br>
+#endif<br>
} else {<br>
align_free(dri_sw_dt->data);<br>
}<br>
<span class="HOEnZb"><font color="#888888">-- <br>
2.18.0.345.g5c9ce644c3-goog<br>
<br>
</font></span></blockquote></div><br></div></div>