blob: 542cb4e675b8ec28125bb0935422484c5cdab132 [file] [log] [blame]
fei.dengf7a0cd32023-08-29 09:36:37 +00001/*
2 * Copyright (C) 2021 Amlogic Corporation.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#include <errno.h>
17#include <dlfcn.h>
18#include <stdlib.h>
19#include "drm_lib_wrap.h"
20#include "Logger.h"
fei.dengb9a1a572023-09-13 01:33:57 +000021#include "ErrorCode.h"
fei.dengf7a0cd32023-08-29 09:36:37 +000022
23#define TAG "rlib:drm_lib_wrap"
24
25#define DRM_MESON_LIB_NAME "libdrm_meson.so"
26
fei.dengb9a1a572023-09-13 01:33:57 +000027DrmMesonLib * drmMesonLoadLib(int logCategory)
fei.dengf7a0cd32023-08-29 09:36:37 +000028{
fei.dengb9a1a572023-09-13 01:33:57 +000029 INFO(logCategory, "load libdrm meson so symbol");
fei.dengf7a0cd32023-08-29 09:36:37 +000030
31 DrmMesonLib *handle = (DrmMesonLib*)calloc( 1, sizeof(DrmMesonLib));
32 if (!handle) {
fei.dengb9a1a572023-09-13 01:33:57 +000033 ERROR(logCategory, "calloc DrmMesonLib struct fail");
fei.dengf7a0cd32023-08-29 09:36:37 +000034 goto err_labal;
35 }
36
37 handle->libHandle = dlopen(DRM_MESON_LIB_NAME, RTLD_NOW);
38 if (handle->libHandle == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000039 ERROR(logCategory, "unable to dlopen %s : %s",DRM_MESON_LIB_NAME, dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000040 goto err_labal;
41 }
42
43 handle->libDrmDisplayInit = (lib_drm_display_init)dlsym(handle->libHandle, "drm_display_init");
44 if (handle->libDrmDisplayInit == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000045 ERROR(logCategory,"dlsym drm_display_init failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000046 goto err_labal;
47 }
48
49 handle->libDrmDisplayDestroy = (lib_drm_destroy_display)dlsym(handle->libHandle, "drm_destroy_display");
50 if (handle->libDrmDisplayDestroy == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000051 ERROR(logCategory,"dlsym drm_destroy_display failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000052 goto err_labal;
53 }
54
55 handle->libDrmDisplayRegisterDonCb = (lib_drm_display_register_done_cb)dlsym(handle->libHandle, "drm_display_register_done_cb");
56 if (handle->libDrmDisplayRegisterDonCb == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000057 ERROR(logCategory, "dlsym drm_display_register_done_cb failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000058 goto err_labal;
59 }
60
61 handle->libDrmDisplayRegisterResCb = (lib_drm_display_register_res_cb)dlsym(handle->libHandle, "drm_display_register_res_cb");
62 if (handle->libDrmDisplayRegisterResCb == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000063 ERROR(logCategory,"dlsym drm_display_register_res_cb failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000064 goto err_labal;
65 }
66
67 handle->libDrmSetAllocOnlyFlag = (lib_drm_set_alloc_only_flag)dlsym(handle->libHandle, "drm_set_alloc_only_flag");
68 if (handle->libDrmSetAllocOnlyFlag == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000069 ERROR(logCategory,"dlsym drm_set_alloc_only_flag failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000070 goto err_labal;
71 }
72
73 handle->libDrmAllocBufs = (lib_drm_alloc_bufs)dlsym(handle->libHandle, "drm_alloc_bufs");
74 if (handle->libDrmAllocBufs == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000075 ERROR(logCategory,"dlsym drm_alloc_bufs failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000076 goto err_labal;
77 }
78
79 handle->libDrmFreeBufs = (lib_drm_free_bufs)dlsym(handle->libHandle, "drm_free_bufs");
80 if (handle->libDrmFreeBufs == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000081 ERROR(logCategory,"dlsym drm_free_bufs failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000082 goto err_labal;
83 }
84
85 handle->libDrmAllocBuf = (lib_drm_alloc_buf)dlsym(handle->libHandle, "drm_alloc_buf");
86 if (handle->libDrmAllocBuf == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000087 ERROR(logCategory,"dlsym drm_alloc_buf failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000088 goto err_labal;
89 }
90
91 handle->libDrmImportBuf = (lib_drm_import_buf)dlsym(handle->libHandle, "drm_import_buf");
92 if (handle->libDrmImportBuf == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000093 ERROR(logCategory,"dlsym drm_import_buf failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +000094 goto err_labal;
95 }
96
97 handle->libDrmFreeBuf = (lib_drm_free_buf)dlsym(handle->libHandle, "drm_free_buf");
98 if (handle->libDrmFreeBuf == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +000099 ERROR(logCategory,"dlsym drm_free_buf failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +0000100 goto err_labal;
101 }
102
103 handle->libDrmPostBuf = (lib_drm_post_buf)dlsym(handle->libHandle, "drm_post_buf");
104 if (handle->libDrmPostBuf == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +0000105 ERROR(logCategory,"dlsym drm_post_buf failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +0000106 goto err_labal;
107 }
108
109 handle->libDrmModeAsyncAtomicCommit = (lib_drmModeAsyncAtomicCommit)dlsym(handle->libHandle, "drmModeAsyncAtomicCommit");
110 if (handle->libDrmModeAsyncAtomicCommit == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +0000111 ERROR(logCategory,"dlsym drmModeAsyncAtomicCommit failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +0000112 goto err_labal;
113 }
114
115 handle->libDrmWaitVideoFence = (lib_drm_waitvideoFence)dlsym(handle->libHandle, "drm_waitvideoFence");
116 if (handle->libDrmWaitVideoFence == NULL) {
fei.dengb9a1a572023-09-13 01:33:57 +0000117 ERROR(logCategory,"dlsym drm_waitvideoFence failed, err=%s \n", dlerror());
fei.dengf7a0cd32023-08-29 09:36:37 +0000118 goto err_labal;
119 }
120
121 return handle;
122err_labal:
123 if (handle) {
124 if (handle->libHandle) {
125 dlclose(handle->libHandle);
126 }
127 free(handle);
128 }
129 return NULL;
130}
131
fei.dengb9a1a572023-09-13 01:33:57 +0000132int drmMesonUnloadLib(int logCategory,DrmMesonLib *drmMesonLib)
fei.dengf7a0cd32023-08-29 09:36:37 +0000133{
134 if (drmMesonLib) {
135 if (drmMesonLib->libHandle) {
fei.dengb9a1a572023-09-13 01:33:57 +0000136 INFO(logCategory, "dlclose libdrm meson so symbol");
fei.dengf7a0cd32023-08-29 09:36:37 +0000137 dlclose(drmMesonLib->libHandle);
138 }
139 free(drmMesonLib);
140 }
fei.dengb9a1a572023-09-13 01:33:57 +0000141 return NO_ERROR;
fei.dengf7a0cd32023-08-29 09:36:37 +0000142}