X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=mediatek.c;h=3d2702fb5c7b7309d530a8cf5e438b4f1e74bf9f;hb=4b5d0bf2ab4da0f475f01575fb369b7eb9415d7c;hp=ce7ff87387f8bcaf7e87fe8b7c922369aafaf798;hpb=f4b7b8da0da92291007d5b14097992f23420b98d;p=android-x86%2Fexternal-minigbm.git diff --git a/mediatek.c b/mediatek.c index ce7ff87..3d2702f 100644 --- a/mediatek.c +++ b/mediatek.c @@ -18,14 +18,27 @@ #include "helpers.h" #include "util.h" -static const uint32_t supported_formats[] = { DRM_FORMAT_ABGR8888, DRM_FORMAT_ARGB8888, - DRM_FORMAT_R8, DRM_FORMAT_RGB565, - DRM_FORMAT_XBGR8888, DRM_FORMAT_XRGB8888, - DRM_FORMAT_YVU420, DRM_FORMAT_YVU420_ANDROID }; +static const uint32_t render_target_formats[] = { DRM_FORMAT_ABGR8888, DRM_FORMAT_ARGB8888, + DRM_FORMAT_RGB565, DRM_FORMAT_XBGR8888, + DRM_FORMAT_XRGB8888 }; + +static const uint32_t texture_source_formats[] = { DRM_FORMAT_R8, DRM_FORMAT_YVU420, + DRM_FORMAT_YVU420_ANDROID }; static int mediatek_init(struct driver *drv) { - return drv_add_linear_combinations(drv, supported_formats, ARRAY_SIZE(supported_formats)); + int ret; + ret = drv_add_combinations(drv, render_target_formats, ARRAY_SIZE(render_target_formats), + &LINEAR_METADATA, BO_USE_RENDER_MASK); + if (ret) + return ret; + + ret = drv_add_combinations(drv, texture_source_formats, ARRAY_SIZE(texture_source_formats), + &LINEAR_METADATA, BO_USE_TEXTURE_MASK); + if (ret) + return ret; + + return drv_modify_linear_combinations(drv); } static int mediatek_bo_create(struct bo *bo, uint32_t width, uint32_t height, uint32_t format, @@ -60,7 +73,7 @@ static int mediatek_bo_create(struct bo *bo, uint32_t width, uint32_t height, ui return 0; } -static void *mediatek_bo_map(struct bo *bo, struct map_info *data, size_t plane) +static void *mediatek_bo_map(struct bo *bo, struct map_info *data, size_t plane, int prot) { int ret; struct drm_mtk_gem_map_off gem_map; @@ -76,18 +89,17 @@ static void *mediatek_bo_map(struct bo *bo, struct map_info *data, size_t plane) data->length = bo->total_size; - return mmap(0, bo->total_size, PROT_READ | PROT_WRITE, MAP_SHARED, bo->drv->fd, - gem_map.offset); + return mmap(0, bo->total_size, prot, MAP_SHARED, bo->drv->fd, gem_map.offset); } -static uint32_t mediatek_resolve_format(uint32_t format) +static uint32_t mediatek_resolve_format(uint32_t format, uint64_t usage) { switch (format) { case DRM_FORMAT_FLEX_IMPLEMENTATION_DEFINED: /*HACK: See b/28671744 */ return DRM_FORMAT_XBGR8888; case DRM_FORMAT_FLEX_YCbCr_420_888: - return DRM_FORMAT_YVU420_ANDROID; + return DRM_FORMAT_YVU420; default: return format; }