DRM 的Property IN_FENCE_FD使用示例
时间: 2023-08-06 21:02:03 浏览: 227
drm.zip_DRM_VYHJ_duringgbk_linux drm headers_msm_drm.
Property IN_FENCE_FD 在 DRM 中用于表示输入的同步信号,在使用双缓冲技术时特别有用。它可以用来确保在渲染帧之前,输入数据已经准备就绪。
下面是一个简单的示例代码,展示了如何使用 IN_FENCE_FD 属性:
```c
#include <stdio.h>
#include <fcntl.h>
#include <unistd.h>
#include <drm/drm.h>
#include <drm/drm_mode.h>
int main() {
int fd;
struct drm_mode_create_dumb create_dumb;
struct drm_mode_map_dumb map_dumb;
struct drm_mode_fb_cmd cmd;
struct drm_gem_close gem_close;
struct drm_mode_atomic atomic;
struct drm_event_fence event_fence;
// 打开 DRM 设备
fd = open("/dev/dri/card0", O_RDWR);
// 创建 dumb buffer
create_dumb.width = 800;
create_dumb.height = 600;
create_dumb.bpp = 32;
ioctl(fd, DRM_IOCTL_MODE_CREATE_DUMB, &create_dumb);
// 映射 dumb buffer
map_dumb.handle = create_dumb.handle;
ioctl(fd, DRM_IOCTL_MODE_MAP_DUMB, &map_dumb);
// 配置 framebuffer
cmd.fb_id = 0;
cmd.width = create_dumb.width;
cmd.height = create_dumb.height;
cmd.pitch = create_dumb.pitch;
cmd.bpp = create_dumb.bpp;
cmd.depth = 24;
cmd.handle = create_dumb.handle;
ioctl(fd, DRM_IOCTL_MODE_ADDFB, &cmd);
// 准备同步信号
int fence_fd = fence_create(fd, 0);
// 提交 buffer
atomic.fb_ids_ptr = (uint64_t) &cmd.fb_id;
atomic.crtc_id = 0;
atomic.connector_id = 0;
atomic.count_props = 1;
atomic.user_data = 0;
atomic.flags = DRM_MODE_ATOMIC_NONBLOCK | DRM_MODE_PAGE_FLIP_EVENT | DRM_MODE_ATOMIC_ALLOW_MODESET;
atomic.objs_ptr = (uint64_t) &cmd.fb_id;
atomic.objs = 1;
atomic.fence_fd = fence_fd; // 设置 IN_FENCE_FD
ioctl(fd, DRM_IOCTL_MODE_ATOMIC, &atomic);
// 等待同步信号
read(fence_fd, &event_fence, sizeof(event_fence));
// 关闭 fence 文件描述符
close(fence_fd);
// 关闭 framebuffer
ioctl(fd, DRM_IOCTL_MODE_RMFB, &cmd.fb_id);
// 关闭 dumb buffer
gem_close.handle = create_dumb.handle;
ioctl(fd, DRM_IOCTL_GEM_CLOSE, &gem_close);
// 关闭 DRM 设备
close(fd);
return 0;
}
```
此示例代码演示了如何使用 IN_FENCE_FD 属性来确保在提交 framebuffer 之前,同步信号已经准备就绪。请注意,这只是一个简单的示例,实际使用时可能需要根据具体需求进行修改和扩展。
阅读全文