Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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
wine
wine-cw
Commits
2a7a2371
Commit
2a7a2371
authored
Apr 06, 2009
by
Stefan Dösinger
Committed by
Alexandre Julliard
Apr 08, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wined3d: Merge indexbuffer and buffer implementations.
parent
3ed94329
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
23 additions
and
80 deletions
+23
-80
buffer.c
dlls/wined3d/buffer.c
+0
-0
device.c
dlls/wined3d/device.c
+18
-58
drawprim.c
dlls/wined3d/drawprim.c
+2
-2
state.c
dlls/wined3d/state.c
+2
-2
wined3d_private.h
dlls/wined3d/wined3d_private.h
+1
-18
No files found.
dlls/wined3d/buffer.c
View file @
2a7a2371
This diff is collapsed.
Click to expand it.
dlls/wined3d/device.c
View file @
2a7a2371
...
...
@@ -463,6 +463,7 @@ static HRESULT WINAPI IWineD3DDeviceImpl_CreateBuffer(IWineD3DDevice *iface,
HeapFree
(
GetProcessHeap
(),
0
,
object
);
return
hr
;
}
object
->
buffer_type_hint
=
GL_ARRAY_BUFFER_ARB
;
TRACE
(
"Created resource %p
\n
"
,
object
);
...
...
@@ -540,6 +541,7 @@ static HRESULT WINAPI IWineD3DDeviceImpl_CreateVertexBuffer(IWineD3DDevice *ifac
*
ppVertexBuffer
=
NULL
;
return
hr
;
}
object
->
buffer_type_hint
=
GL_ARRAY_BUFFER_ARB
;
TRACE
(
"(%p) : Created resource %p
\n
"
,
This
,
object
);
...
...
@@ -580,62 +582,12 @@ static HRESULT WINAPI IWineD3DDeviceImpl_CreateVertexBuffer(IWineD3DDevice *ifac
return
WINED3D_OK
;
}
static
void
CreateIndexBufferVBO
(
IWineD3DDeviceImpl
*
This
,
IWineD3DIndexBufferImpl
*
object
)
{
GLenum
error
,
glUsage
;
TRACE
(
"Creating VBO for Index Buffer %p
\n
"
,
object
);
/* The following code will modify the ELEMENT_ARRAY_BUFFER binding, make sure it is
* restored on the next draw
*/
IWineD3DDeviceImpl_MarkStateDirty
(
This
,
STATE_INDEXBUFFER
);
/* Make sure that a context is there. Needed in a multithreaded environment. Otherwise this call is a nop */
ActivateContext
(
This
,
This
->
lastActiveRenderTarget
,
CTXUSAGE_RESOURCELOAD
);
ENTER_GL
();
while
(
glGetError
());
GL_EXTCALL
(
glGenBuffersARB
(
1
,
&
object
->
vbo
));
error
=
glGetError
();
if
(
error
!=
GL_NO_ERROR
||
object
->
vbo
==
0
)
{
ERR
(
"Creating a vbo failed with error %s (%#x), continuing without vbo for this buffer
\n
"
,
debug_glerror
(
error
),
error
);
goto
out
;
}
GL_EXTCALL
(
glBindBufferARB
(
GL_ELEMENT_ARRAY_BUFFER_ARB
,
object
->
vbo
));
error
=
glGetError
();
if
(
error
!=
GL_NO_ERROR
)
{
ERR
(
"Failed to bind index buffer with error %s (%#x), continuing without vbo for this buffer
\n
"
,
debug_glerror
(
error
),
error
);
goto
out
;
}
/* Use static write only usage for now. Dynamic index buffers stay in sysmem, and due to the sysmem
* copy no readback will be needed
*/
glUsage
=
GL_STATIC_DRAW_ARB
;
GL_EXTCALL
(
glBufferDataARB
(
GL_ELEMENT_ARRAY_BUFFER_ARB
,
object
->
resource
.
size
,
NULL
,
glUsage
));
error
=
glGetError
();
if
(
error
!=
GL_NO_ERROR
)
{
ERR
(
"Failed to initialize the index buffer with error %s (%#x)
\n
"
,
debug_glerror
(
error
),
error
);
goto
out
;
}
LEAVE_GL
();
TRACE
(
"Successfully created vbo %d for index buffer %p
\n
"
,
object
->
vbo
,
object
);
return
;
out:
GL_EXTCALL
(
glBindBufferARB
(
GL_ELEMENT_ARRAY_BUFFER_ARB
,
0
));
GL_EXTCALL
(
glDeleteBuffersARB
(
1
,
&
object
->
vbo
));
LEAVE_GL
();
object
->
vbo
=
0
;
}
static
HRESULT
WINAPI
IWineD3DDeviceImpl_CreateIndexBuffer
(
IWineD3DDevice
*
iface
,
UINT
Length
,
DWORD
Usage
,
static
HRESULT
WINAPI
IWineD3DDeviceImpl_CreateIndexBuffer
(
IWineD3DDevice
*
iface
,
UINT
Length
,
DWORD
Usage
,
WINED3DFORMAT
Format
,
WINED3DPOOL
Pool
,
IWineD3DIndexBuffer
**
ppIndexBuffer
,
HANDLE
*
sharedHandle
,
IUnknown
*
parent
)
{
IWineD3DDeviceImpl
*
This
=
(
IWineD3DDeviceImpl
*
)
iface
;
const
struct
GlPixelFormatDesc
*
format_desc
=
getFormatDescEntry
(
Format
,
&
This
->
adapter
->
gl_info
);
IWineD3DIndexBufferImpl
*
object
;
struct
wined3d_buffer
*
object
;
HRESULT
hr
;
TRACE
(
"(%p) Creating index buffer
\n
"
,
This
);
...
...
@@ -649,7 +601,7 @@ static HRESULT WINAPI IWineD3DDeviceImpl_CreateIndexBuffer(IWineD3DDevice *iface
return
WINED3DERR_OUTOFVIDEOMEMORY
;
}
object
->
lpVtbl
=
&
IWineD3DIndexBuffer_V
tbl
;
object
->
vtbl
=
&
wined3d_buffer_v
tbl
;
hr
=
resource_init
(
&
object
->
resource
,
WINED3DRTYPE_BUFFER
,
This
,
Length
,
Usage
,
format_desc
,
Pool
,
parent
);
if
(
FAILED
(
hr
))
{
...
...
@@ -658,13 +610,14 @@ static HRESULT WINAPI IWineD3DDeviceImpl_CreateIndexBuffer(IWineD3DDevice *iface
*
ppIndexBuffer
=
NULL
;
return
hr
;
}
object
->
buffer_type_hint
=
GL_ELEMENT_ARRAY_BUFFER_ARB
;
TRACE
(
"(%p) : Created resource %p
\n
"
,
This
,
object
);
IWineD3DDeviceImpl_AddResource
(
iface
,
(
IWineD3DResource
*
)
object
);
if
(
Pool
!=
WINED3DPOOL_SYSTEMMEM
&&
!
(
Usage
&
WINED3DUSAGE_DYNAMIC
)
&&
GL_SUPPORT
(
ARB_VERTEX_BUFFER_OBJECT
))
{
CreateIndexBufferVBO
(
This
,
object
)
;
object
->
flags
|=
WINED3D_BUFFER_CREATEBO
;
}
TRACE
(
"(%p) : Len=%d, Use=%x, Format=(%u,%s), Pool=%d - Memory@%p, Iface@%p
\n
"
,
This
,
Length
,
Usage
,
Format
,
...
...
@@ -3704,9 +3657,16 @@ static HRESULT WINAPI IWineD3DDeviceImpl_SetIndices(IWineD3DDevice *iface, IWine
if
(
oldIdxs
!=
pIndexData
)
{
IWineD3DDeviceImpl_MarkStateDirty
(
This
,
STATE_INDEXBUFFER
);
if
(
pIndexData
)
IWineD3DIndexBuffer_AddRef
(
pIndexData
);
if
(
oldIdxs
)
IWineD3DIndexBuffer_Release
(
oldIdxs
);
if
(
pIndexData
)
{
InterlockedIncrement
(
&
((
struct
wined3d_buffer
*
)
pIndexData
)
->
bind_count
);
IWineD3DIndexBuffer_AddRef
(
pIndexData
);
}
if
(
oldIdxs
)
{
InterlockedDecrement
(
&
((
struct
wined3d_buffer
*
)
oldIdxs
)
->
bind_count
);
IWineD3DIndexBuffer_Release
(
oldIdxs
);
}
}
return
WINED3D_OK
;
}
...
...
@@ -5700,7 +5660,7 @@ static HRESULT WINAPI IWineD3DDeviceImpl_DrawIndexedPrimitive(IWineD3DDevice *if
IWineD3DDeviceImpl_MarkStateDirty
(
This
,
STATE_INDEXBUFFER
);
This
->
stateBlock
->
streamIsUP
=
FALSE
;
}
vbo
=
((
IWineD3DIndexBufferImpl
*
)
pIB
)
->
vbo
;
vbo
=
((
struct
wined3d_buffer
*
)
pIB
)
->
buffer_object
;
TRACE
(
"(%p) : min %u, vertex count %u, startIdx %u, index count %u
\n
"
,
This
,
minIndex
,
NumVertices
,
startIndex
,
index_count
);
...
...
@@ -5718,7 +5678,7 @@ static HRESULT WINAPI IWineD3DDeviceImpl_DrawIndexedPrimitive(IWineD3DDevice *if
}
drawPrimitive
(
iface
,
index_count
,
NumVertices
,
startIndex
,
idxStride
,
vbo
?
NULL
:
((
IWineD3DIndexBufferImpl
*
)
pIB
)
->
resource
.
allocatedMemory
,
minIndex
);
vbo
?
NULL
:
((
struct
wined3d_buffer
*
)
pIB
)
->
resource
.
allocatedMemory
,
minIndex
);
return
WINED3D_OK
;
}
...
...
dlls/wined3d/drawprim.c
View file @
2a7a2371
...
...
@@ -95,7 +95,7 @@ static void drawStridedSlow(IWineD3DDevice *iface, const struct wined3d_stream_i
* idxData will be != NULL
*/
if
(
idxData
==
NULL
)
{
idxData
=
((
IWineD3DIndexBufferImpl
*
)
This
->
stateBlock
->
pIndexData
)
->
resource
.
allocatedMemory
;
idxData
=
((
struct
wined3d_buffer
*
)
This
->
stateBlock
->
pIndexData
)
->
resource
.
allocatedMemory
;
}
if
(
idxSize
==
2
)
pIdxBufS
=
idxData
;
...
...
@@ -413,7 +413,7 @@ static void drawStridedSlowVs(IWineD3DDevice *iface, const struct wined3d_stream
* idxData will be != NULL
*/
if
(
idxData
==
NULL
)
{
idxData
=
((
IWineD3DIndexBufferImpl
*
)
stateblock
->
pIndexData
)
->
resource
.
allocatedMemory
;
idxData
=
((
struct
wined3d_buffer
*
)
stateblock
->
pIndexData
)
->
resource
.
allocatedMemory
;
}
if
(
idxSize
==
2
)
pIdxBufS
=
idxData
;
...
...
dlls/wined3d/state.c
View file @
2a7a2371
...
...
@@ -4631,8 +4631,8 @@ static void indexbuffer(DWORD state, IWineD3DStateBlockImpl *stateblock, WineD3D
if
(
stateblock
->
streamIsUP
||
stateblock
->
pIndexData
==
NULL
)
{
GL_EXTCALL
(
glBindBufferARB
(
GL_ELEMENT_ARRAY_BUFFER_ARB
,
0
));
}
else
{
IWineD3DIndexBufferImpl
*
ib
=
(
IWineD3DIndexBufferImpl
*
)
stateblock
->
pIndexData
;
GL_EXTCALL
(
glBindBufferARB
(
GL_ELEMENT_ARRAY_BUFFER_ARB
,
ib
->
vbo
));
struct
wined3d_buffer
*
ib
=
(
struct
wined3d_buffer
*
)
stateblock
->
pIndexData
;
GL_EXTCALL
(
glBindBufferARB
(
GL_ELEMENT_ARRAY_BUFFER_ARB
,
ib
->
buffer_object
));
}
}
...
...
dlls/wined3d/wined3d_private.h
View file @
2a7a2371
...
...
@@ -1405,24 +1405,6 @@ HRESULT resource_set_private_data(IWineD3DResource *iface, REFGUID guid,
#define RESOURCE_ALIGNMENT 32
/*****************************************************************************
* IWineD3DIndexBuffer implementation structure (extends IWineD3DResourceImpl)
*/
typedef
struct
IWineD3DIndexBufferImpl
{
/* IUnknown & WineD3DResource Information */
const
IWineD3DIndexBufferVtbl
*
lpVtbl
;
IWineD3DResourceClass
resource
;
GLuint
vbo
;
UINT
dirtystart
,
dirtyend
;
LONG
lockcount
;
/* WineD3DVertexBuffer specifics */
}
IWineD3DIndexBufferImpl
;
extern
const
IWineD3DIndexBufferVtbl
IWineD3DIndexBuffer_Vtbl
;
/*****************************************************************************
* IWineD3DBaseTexture D3D- > openGL state map lookups
*/
#define WINED3DFUNC_NOTSUPPORTED -2
...
...
@@ -2103,6 +2085,7 @@ struct wined3d_buffer
GLuint
buffer_object
;
GLenum
buffer_object_usage
;
GLenum
buffer_type_hint
;
UINT
buffer_object_size
;
LONG
bind_count
;
DWORD
flags
;
...
...
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