mirror of
https://github.com/mpv-player/mpv
synced 2025-01-08 16:10:29 +00:00
b091dfda71
This handle type was only needed for backwards compatibility with windows 7. Dropping it allows us to simplify the code: there is no longer a need for runtime checks, as the handle type can now be statically assigned based on the platform. The motivating usecase here, apart from code simplification, is a desired switch to timeline semaphores, which (in the CUDA API) only supports the non-KMT win32 handles. It's worth pointing out that we need no runtime check for IsWindows8OrGreater(), because the `export_caps.sync` check will already fail on versions of windows not supporting PL_HANDLE_WIN32.
60 lines
1.8 KiB
C
60 lines
1.8 KiB
C
/*
|
|
* Copyright (c) 2019 Philip Langdale <philipl@overt.org>
|
|
*
|
|
* This file is part of mpv.
|
|
*
|
|
* mpv is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* mpv is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with mpv. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <ffnvcodec/dynlink_loader.h>
|
|
|
|
#include "video/out/gpu/hwdec.h"
|
|
|
|
struct cuda_hw_priv {
|
|
struct mp_hwdec_ctx hwctx;
|
|
CudaFunctions *cu;
|
|
CUcontext display_ctx;
|
|
CUcontext decode_ctx;
|
|
|
|
// Do we need to do a full CPU sync after copying
|
|
bool do_full_sync;
|
|
|
|
bool (*ext_init)(struct ra_hwdec_mapper *mapper,
|
|
const struct ra_format *format, int n);
|
|
void (*ext_uninit)(const struct ra_hwdec_mapper *mapper, int n);
|
|
|
|
// These are only necessary if the gpu api requires synchronisation
|
|
bool (*ext_wait)(const struct ra_hwdec_mapper *mapper, int n);
|
|
bool (*ext_signal)(const struct ra_hwdec_mapper *mapper, int n);
|
|
};
|
|
|
|
struct cuda_mapper_priv {
|
|
struct mp_image layout;
|
|
CUarray cu_array[4];
|
|
|
|
CUcontext display_ctx;
|
|
|
|
void *ext[4];
|
|
};
|
|
|
|
typedef bool (*cuda_interop_init)(const struct ra_hwdec *hw);
|
|
|
|
bool cuda_gl_init(const struct ra_hwdec *hw);
|
|
|
|
bool cuda_vk_init(const struct ra_hwdec *hw);
|
|
|
|
int check_cu(const struct ra_hwdec *hw, CUresult err, const char *func);
|