win32u: Use syscall interface for brush functions.
Signed-off-by: Jacek Caban <jacek@codeweavers.com> Signed-off-by: Huw Davies <huw@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
2cc52c6e45
commit
33dddc84cf
|
@ -1081,19 +1081,15 @@ static struct unix_funcs unix_funcs =
|
||||||
NtGdiCreateClientObj,
|
NtGdiCreateClientObj,
|
||||||
NtGdiCreateCompatibleBitmap,
|
NtGdiCreateCompatibleBitmap,
|
||||||
NtGdiCreateCompatibleDC,
|
NtGdiCreateCompatibleDC,
|
||||||
NtGdiCreateDIBBrush,
|
|
||||||
NtGdiCreateDIBSection,
|
NtGdiCreateDIBSection,
|
||||||
NtGdiCreateDIBitmapInternal,
|
NtGdiCreateDIBitmapInternal,
|
||||||
NtGdiCreateEllipticRgn,
|
NtGdiCreateEllipticRgn,
|
||||||
NtGdiCreateHalftonePalette,
|
NtGdiCreateHalftonePalette,
|
||||||
NtGdiCreateHatchBrushInternal,
|
|
||||||
NtGdiCreateMetafileDC,
|
NtGdiCreateMetafileDC,
|
||||||
NtGdiCreatePaletteInternal,
|
NtGdiCreatePaletteInternal,
|
||||||
NtGdiCreatePatternBrushInternal,
|
|
||||||
NtGdiCreatePen,
|
NtGdiCreatePen,
|
||||||
NtGdiCreateRectRgn,
|
NtGdiCreateRectRgn,
|
||||||
NtGdiCreateRoundRectRgn,
|
NtGdiCreateRoundRectRgn,
|
||||||
NtGdiCreateSolidBrush,
|
|
||||||
NtGdiDdDDICheckVidPnExclusiveOwnership,
|
NtGdiDdDDICheckVidPnExclusiveOwnership,
|
||||||
NtGdiDdDDICloseAdapter,
|
NtGdiDdDDICloseAdapter,
|
||||||
NtGdiDdDDICreateDCFromMemory,
|
NtGdiDdDDICreateDCFromMemory,
|
||||||
|
|
|
@ -34,6 +34,10 @@
|
||||||
|
|
||||||
static void * const syscalls[] =
|
static void * const syscalls[] =
|
||||||
{
|
{
|
||||||
|
NtGdiCreateDIBBrush,
|
||||||
|
NtGdiCreateHatchBrushInternal,
|
||||||
|
NtGdiCreatePatternBrushInternal,
|
||||||
|
NtGdiCreateSolidBrush,
|
||||||
NtGdiFlush,
|
NtGdiFlush,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -147,23 +147,23 @@
|
||||||
@ stub NtGdiCreateColorTransform
|
@ stub NtGdiCreateColorTransform
|
||||||
@ stdcall NtGdiCreateCompatibleBitmap(long long long)
|
@ stdcall NtGdiCreateCompatibleBitmap(long long long)
|
||||||
@ stdcall NtGdiCreateCompatibleDC(long)
|
@ stdcall NtGdiCreateCompatibleDC(long)
|
||||||
@ stdcall NtGdiCreateDIBBrush(ptr long long long long ptr)
|
@ stdcall -syscall NtGdiCreateDIBBrush(ptr long long long long ptr)
|
||||||
@ stdcall NtGdiCreateDIBSection(long long long ptr long long long long ptr)
|
@ stdcall NtGdiCreateDIBSection(long long long ptr long long long long ptr)
|
||||||
@ stdcall NtGdiCreateDIBitmapInternal(long long long long ptr ptr long long long long long)
|
@ stdcall NtGdiCreateDIBitmapInternal(long long long long ptr ptr long long long long long)
|
||||||
@ stdcall NtGdiCreateEllipticRgn(long long long long)
|
@ stdcall NtGdiCreateEllipticRgn(long long long long)
|
||||||
@ stdcall NtGdiCreateHalftonePalette(long)
|
@ stdcall NtGdiCreateHalftonePalette(long)
|
||||||
@ stdcall NtGdiCreateHatchBrushInternal(long long long)
|
@ stdcall -syscall NtGdiCreateHatchBrushInternal(long long long)
|
||||||
@ stdcall NtGdiCreateMetafileDC(long)
|
@ stdcall NtGdiCreateMetafileDC(long)
|
||||||
@ stub NtGdiCreateOPMProtectedOutput
|
@ stub NtGdiCreateOPMProtectedOutput
|
||||||
@ stub NtGdiCreateOPMProtectedOutputs
|
@ stub NtGdiCreateOPMProtectedOutputs
|
||||||
@ stdcall NtGdiCreatePaletteInternal(ptr long)
|
@ stdcall NtGdiCreatePaletteInternal(ptr long)
|
||||||
@ stdcall NtGdiCreatePatternBrushInternal(long long long)
|
@ stdcall -syscall NtGdiCreatePatternBrushInternal(long long long)
|
||||||
@ stdcall NtGdiCreatePen(long long long long)
|
@ stdcall NtGdiCreatePen(long long long long)
|
||||||
@ stdcall NtGdiCreateRectRgn(long long long long)
|
@ stdcall NtGdiCreateRectRgn(long long long long)
|
||||||
@ stdcall NtGdiCreateRoundRectRgn(long long long long long long)
|
@ stdcall NtGdiCreateRoundRectRgn(long long long long long long)
|
||||||
@ stub NtGdiCreateServerMetaFile
|
@ stub NtGdiCreateServerMetaFile
|
||||||
@ stub NtGdiCreateSessionMappedDIBSection
|
@ stub NtGdiCreateSessionMappedDIBSection
|
||||||
@ stdcall NtGdiCreateSolidBrush(long long)
|
@ stdcall -syscall NtGdiCreateSolidBrush(long long)
|
||||||
@ stub NtGdiDDCCIGetCapabilitiesString
|
@ stub NtGdiDDCCIGetCapabilitiesString
|
||||||
@ stub NtGdiDDCCIGetCapabilitiesStringLength
|
@ stub NtGdiDDCCIGetCapabilitiesStringLength
|
||||||
@ stub NtGdiDDCCIGetTimingReport
|
@ stub NtGdiDDCCIGetTimingReport
|
||||||
|
|
|
@ -66,8 +66,6 @@ struct unix_funcs
|
||||||
HANDLE (WINAPI *pNtGdiCreateClientObj)( ULONG type );
|
HANDLE (WINAPI *pNtGdiCreateClientObj)( ULONG type );
|
||||||
HBITMAP (WINAPI *pNtGdiCreateCompatibleBitmap)( HDC hdc, INT width, INT height );
|
HBITMAP (WINAPI *pNtGdiCreateCompatibleBitmap)( HDC hdc, INT width, INT height );
|
||||||
HDC (WINAPI *pNtGdiCreateCompatibleDC)( HDC hdc );
|
HDC (WINAPI *pNtGdiCreateCompatibleDC)( HDC hdc );
|
||||||
HBRUSH (WINAPI *pNtGdiCreateDIBBrush)( const void *data, UINT coloruse, UINT size,
|
|
||||||
BOOL is_8x8, BOOL pen, const void *client );
|
|
||||||
HBITMAP (WINAPI *pNtGdiCreateDIBSection)( HDC hdc, HANDLE section, DWORD offset, const BITMAPINFO *bmi,
|
HBITMAP (WINAPI *pNtGdiCreateDIBSection)( HDC hdc, HANDLE section, DWORD offset, const BITMAPINFO *bmi,
|
||||||
UINT usage, UINT header_size, ULONG flags,
|
UINT usage, UINT header_size, ULONG flags,
|
||||||
ULONG_PTR color_space, void **bits );
|
ULONG_PTR color_space, void **bits );
|
||||||
|
@ -77,15 +75,12 @@ struct unix_funcs
|
||||||
ULONG flags, HANDLE xform );
|
ULONG flags, HANDLE xform );
|
||||||
HRGN (WINAPI *pNtGdiCreateEllipticRgn)( INT left, INT top, INT right, INT bottom );
|
HRGN (WINAPI *pNtGdiCreateEllipticRgn)( INT left, INT top, INT right, INT bottom );
|
||||||
HPALETTE (WINAPI *pNtGdiCreateHalftonePalette)( HDC hdc );
|
HPALETTE (WINAPI *pNtGdiCreateHalftonePalette)( HDC hdc );
|
||||||
HBRUSH (WINAPI *pNtGdiCreateHatchBrushInternal)( INT style, COLORREF color, BOOL pen );
|
|
||||||
HDC (WINAPI *pNtGdiCreateMetafileDC)( HDC hdc );
|
HDC (WINAPI *pNtGdiCreateMetafileDC)( HDC hdc );
|
||||||
HPALETTE (WINAPI *pNtGdiCreatePaletteInternal)( const LOGPALETTE *palette, UINT count );
|
HPALETTE (WINAPI *pNtGdiCreatePaletteInternal)( const LOGPALETTE *palette, UINT count );
|
||||||
HBRUSH (WINAPI *pNtGdiCreatePatternBrushInternal)( HBITMAP hbitmap, BOOL pen, BOOL is_8x8 );
|
|
||||||
HPEN (WINAPI *pNtGdiCreatePen)( INT style, INT width, COLORREF color, HBRUSH brush );
|
HPEN (WINAPI *pNtGdiCreatePen)( INT style, INT width, COLORREF color, HBRUSH brush );
|
||||||
HRGN (WINAPI *pNtGdiCreateRectRgn)( INT left, INT top, INT right, INT bottom );
|
HRGN (WINAPI *pNtGdiCreateRectRgn)( INT left, INT top, INT right, INT bottom );
|
||||||
HRGN (WINAPI *pNtGdiCreateRoundRectRgn)( INT left, INT top, INT right, INT bottom,
|
HRGN (WINAPI *pNtGdiCreateRoundRectRgn)( INT left, INT top, INT right, INT bottom,
|
||||||
INT ellipse_width, INT ellipse_height );
|
INT ellipse_width, INT ellipse_height );
|
||||||
HBRUSH (WINAPI *pNtGdiCreateSolidBrush)( COLORREF color, HBRUSH brush );
|
|
||||||
NTSTATUS (WINAPI *pNtGdiDdDDICheckVidPnExclusiveOwnership)( const D3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP *desc );
|
NTSTATUS (WINAPI *pNtGdiDdDDICheckVidPnExclusiveOwnership)( const D3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP *desc );
|
||||||
NTSTATUS (WINAPI *pNtGdiDdDDICloseAdapter)( const D3DKMT_CLOSEADAPTER *desc );
|
NTSTATUS (WINAPI *pNtGdiDdDDICloseAdapter)( const D3DKMT_CLOSEADAPTER *desc );
|
||||||
NTSTATUS (WINAPI *pNtGdiDdDDICreateDCFromMemory)( D3DKMT_CREATEDCFROMMEMORY *desc );
|
NTSTATUS (WINAPI *pNtGdiDdDDICreateDCFromMemory)( D3DKMT_CREATEDCFROMMEMORY *desc );
|
||||||
|
|
|
@ -118,12 +118,6 @@ HDC WINAPI NtGdiCreateCompatibleDC( HDC hdc )
|
||||||
return unix_funcs->pNtGdiCreateCompatibleDC( hdc );
|
return unix_funcs->pNtGdiCreateCompatibleDC( hdc );
|
||||||
}
|
}
|
||||||
|
|
||||||
HBRUSH WINAPI NtGdiCreateDIBBrush( const void *data, UINT coloruse, UINT size,
|
|
||||||
BOOL is_8x8, BOOL pen, const void *client )
|
|
||||||
{
|
|
||||||
return unix_funcs->pNtGdiCreateDIBBrush( data, coloruse, size, is_8x8, pen, client );
|
|
||||||
}
|
|
||||||
|
|
||||||
HBITMAP WINAPI NtGdiCreateDIBSection( HDC hdc, HANDLE section, DWORD offset, const BITMAPINFO *bmi,
|
HBITMAP WINAPI NtGdiCreateDIBSection( HDC hdc, HANDLE section, DWORD offset, const BITMAPINFO *bmi,
|
||||||
UINT usage, UINT header_size, ULONG flags,
|
UINT usage, UINT header_size, ULONG flags,
|
||||||
ULONG_PTR color_space, void **bits )
|
ULONG_PTR color_space, void **bits )
|
||||||
|
@ -151,11 +145,6 @@ HPALETTE WINAPI NtGdiCreateHalftonePalette( HDC hdc )
|
||||||
return unix_funcs->pNtGdiCreateHalftonePalette( hdc );
|
return unix_funcs->pNtGdiCreateHalftonePalette( hdc );
|
||||||
}
|
}
|
||||||
|
|
||||||
HBRUSH WINAPI NtGdiCreateHatchBrushInternal( INT style, COLORREF color, BOOL pen )
|
|
||||||
{
|
|
||||||
return unix_funcs->pNtGdiCreateHatchBrushInternal( style, color, pen );
|
|
||||||
}
|
|
||||||
|
|
||||||
HDC WINAPI NtGdiCreateMetafileDC( HDC hdc )
|
HDC WINAPI NtGdiCreateMetafileDC( HDC hdc )
|
||||||
{
|
{
|
||||||
return unix_funcs->pNtGdiCreateMetafileDC( hdc );
|
return unix_funcs->pNtGdiCreateMetafileDC( hdc );
|
||||||
|
@ -166,11 +155,6 @@ HPALETTE WINAPI NtGdiCreatePaletteInternal( const LOGPALETTE *palette, UINT coun
|
||||||
return unix_funcs->pNtGdiCreatePaletteInternal( palette, count );
|
return unix_funcs->pNtGdiCreatePaletteInternal( palette, count );
|
||||||
}
|
}
|
||||||
|
|
||||||
HBRUSH WINAPI NtGdiCreatePatternBrushInternal( HBITMAP hbitmap, BOOL pen, BOOL is_8x8 )
|
|
||||||
{
|
|
||||||
return unix_funcs->pNtGdiCreatePatternBrushInternal( hbitmap, pen, is_8x8 );
|
|
||||||
}
|
|
||||||
|
|
||||||
HPEN WINAPI NtGdiCreatePen( INT style, INT width, COLORREF color, HBRUSH brush )
|
HPEN WINAPI NtGdiCreatePen( INT style, INT width, COLORREF color, HBRUSH brush )
|
||||||
{
|
{
|
||||||
return unix_funcs->pNtGdiCreatePen( style, width, color, brush );
|
return unix_funcs->pNtGdiCreatePen( style, width, color, brush );
|
||||||
|
@ -187,11 +171,6 @@ HRGN WINAPI NtGdiCreateRoundRectRgn( INT left, INT top, INT right, INT bottom,
|
||||||
return unix_funcs->pNtGdiCreateRoundRectRgn( left, top, right, bottom, ellipse_width, ellipse_height );
|
return unix_funcs->pNtGdiCreateRoundRectRgn( left, top, right, bottom, ellipse_width, ellipse_height );
|
||||||
}
|
}
|
||||||
|
|
||||||
HBRUSH WINAPI NtGdiCreateSolidBrush( COLORREF color, HBRUSH brush )
|
|
||||||
{
|
|
||||||
return unix_funcs->pNtGdiCreateSolidBrush( color, brush );
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOL WINAPI NtGdiDeleteClientObj( HGDIOBJ obj )
|
BOOL WINAPI NtGdiDeleteClientObj( HGDIOBJ obj )
|
||||||
{
|
{
|
||||||
return unix_funcs->pNtGdiDeleteClientObj( obj );
|
return unix_funcs->pNtGdiDeleteClientObj( obj );
|
||||||
|
|
|
@ -4,4 +4,5 @@ IMPORTS = win32u ntdll winecrt0
|
||||||
EXTRADLLFLAGS = -nodefaultlibs -Wl,--image-base,0x6f200000
|
EXTRADLLFLAGS = -nodefaultlibs -Wl,--image-base,0x6f200000
|
||||||
|
|
||||||
C_SRCS = \
|
C_SRCS = \
|
||||||
|
gdi.c \
|
||||||
syscall.c
|
syscall.c
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
/*
|
||||||
|
* WoW64 GDI functions
|
||||||
|
*
|
||||||
|
* Copyright 2021 Jacek Caban for CodeWeavers
|
||||||
|
*
|
||||||
|
* This library 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.
|
||||||
|
*
|
||||||
|
* This library 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 this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#include "ntstatus.h"
|
||||||
|
#define WIN32_NO_STATUS
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
#include "ntgdi.h"
|
||||||
|
#include "wow64win_private.h"
|
||||||
|
|
||||||
|
NTSTATUS WINAPI wow64_NtGdiCreateDIBBrush( UINT *args )
|
||||||
|
{
|
||||||
|
const void *data = get_ptr( &args );
|
||||||
|
UINT coloruse = get_ulong( &args );
|
||||||
|
UINT size = get_ulong( &args );
|
||||||
|
BOOL is_8x8 = get_ulong( &args );
|
||||||
|
BOOL pen = get_ulong( &args );
|
||||||
|
const void *client = get_ptr( &args );
|
||||||
|
|
||||||
|
return HandleToUlong( NtGdiCreateDIBBrush( data, coloruse, size, is_8x8, pen, client ));
|
||||||
|
}
|
||||||
|
|
||||||
|
NTSTATUS WINAPI wow64_NtGdiCreateHatchBrushInternal( UINT *args )
|
||||||
|
{
|
||||||
|
INT style = get_ulong( &args );
|
||||||
|
COLORREF color = get_ulong( &args );
|
||||||
|
BOOL pen = get_ulong( &args );
|
||||||
|
|
||||||
|
return HandleToULong( NtGdiCreateHatchBrushInternal( style, color, pen ));
|
||||||
|
}
|
||||||
|
|
||||||
|
NTSTATUS WINAPI wow64_NtGdiCreatePatternBrushInternal( UINT *args )
|
||||||
|
{
|
||||||
|
HBITMAP hbitmap = get_handle( &args );
|
||||||
|
BOOL pen = get_ulong( &args );
|
||||||
|
BOOL is_8x8 = get_ulong( &args );
|
||||||
|
|
||||||
|
return HandleToUlong( NtGdiCreatePatternBrushInternal( hbitmap, pen, is_8x8 ));
|
||||||
|
}
|
||||||
|
|
||||||
|
NTSTATUS WINAPI wow64_NtGdiCreateSolidBrush( UINT *args )
|
||||||
|
{
|
||||||
|
COLORREF color = get_ulong( &args );
|
||||||
|
HBRUSH brush = get_handle( &args );
|
||||||
|
|
||||||
|
return HandleToUlong( NtGdiCreateSolidBrush( color, brush ));
|
||||||
|
}
|
||||||
|
|
||||||
|
NTSTATUS WINAPI wow64_NtGdiFlush( UINT *args )
|
||||||
|
{
|
||||||
|
return NtGdiFlush();
|
||||||
|
}
|
|
@ -28,13 +28,6 @@
|
||||||
#include "winternl.h"
|
#include "winternl.h"
|
||||||
#include "wow64win_private.h"
|
#include "wow64win_private.h"
|
||||||
|
|
||||||
extern BOOL WINAPI NtGdiFlush(void);
|
|
||||||
|
|
||||||
NTSTATUS WINAPI wow64_NtGdiFlush( UINT *args )
|
|
||||||
{
|
|
||||||
return NtGdiFlush();
|
|
||||||
}
|
|
||||||
|
|
||||||
static void * const win32_syscalls[] =
|
static void * const win32_syscalls[] =
|
||||||
{
|
{
|
||||||
#define SYSCALL_ENTRY(func) wow64_ ## func,
|
#define SYSCALL_ENTRY(func) wow64_ ## func,
|
||||||
|
|
|
@ -22,6 +22,10 @@
|
||||||
#define __WOW64WIN_SYSCALL_H
|
#define __WOW64WIN_SYSCALL_H
|
||||||
|
|
||||||
#define ALL_WIN32_SYSCALLS \
|
#define ALL_WIN32_SYSCALLS \
|
||||||
|
SYSCALL_ENTRY( NtGdiCreateDIBBrush ) \
|
||||||
|
SYSCALL_ENTRY( NtGdiCreateHatchBrushInternal ) \
|
||||||
|
SYSCALL_ENTRY( NtGdiCreatePatternBrushInternal ) \
|
||||||
|
SYSCALL_ENTRY( NtGdiCreateSolidBrush ) \
|
||||||
SYSCALL_ENTRY( NtGdiFlush )
|
SYSCALL_ENTRY( NtGdiFlush )
|
||||||
|
|
||||||
#endif /* __WOW64WIN_SYSCALL_H */
|
#endif /* __WOW64WIN_SYSCALL_H */
|
||||||
|
|
|
@ -27,4 +27,8 @@
|
||||||
ALL_WIN32_SYSCALLS
|
ALL_WIN32_SYSCALLS
|
||||||
#undef SYSCALL_ENTRY
|
#undef SYSCALL_ENTRY
|
||||||
|
|
||||||
|
static inline ULONG get_ulong( UINT **args ) { return *(*args)++; }
|
||||||
|
static inline HANDLE get_handle( UINT **args ) { return LongToHandle( *(*args)++ ); }
|
||||||
|
static inline void *get_ptr( UINT **args ) { return ULongToPtr( *(*args)++ ); }
|
||||||
|
|
||||||
#endif /* __WOW64WIN_PRIVATE_H */
|
#endif /* __WOW64WIN_PRIVATE_H */
|
||||||
|
|
Loading…
Reference in New Issue