Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-fonts
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Aleksandr Isakov
wine-fonts
Commits
15f6a28e
Commit
15f6a28e
authored
Jan 09, 2015
by
Michael Müller
Committed by
Vitaly Lipatov
Jul 30, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
nvcuda: Properly wrap undocumented 'ContextStorage' interface and add tests.
parent
6203ba06
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
79 additions
and
26 deletions
+79
-26
internal.c
dlls/nvcuda/internal.c
+77
-26
nvcuda.c
dlls/nvcuda/tests/nvcuda.c
+0
-0
cuda.h
include/cuda.h
+2
-0
No files found.
dlls/nvcuda/internal.c
View file @
15f6a28e
...
...
@@ -87,7 +87,7 @@ static const CUuuid UUID_Unknown2 = {{0xA0, 0x94, 0x79, 0x8C,
0x93
,
0xF2
,
0x08
,
0x00
,
0x20
,
0x0C
,
0x0A
,
0x66
}};
static
const
CUuuid
UUID_Unknown3
=
{{
0x42
,
0xD8
,
0x5A
,
0x81
,
0x23
,
0xF6
,
0xCB
,
0x47
,
0x82
,
0x98
,
0xF6
,
0xE7
,
0x8A
,
0x3A
,
0xEC
,
0xDC
}};
static
const
CUuuid
UUID_
Unknown4
=
{{
0xC6
,
0x93
,
0x33
,
0x6E
,
0x11
,
0x21
,
0xDF
,
0x11
,
static
const
CUuuid
UUID_
ContextStorage
=
{{
0xC6
,
0x93
,
0x33
,
0x6E
,
0x11
,
0x21
,
0xDF
,
0x11
,
0xA8
,
0xC3
,
0x68
,
0xF3
,
0x55
,
0xD8
,
0x95
,
0x93
}};
static
const
CUuuid
UUID_Unknown5
=
{{
0x0C
,
0xA5
,
0x0B
,
0x8C
,
0x10
,
0x04
,
0x92
,
0x9A
,
0x89
,
0xA7
,
0xD0
,
0xDF
,
0x10
,
0xE7
,
0x72
,
0x86
}};
...
...
@@ -163,20 +163,20 @@ static const struct
}
*
Unknown3_orig
=
NULL
;
/*
*
Unknown4
*
ContextStorage
*/
struct
Unknown4
_table
struct
ContextStorage
_table
{
void
*
(
WINAPI
*
func0
)(
void
*
param0
,
void
*
param1
,
void
*
param2
,
void
*
param3
);
void
*
(
WINAPI
*
func1
)(
void
*
param0
,
void
*
param1
);
void
*
(
WINAPI
*
func2
)(
void
*
param0
,
void
*
param1
,
void
*
param2
);
CUresult
(
WINAPI
*
Set
)(
CUcontext
ctx
,
void
*
key
,
void
*
value
,
void
*
callback
);
CUresult
(
WINAPI
*
Remove
)(
CUcontext
ctx
,
void
*
key
);
CUresult
(
WINAPI
*
Get
)(
void
**
value
,
CUcontext
ctx
,
void
*
key
);
};
static
const
struct
{
void
*
(
*
func0
)(
void
*
param0
,
void
*
param1
,
void
*
param2
,
void
*
param3
);
void
*
(
*
func1
)(
void
*
param0
,
void
*
param1
);
void
*
(
*
func2
)(
void
*
param0
,
void
*
param1
,
void
*
param2
);
}
*
Unknown4
_orig
=
NULL
;
CUresult
(
*
Set
)(
CUcontext
ctx
,
void
*
key
,
void
*
value
,
void
*
callback
);
CUresult
(
*
Remove
)(
CUcontext
ctx
,
void
*
key
);
CUresult
(
*
Get
)(
void
**
value
,
CUcontext
ctx
,
void
*
key
);
}
*
ContextStorage
_orig
=
NULL
;
/*
* TlsNotifyInterface
...
...
@@ -309,29 +309,80 @@ static struct Unknown3_table Unknown3_Impl =
Unknown3_func1_relay
,
};
st
atic
void
*
WINAPI
Unknown4_func0_relay
(
void
*
param0
,
void
*
param1
,
void
*
param2
,
void
*
param3
)
st
ruct
context_storage
{
TRACE
(
"(%p, %p, %p, %p)
\n
"
,
param0
,
param1
,
param2
,
param3
);
return
Unknown4_orig
->
func0
(
param0
,
param1
,
param2
,
param3
);
void
*
value
;
void
(
WINAPI
*
callback
)(
CUcontext
ctx
,
void
*
key
,
void
*
value
);
};
static
void
storage_destructor_callback
(
CUcontext
ctx
,
void
*
key
,
void
*
value
)
{
struct
context_storage
*
storage
=
value
;
TRACE
(
"(%p, %p, %p)
\n
"
,
ctx
,
key
,
value
);
if
(
storage
->
callback
)
{
TRACE
(
"calling destructor callback %p(%p, %p, %p)
\n
"
,
storage
->
callback
,
ctx
,
key
,
storage
->
value
);
storage
->
callback
(
ctx
,
key
,
storage
->
value
);
TRACE
(
"destructor callback %p returned
\n
"
,
storage
->
callback
);
}
HeapFree
(
GetProcessHeap
(),
0
,
storage
);
}
static
void
*
WINAPI
Unknown4_func1_relay
(
void
*
param0
,
void
*
param1
)
static
CUresult
WINAPI
ContextStorage_Set
(
CUcontext
ctx
,
void
*
key
,
void
*
value
,
void
*
callback
)
{
TRACE
(
"(%p, %p)
\n
"
,
param0
,
param1
);
return
Unknown4_orig
->
func1
(
param0
,
param1
);
struct
context_storage
*
storage
;
CUresult
ret
;
TRACE
(
"(%p, %p, %p, %p)
\n
"
,
ctx
,
key
,
value
,
callback
);
storage
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
storage
)
);
if
(
!
storage
)
return
CUDA_ERROR_OUT_OF_MEMORY
;
storage
->
callback
=
callback
;
storage
->
value
=
value
;
ret
=
ContextStorage_orig
->
Set
(
ctx
,
key
,
storage
,
storage_destructor_callback
);
if
(
ret
)
HeapFree
(
GetProcessHeap
(),
0
,
storage
);
return
ret
;
}
static
void
*
WINAPI
Unknown4_func2_relay
(
void
*
param0
,
void
*
param1
,
void
*
param2
)
static
CUresult
WINAPI
ContextStorage_Remove
(
CUcontext
ctx
,
void
*
key
)
{
TRACE
(
"(%p, %p, %p)
\n
"
,
param0
,
param1
,
param2
);
return
Unknown4_orig
->
func2
(
param0
,
param1
,
param2
);
struct
context_storage
*
storage
;
TRACE
(
"(%p, %p)
\n
"
,
ctx
,
key
);
/* FIXME: This is not completely race-condition save, but using a mutex
* could have a relatively big overhead. Can still be added later when it
* turns out to be necessary. */
if
(
!
ContextStorage_orig
->
Get
((
void
**
)
&
storage
,
ctx
,
key
))
HeapFree
(
GetProcessHeap
(),
0
,
storage
);
return
ContextStorage_orig
->
Remove
(
ctx
,
key
);
}
static
CUresult
WINAPI
ContextStorage_Get
(
void
**
value
,
CUcontext
ctx
,
void
*
key
)
{
struct
context_storage
*
storage
;
CUresult
ret
;
TRACE
(
"(%p, %p, %p)
\n
"
,
value
,
ctx
,
key
);
ret
=
ContextStorage_orig
->
Get
((
void
**
)
&
storage
,
ctx
,
key
);
if
(
!
ret
)
*
value
=
storage
->
value
;
return
ret
;
}
struct
Unknown4_table
Unknown4
_Impl
=
struct
ContextStorage_table
ContextStorage
_Impl
=
{
Unknown4_func0_relay
,
Unknown4_func1_relay
,
Unknown4_func2_relay
,
ContextStorage_Set
,
ContextStorage_Remove
,
ContextStorage_Get
,
};
static
void
*
WINAPI
Unknown5_func0_relay
(
void
*
param0
,
void
*
param1
,
void
*
param2
)
...
...
@@ -479,15 +530,15 @@ CUresult cuda_get_table(const void **table, const CUuuid *uuid, const void *orig
*
table
=
(
void
*
)
&
Unknown3_Impl
;
return
CUDA_SUCCESS
;
}
else
if
(
cuda_equal_uuid
(
uuid
,
&
UUID_
Unknown4
))
else
if
(
cuda_equal_uuid
(
uuid
,
&
UUID_
ContextStorage
))
{
if
(
orig_result
)
return
orig_result
;
if
(
!
orig_table
)
return
CUDA_ERROR_UNKNOWN
;
Unknown4
_orig
=
orig_table
;
*
table
=
(
void
*
)
&
Unknown4
_Impl
;
ContextStorage
_orig
=
orig_table
;
*
table
=
(
void
*
)
&
ContextStorage
_Impl
;
return
CUDA_SUCCESS
;
}
else
if
(
cuda_equal_uuid
(
uuid
,
&
UUID_Unknown5
))
...
...
dlls/nvcuda/tests/nvcuda.c
View file @
15f6a28e
This diff is collapsed.
Click to expand it.
include/cuda.h
View file @
15f6a28e
...
...
@@ -22,6 +22,8 @@
#define CUDA_SUCCESS 0
#define CUDA_ERROR_INVALID_VALUE 1
#define CUDA_ERROR_OUT_OF_MEMORY 2
#define CUDA_ERROR_INVALID_CONTEXT 201
#define CUDA_ERROR_INVALID_HANDLE 400
#define CUDA_ERROR_NOT_SUPPORTED 801
#define CUDA_ERROR_UNKNOWN 999
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment