X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=drv.h;h=d27e84590981c6cf1bf66103ed42dc0ed801511f;hb=1c4a1cf7e48264011549b6da1b1588a8ff076a11;hp=f478a665940d41e61f13c28a2b78c00f206e7ba9;hpb=29d742e7d64baa2b50cf262dbad2db752c883238;p=android-x86%2Fexternal-minigbm.git diff --git a/drv.h b/drv.h index f478a66..d27e845 100644 --- a/drv.h +++ b/drv.h @@ -33,11 +33,18 @@ extern "C" { #define BO_USE_EXTERNAL_DISP (1ull << 10) #define BO_USE_PROTECTED (1ull << 11) #define BO_USE_HW_VIDEO_ENCODER (1ull << 12) -#define BO_USE_HW_CAMERA_WRITE (1ull << 13) -#define BO_USE_HW_CAMERA_READ (1ull << 14) -#define BO_USE_HW_CAMERA_ZSL (1ull << 15) +#define BO_USE_CAMERA_WRITE (1ull << 13) +#define BO_USE_CAMERA_READ (1ull << 14) #define BO_USE_RENDERSCRIPT (1ull << 16) #define BO_USE_TEXTURE (1ull << 17) +#define BO_USE_HW_VIDEO_DECODER (1ull << 18) + + +/* Map flags */ +#define BO_MAP_NONE 0 +#define BO_MAP_READ (1 << 0) +#define BO_MAP_WRITE (1 << 1) +#define BO_MAP_READ_WRITE (BO_MAP_READ | BO_MAP_WRITE) /* This is our extension to . We need to make sure we don't step * on the namespace of already defined formats, which can be done by using invalid @@ -66,21 +73,36 @@ struct drv_import_fd_data { int fds[DRV_MAX_PLANES]; uint32_t strides[DRV_MAX_PLANES]; uint32_t offsets[DRV_MAX_PLANES]; - uint32_t sizes[DRV_MAX_PLANES]; uint64_t format_modifiers[DRV_MAX_PLANES]; uint32_t width; uint32_t height; uint32_t format; + uint64_t use_flags; }; -struct map_info { +struct vma { void *addr; size_t length; uint32_t handle; + uint32_t map_flags; int32_t refcount; + uint32_t map_strides[DRV_MAX_PLANES]; void *priv; }; +struct rectangle { + uint32_t x; + uint32_t y; + uint32_t width; + uint32_t height; +}; + +struct mapping { + struct vma *vma; + struct rectangle rect; + uint32_t refcount; +}; + struct driver *drv_create(int fd); void drv_destroy(struct driver *drv); @@ -89,12 +111,13 @@ int drv_get_fd(struct driver *drv); const char *drv_get_name(struct driver *drv); -struct combination *drv_get_combination(struct driver *drv, uint32_t format, uint64_t usage); +struct combination *drv_get_combination(struct driver *drv, uint32_t format, uint64_t use_flags); -struct bo *drv_bo_new(struct driver *drv, uint32_t width, uint32_t height, uint32_t format); +struct bo *drv_bo_new(struct driver *drv, uint32_t width, uint32_t height, uint32_t format, + uint64_t use_flags); struct bo *drv_bo_create(struct driver *drv, uint32_t width, uint32_t height, uint32_t format, - uint64_t flags); + uint64_t use_flags); struct bo *drv_bo_create_with_modifiers(struct driver *drv, uint32_t width, uint32_t height, uint32_t format, const uint64_t *modifiers, uint32_t count); @@ -103,10 +126,14 @@ void drv_bo_destroy(struct bo *bo); struct bo *drv_bo_import(struct driver *drv, struct drv_import_fd_data *data); -void *drv_bo_map(struct bo *bo, uint32_t x, uint32_t y, uint32_t width, uint32_t height, - uint32_t flags, struct map_info **map_data, size_t plane); +void *drv_bo_map(struct bo *bo, const struct rectangle *rect, uint32_t map_flags, + struct mapping **map_data, size_t plane); + +int drv_bo_unmap(struct bo *bo, struct mapping *mapping); -int drv_bo_unmap(struct bo *bo, struct map_info *map_data); +int drv_bo_invalidate(struct bo *bo, struct mapping *mapping); + +int drv_bo_flush_or_unmap(struct bo *bo, struct mapping *mapping); uint32_t drv_bo_get_width(struct bo *bo); @@ -130,16 +157,24 @@ uint64_t drv_bo_get_plane_format_modifier(struct bo *bo, size_t plane); uint32_t drv_bo_get_format(struct bo *bo); -uint32_t drv_bo_get_stride_in_pixels(struct bo *bo); +uint32_t drv_bytes_per_pixel_from_format(uint32_t format, size_t plane); -uint32_t drv_resolve_format(struct driver *drv, uint32_t format); +uint32_t drv_stride_from_format(uint32_t format, uint32_t width, size_t plane); -size_t drv_num_planes_from_format(uint32_t format); +uint32_t drv_resolve_format(struct driver *drv, uint32_t format, uint64_t use_flags); -uint32_t drv_size_from_format(uint32_t format, uint32_t stride, uint32_t height, size_t plane); +size_t drv_num_planes_from_format(uint32_t format); uint32_t drv_num_buffers_per_bo(struct bo *bo); +#define drv_log(format, ...) \ + do { \ + drv_log_prefix("minigbm", __FILE__, __LINE__, format, ##__VA_ARGS__); \ + } while (0) + +__attribute__((format(printf, 4, 5))) void drv_log_prefix(const char *prefix, const char *file, + int line, const char *format, ...); + #ifdef __cplusplus } #endif