On Fri, Jan 22, 2016 at 03:18:15PM +0000, Davies, Devon wrote: > Hi, > > Thanks for the feedback. > > I'll update the commit title. I will also separate this patch into 5 patches. > > For now I want to keep the "ifdef dance" in igt_fbc.c. If we want to split the file up, that should be a new commit/patch. > (I think we should get the fbc tests building on Android first before we start the splitting up igt_fbc.c, since we want to start testing asap.) Nope, no #ifdef madness in library code. If we need that in headers, or for truly exceptional cases in intel_os.c then ok. But in core library code it just makes reading things much, much harder. So either we rewrite igt_fb.c to not need cairo at all, or android just grows itself some cairo. Thanks, Daniel > > I looked to see if I had removed/added any extra lines... some must have missed me, I will revert them. > > The ffs define: I can see that being dangerous. > Should I do > #if defined(__GNUC__) > #define ffs __builtin_ffs > #endif > ? > In my opinion that is cleaner than having a ifdef around the actual ffs function call. It's also easier to add to (in case someone in the future uses a different compiler). > > igt_drm_plane_commit: > I don't know why Android is different, according to git blame, it's been this way since 13th June 2014. > I'll ask why separately to this thread. > As for making a wrapper. I think that should be part of another commit. > (Again to be done after this, since we want to begin testing asap.) > > Thanks, > Devon. > > -----Original Message----- > From: Zanoni, Paulo R > Sent: Wednesday, January 20, 2016 7:35 PM > To: intel-gfx@xxxxxxxxxxxxxxxxxxxxx; Davies, Devon > Cc: Gore, Tim; Vetter, Daniel > Subject: Re: [PATCH i-g-t] tests/kms_fbc_crc.c: No longer dependant on Cairo A setup function that used to use Cairo to draw 2 rectangles covering the whole screen has been changed to use igt_draw > > Hi > > In our IGT/Kernel culture, patch commit titles (here, presented as the email subject) are usually small (under 70-80 chars) providing a quick summary of what the change does. > > Also, we try to make each patch contain a single logical and complete change. So, for example, one approach you could have taken here would > be: > - patch 1: update lib/igt_fb.c so it compiles on Android without cairo > - patch 2: solve the ffs() problem > - patch 3: solve the drmModeSetPlane() problem > - patch 4: change kms_fbc_crc to not need cairo > - patch 5: change the build system so it compiles tests that now work on Android > > Following is another text explaining this pattern: > http://cgit.freedesktop.org/drm-intel/tree/Documentation/SubmittingPatc > hes#n201 > > > Now, regarding the Android vs Cairo macros: I know this has been discussed in the mailing list a few times but I didn't follow it closely, and IGT even has the ANDROID_HAS_CAIRO support, so I'd like Daniel or others to comment on this. Do we want the ifdef dance in igt_fb? Perhaps we could split the libs into igt_fb for the non-cairo parts, and igt_cairo for the cairo parts? The igt_fb library is definitely useful without cairo, so this would make sense to me. But perhaps we want to just keep everything as-is since it's possible to have cairo on Android? > > There are some other comments inline. Please see below. > > > Em Sex, 2016-01-15 às 15:42 +0000, devon.davies@xxxxxxxxx escreveu: > > From: Devon Davies <devon.davies@xxxxxxxxx> > > > > tests/kms_frontbuffer_tracking.c: Now builds with DRM_PRIMARY_DISABLE > > Each call to the function drmModeSetPlane now has an addtional > > NULL in the > > arguments if DRM_PRIMARY_DISABLE is set. > > > > tests/Android.mk: Allow the above tests to be built without Cairo > > Simply removed them from the tests the be skipped. > > > > libs/igt_kms.c: Now builds with DRM_PRIMARY_DISABLE > > I had to define ffs as __builtin_fss due to compiler issues. > > Each call to the function drmModeSetPlane now has an addtional > > NULL in the > > arguments if DRM_PRIMARY_DISABLE is set. > > > > libs/igt_fb.c: Will now build some functions without Cairo > > Functions which aren't used by the framebuffer compression tests > > are > > now behind an #if (!defined(ANDROID)) || (defined(ANDROID) && > > ANDROID_HAS_CAIRO > > > > libs/Android.mk > > igt_fb and igt_kms are no longer ignored if we don't have Cairo. > > > > The tests kms_fbc_crc and kms_frontbuffer_tracking had an unnecessary > > dependance on the Cairo graphics engine. > > Also, drmModeSetPlane may have an additional argument if > > DRM_PRIMARY_DISABLE is set (as it was for me), I have fixed that > > issue. > > > > Signed-off-by: Devon Davies <devon.davies@xxxxxxxxx> > > --- > > lib/Android.mk | 4 -- > > lib/igt_fb.c | 26 ++++++++++++- > > lib/igt_kms.c | 15 ++++++-- > > tests/Android.mk | 5 +++ > > tests/kms_fbc_crc.c | 20 ++++++---- > > tests/kms_frontbuffer_tracking.c | 79 > > +++++++++++++++++++++++++++++++++------- > > 6 files changed, 119 insertions(+), 30 deletions(-) > > > > diff --git a/lib/Android.mk b/lib/Android.mk index badec1e..bbdb051 > > 100644 > > --- a/lib/Android.mk > > +++ b/lib/Android.mk > > @@ -37,10 +37,6 @@ ifeq ("${ANDROID_HAS_CAIRO}", "1") > > LOCAL_C_INCLUDES += $(ANDROID_BUILD_TOP)/external/cairo- > > 1.12.16/src > > LOCAL_CFLAGS += -DANDROID_HAS_CAIRO=1 -DIGT_DATADIR=\".\" > > -DIGT_SRCDIR=\".\" > > else > > -skip_lib_list := \ > > - igt_kms.c \ > > - igt_kms.h \ > > - igt_fb.c > > -DANDROID_HAS_CAIRO=0 > > endif > > > > diff --git a/lib/igt_fb.c b/lib/igt_fb.c index c985824..5acdaa7 100644 > > --- a/lib/igt_fb.c > > +++ b/lib/igt_fb.c > > @@ -33,6 +33,7 @@ > > #include "igt_fb.h" > > #include "ioctl_wrappers.h" > > > > + > > Please don't add random lines to files. > > > > /** > > * SECTION:igt_fb > > * @short_description: Framebuffer handling and drawing library @@ > > -52,11 +53,23 @@ > > */ > > > > /* drm fourcc/cairo format maps */ > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > + > > #define DF(did, cid, _bpp, _depth) \ > > { DRM_FORMAT_##did, CAIRO_FORMAT_##cid, # did, _bpp, _depth } > > + > > +#else > > + > > +#define DF(did, cid, _bpp, _depth) \ > > + { DRM_FORMAT_##did, # did, _bpp, _depth } > > + > > +#endif > > + > > static struct format_desc_struct { > > uint32_t drm_id; > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > cairo_format_t cairo_id; > > +#endif > > const char *name; > > int bpp; > > int depth; > > @@ -72,7 +85,6 @@ static struct format_desc_struct { > > #define for_each_format(f) \ > > for (f = format_desc; f - format_desc < ARRAY_SIZE(format_desc); > > f++) > > > > - > > Please don't remove random lines from files. > > > > /* helpers to create nice-looking framebuffers */ > > static int create_bo_for_fb(int fd, int width, int height, int bpp, > > uint64_t tiling, unsigned bo_size, @@ -125,6 +137,8 @@ static > > int create_bo_for_fb(int fd, int width, int height, int bpp, > > return ret; > > } > > > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > + > > /** > > * igt_paint_color: > > * @cr: cairo drawing context > > @@ -394,6 +408,7 @@ void igt_paint_image(cairo_t *cr, const char > > *filename, > > > > fclose(f); > > } > > +#endif > > > > /** > > * igt_create_fb_with_bo_size: > > @@ -494,6 +509,7 @@ unsigned int igt_create_fb(int fd, int width, int > > height, uint32_t format, > > return igt_create_fb_with_bo_size(fd, width, height, format, tiling, > > fb, > > 0, 0); > > } > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > > > /** > > * igt_create_color_fb: > > @@ -985,6 +1001,7 @@ void igt_write_fb_to_png(int fd, struct igt_fb > > *fb, const char *filename) > > > > igt_assert(status == CAIRO_STATUS_SUCCESS); > > } > > +#endif > > > > /** > > * igt_remove_fb: > > @@ -997,10 +1014,13 @@ void igt_write_fb_to_png(int fd, struct igt_fb > > *fb, const char *filename) > > */ > > void igt_remove_fb(int fd, struct igt_fb *fb) > > { > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > cairo_surface_destroy(fb->cairo_surface); > > +#endif > > do_or_die(drmModeRmFB(fd, fb->fb_id)); > > gem_close(fd, fb->gem_handle); > > } > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > > > /** > > * igt_bpp_depth_to_drm_format: > > @@ -1024,6 +1044,8 @@ uint32_t igt_bpp_depth_to_drm_format(int bpp, > > int depth) > > depth); > > } > > > > +#endif > > + > > /** > > * igt_drm_format_to_bpp: > > * @drm_format: drm fourcc pixel format code @@ -1062,6 +1084,7 @@ > > const char *igt_format_str(uint32_t drm_format) > > > > return "invalid"; > > } > > +#if (!defined(ANDROID)) || (defined(ANDROID) && ANDROID_HAS_CAIRO) > > > > /** > > * igt_get_all_formats: > > @@ -1089,3 +1112,4 @@ void igt_get_all_formats(const uint32_t > > **formats, int *format_count) > > *formats = drm_formats; > > *format_count = ARRAY_SIZE(format_desc); > > } > > +#endif > > diff --git a/lib/igt_kms.c b/lib/igt_kms.c index 497118a..7b682cb > > 100644 > > --- a/lib/igt_kms.c > > +++ b/lib/igt_kms.c > > @@ -49,6 +49,8 @@ > > #include "intel_chipset.h" > > #include "igt_debugfs.h" > > > > +#define ffs __builtin_ffs > > A define like this can be dangerous. Shouldn't we just fix all the callers, so code readers know exactly which function is being run? > > On the other hand, it seems that this change will restrict us to gcc- only. So maybe we could just define ffs as __builtin_ffs if ANDROID is defined? > > > > + > > /* list of connectors that need resetting on exit */ > > #define MAX_CONNECTORS 32 > > static char *forced_connectors[MAX_CONNECTORS + 1]; @@ -1354,8 > > +1356,11 @@ static int igt_drm_plane_commit(igt_plane_t *plane, > > IGT_FIXED(0,0), /* src_x */ > > IGT_FIXED(0,0), /* src_y */ > > IGT_FIXED(0,0), /* src_w */ > > - IGT_FIXED(0,0) /* src_h */); > > - > > + IGT_FIXED(0,0) /* src_h */ > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > If we're going this way, maybe the best approach would be to add a wrapper (igt_kms_set_plane?) and make the current callers use it. > > On a side note: why is Android different here!? > > > Thanks, > Paulo > > > + ); > > CHECK_RETURN(ret, fail_on_error); > > } else if (plane->fb_changed || plane->position_changed || > > plane->size_changed) { > > @@ -1386,7 +1391,11 @@ static int igt_drm_plane_commit(igt_plane_t > > *plane, > > crtc_x, crtc_y, > > crtc_w, crtc_h, > > src_x, src_y, > > - src_w, src_h); > > + src_w, src_h > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > > > CHECK_RETURN(ret, fail_on_error); > > } > > diff --git a/tests/Android.mk b/tests/Android.mk index > > 8457125..eb287a6 100644 > > --- a/tests/Android.mk > > +++ b/tests/Android.mk > > @@ -65,6 +65,11 @@ else > > > > tmp_list := $(foreach test_name, $(TESTS_progs_M),\ > > $(if $(findstring kms_,$(test_name)),$(test_name))) > > + > > +# kms_fbc_crc and kms_frontbuffer_tracking no longer depend on Cairo > > + tmp_list := $(filter-out kms_fbc_crc, $(tmp_list)) > > + tmp_list := $(filter-out kms_frontbuffer_tracking, $(tmp_list)) > > + > > skip_tests_list += $(tmp_list) > > > > IGT_LOCAL_CFLAGS += -DANDROID_HAS_CAIRO=0 diff --git > > a/tests/kms_fbc_crc.c b/tests/kms_fbc_crc.c index 02e95e5..717e891 > > 100644 > > --- a/tests/kms_fbc_crc.c > > +++ b/tests/kms_fbc_crc.c > > @@ -336,14 +336,18 @@ static void create_fbs(data_t *data, bool tiled, > > struct igt_fb *fbs) > > uint64_t tiling = tiled ? LOCAL_I915_FORMAT_MOD_X_TILED : > > LOCAL_DRM_FORMAT_MOD_NONE; > > > > - rc = igt_create_color_fb(data->drm_fd, mode->hdisplay, mode- > > >vdisplay, > > - DRM_FORMAT_XRGB8888, tiling, > > - 0.0, 0.0, 0.0, &fbs[0]); > > - igt_assert(rc); > > - rc = igt_create_color_fb(data->drm_fd, mode->hdisplay, mode- > > >vdisplay, > > - DRM_FORMAT_XRGB8888, tiling, > > - 0.1, 0.1, 0.1, &fbs[1]); > > - igt_assert(rc); > > + unsigned int fb_id; > > + > > + fb_id = igt_create_fb(data->drm_fd, mode->hdisplay, mode- > > >vdisplay, > > + DRM_FORMAT_XRGB8888, tiling, > > &fbs[0]); > > + igt_assert(fb_id); > > + igt_draw_fill_fb(data->drm_fd, &fbs[0], 0); > > + > > + fb_id = igt_create_fb(data->drm_fd, mode->hdisplay, mode- > > >vdisplay, > > + DRM_FORMAT_XRGB8888, tiling, > > &fbs[1]); > > + igt_assert(fb_id); > > + igt_draw_fill_fb(data->drm_fd, &fbs[1], 0x77); > > + > > } > > > > /* Since we want to be really safe that the CRCs are actually what we > > really diff --git a/tests/kms_frontbuffer_tracking.c > > b/tests/kms_frontbuffer_tracking.c > > index e7acc7c..f8b9eca 100644 > > --- a/tests/kms_frontbuffer_tracking.c > > +++ b/tests/kms_frontbuffer_tracking.c > > @@ -1079,7 +1079,11 @@ static void unset_all_crtcs(void) > > > > for (i = 0; i < drm.plane_res->count_planes; i++) { > > rc = drmModeSetPlane(drm.fd, drm.plane_res- > > >planes[i], 0, 0, 0, > > - 0, 0, 0, 0, 0, 0, 0, 0); > > + 0, 0, 0, 0, 0, 0, 0, 0 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > } > > } > > @@ -1715,7 +1719,11 @@ static void set_sprite_for_test(const struct > > test_mode *t, > > params->sprite.fb->fb_id, 0, 0, 0, > > params->sprite.w, params->sprite.h, > > 0, 0, params->sprite.w << 16, > > - params->sprite.h << 16); > > + params->sprite.h << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > > > do_assertions(ASSERT_NO_ACTION_CHANGE); > > @@ -2220,7 +2228,11 @@ static void set_prim_plane_for_params(struct > > modeset_params *params) > > params->mode->hdisplay, > > params->mode->vdisplay, > > params->fb.x << 16, params->fb.y << 16, > > - params->fb.w << 16, params->fb.h << > > 16); > > + params->fb.w << 16, params->fb.h << 16 #if > > +DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert(rc == 0); > > } > > > > @@ -2406,7 +2418,11 @@ static void move_subtest(const struct test_mode > > *t) > > params->sprite.fb- > > >fb_id, 0, > > rect.x, rect.y, rect.w, > > rect.h, 0, 0, rect.w << > > 16, > > - rect.h << 16); > > + rect.h << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > break; > > default: > > @@ -2463,8 +2479,11 @@ static void onoff_subtest(const struct > > test_mode *t) > > break; > > case PLANE_SPR: > > rc = drmModeSetPlane(drm.fd, params- > > >sprite_id, > > - 0, 0, 0, 0, 0, > > 0, 0, 0, 0, > > - 0, 0); > > + 0, 0, 0, 0, 0, > > 0, 0, 0, 0, 0, 0 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > break; > > default: > > @@ -2489,7 +2508,11 @@ static void onoff_subtest(const struct > > test_mode *t) > > params- > > >sprite.h, 0, > > 0, > > params- > > >sprite.w << 16, > > - params- > > >sprite.h << 16); > > + params- > > >sprite.h << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > break; > > default: > > @@ -2561,7 +2584,11 @@ static void fullscreen_plane_subtest(const > > struct test_mode *t) > > fullscreen_fb.fb_id, 0, 0, 0, fullscreen_fb.width, > > fullscreen_fb.height, 0, 0, > > fullscreen_fb.width << 16, > > - fullscreen_fb.height << 16); > > + fullscreen_fb.height << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > update_wanted_crc(t, &pattern->crcs[t->format][0]); > > > > @@ -2581,7 +2608,11 @@ static void fullscreen_plane_subtest(const > > struct test_mode *t) > > do_assertions(assertions); > > > > rc = drmModeSetPlane(drm.fd, params->sprite_id, 0, 0, 0, 0, 0, 0, 0, > > 0, > > - 0, 0, 0); > > + 0, 0, 0 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert_eq(rc, 0); > > > > if (t->screen == SCREEN_PRIM) > > @@ -2657,7 +2688,11 @@ static void scaledprimary_subtest(const struct > > test_mode *t) > > 0, 0, > > params->mode->hdisplay, params->mode- > > >vdisplay, > > params->fb.x << 16, params->fb.y << 16, > > - params->fb.w << 16, params->fb.h << > > 16); > > + params->fb.w << 16, params->fb.h << 16 #if > > +DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert(rc == 0); > > do_assertions(DONT_ASSERT_CRC); > > > > @@ -2668,7 +2703,11 @@ static void scaledprimary_subtest(const struct > > test_mode *t) > > params->mode->hdisplay, params->mode- > > >vdisplay, > > params->fb.x << 16, params->fb.y << 16, > > (params->fb.w / 2) << 16, > > - (params->fb.h / 2) << 16); > > + (params->fb.h / 2) << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert(rc == 0); > > do_assertions(DONT_ASSERT_CRC); > > > > @@ -2681,7 +2720,11 @@ static void scaledprimary_subtest(const struct > > test_mode *t) > > params->mode->vdisplay / 2, > > params->fb.x << 16, params->fb.y << 16, > > (params->fb.w / 2) << 16, > > - (params->fb.h / 2) << 16); > > + (params->fb.h / 2) << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert(rc == 0); > > do_assertions(DONT_ASSERT_CRC); > > > > @@ -2695,7 +2738,11 @@ static void scaledprimary_subtest(const struct > > test_mode *t) > > (params->fb.x + params->fb.w / 2) << 16, > > (params->fb.y + params->fb.h / 2) << 16, > > (params->fb.w / 4) << 16, > > - (params->fb.h / 4) << 16); > > + (params->fb.h / 4) << 16 > > +#if DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert(rc == 0); > > do_assertions(DONT_ASSERT_CRC); > > > > @@ -2705,7 +2752,11 @@ static void scaledprimary_subtest(const struct > > test_mode *t) > > 0, 0, > > params->mode->hdisplay, params->mode- > > >vdisplay, > > params->fb.x << 16, params->fb.y << 16, > > - params->fb.w << 16, params->fb.h << > > 16); > > + params->fb.w << 16, params->fb.h << 16 #if > > +DRM_PRIMARY_DISABLE > > + , NULL > > +#endif > > + ); > > igt_assert(rc == 0); > > do_assertions(0); > > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@xxxxxxxxxxxxxxxxxxxxx > http://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx