Brush rewrite part 1/x

- Make the EBRUSHOBJ structure somewhat like XPs. 
- Make the eboXxx members of the DC real EBRUSHOBJs and initialize them on DC creation. Except for IntArc they are not yet used and there still with the old way of doing it.
- Implement DC_vUpdateXxxBrush functions that update the DCs EBRUSHOBJs after changes to the dcattr.
- Implement EBRUSHOBJ_bRealizeBrush that realizes the brush by either calling the DrvRealizeBrush or EngRealizeBrush, which is currently only stubbed and this functionality is not plugged in due to other broken features.
- EBRUSHOBJ_vInit: Store the RGB color and return it in BRUSHOBJ_ulGetBrushColor.
- Implement EBRUSHOBJ_vSetSolidBrushColor, EBRUSHOBJ_vUpdate and EBRUSHOBJ_vUnrealizeBrush
- Rename PENOBJ_bla to PEN_bla.
- Make GDIOBJ_ShareUnlockObjByPtr an inline function
- Implement GDIOBJ_IncrementShareCount as inline function.
- NtGdiSelectBitmap: keep a shared reference on the selected bitmap.
- EngAssociateSurface: don't ASSERT, but fail if locking the surface handle failed.
- EngModifySurface: use an exclusive lock and handle everything inside this function.

svn path=/trunk/; revision=40179
This commit is contained in:
Timo Kreuzer 2009-03-23 00:38:59 +00:00
parent 7eafa4dee6
commit e2a450fc3f
16 changed files with 461 additions and 114 deletions

View file

@ -92,7 +92,7 @@ BltMask(SURFOBJ* Dest,
BYTE *tMask, *lMask;
static BYTE maskbit[8] = { 0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01 };
/* Pattern brushes */
PEBRUSHOBJ GdiBrush = NULL;
PEBRUSHOBJ pebo = NULL;
SURFOBJ *psoPattern = NULL;
PSURFACE psurfPattern;
ULONG PatternWidth = 0, PatternHeight = 0, PatternY = 0;
@ -107,12 +107,12 @@ BltMask(SURFOBJ* Dest,
if (pbo && pbo->iSolidColor == 0xFFFFFFFF)
{
GdiBrush = CONTAINING_RECORD(
pebo = CONTAINING_RECORD(
pbo,
EBRUSHOBJ,
BrushObject);
psurfPattern = SURFACE_LockSurface(GdiBrush->GdiBrushObject->hbmPattern);
psurfPattern = SURFACE_LockSurface(pebo->pbrush->hbmPattern);
if (psurfPattern != NULL)
{
psoPattern = &psurfPattern->SurfObj;
@ -145,7 +145,7 @@ BltMask(SURFOBJ* Dest,
{
DibFunctionsForBitmapFormat[Dest->iBitmapFormat].DIB_PutPixel(
Dest, DestRect->left + i, DestRect->top + j,
DIB_GetSource(psoPattern, (DestRect->left + i) % PatternWidth, PatternY, GdiBrush ? GdiBrush->XlateObject : NULL));
DIB_GetSource(psoPattern, (DestRect->left + i) % PatternWidth, PatternY, pebo ? pebo->XlateObject : NULL));
}
}
c8++;
@ -220,7 +220,7 @@ CallDibBitBlt(SURFOBJ* OutputObj,
if (ROP4_USES_PATTERN(Rop4) && pbo && pbo->iSolidColor == 0xFFFFFFFF)
{
GdiBrush = CONTAINING_RECORD(pbo, EBRUSHOBJ, BrushObject);
if ((psurfPattern = SURFACE_LockSurface(GdiBrush->GdiBrushObject->hbmPattern)))
if ((psurfPattern = SURFACE_LockSurface(GdiBrush->pbrush->hbmPattern)))
{
BltInfo.PatternSurface = &psurfPattern->SurfObj;
}
@ -763,7 +763,7 @@ CallDibStretchBlt(SURFOBJ* psoDest,
if (ROP4_USES_PATTERN(Rop4) && pbo && pbo->iSolidColor == 0xFFFFFFFF)
{
GdiBrush = CONTAINING_RECORD(pbo, EBRUSHOBJ, BrushObject);
psurfPattern = SURFACE_LockSurface(GdiBrush->GdiBrushObject->hbmPattern);
psurfPattern = SURFACE_LockSurface(GdiBrush->pbrush->hbmPattern);
if (psurfPattern)
{
PatternSurface = &psurfPattern->SurfObj;

View file

@ -4,8 +4,7 @@
* PURPOSE: GDI Driver Brush Functions
* FILE: subsystem/win32/win32k/eng/engbrush.c
* PROGRAMER: Jason Filby
* REVISION HISTORY:
* 3/7/1999: Created
* Timo Kreuzer
*/
#include <w32k.h>
@ -15,9 +14,29 @@
/** Internal functions ********************************************************/
VOID FASTCALL
/**
* This function is not exported, because it makes no sense for
* The driver to punt back to this function */
BOOL
APIENTRY
EngRealizeBrush(
BRUSHOBJ *pbo,
SURFOBJ *psoDst,
SURFOBJ *psoPattern,
SURFOBJ *psoMask,
XLATEOBJ *pxlo,
ULONG iHatch)
{
UNIMPLEMENTED;
return FALSE;
}
VOID
FASTCALL
EBRUSHOBJ_vInit(EBRUSHOBJ *pebo, PBRUSH pbrush, XLATEOBJ *pxlo)
{
ULONG iSolidColor;
ASSERT(pebo);
ASSERT(pbrush);
@ -27,20 +46,109 @@ EBRUSHOBJ_vInit(EBRUSHOBJ *pebo, PBRUSH pbrush, XLATEOBJ *pxlo)
}
else if (pbrush->flAttrs & GDIBRUSH_IS_SOLID)
{
pebo->BrushObject.iSolidColor = XLATEOBJ_iXlate(pxlo, pbrush->BrushAttr.lbColor);
/* Set the RGB color */
pebo->crRealize = pbrush->BrushAttr.lbColor;
pebo->ulRGBColor = pbrush->BrushAttr.lbColor;
/* Translate the brush color to the target format */
iSolidColor = XLATEOBJ_iXlate(pxlo, pbrush->BrushAttr.lbColor);
pebo->BrushObject.iSolidColor = iSolidColor;
}
else
{
/* This is a pattern brush that needs realization */
pebo->BrushObject.iSolidColor = 0xFFFFFFFF;
// FIXME: What about calling DrvRealizeBrush?
// EBRUSHOBJ_bRealizeBrush(pebo);
}
pebo->BrushObject.pvRbrush = pbrush->ulRealization;
pebo->BrushObject.flColorType = 0;
pebo->GdiBrushObject = pbrush;
pebo->pbrush = pbrush;
pebo->XlateObject = pxlo;
}
VOID
FASTCALL
EBRUSHOBJ_vSetSolidBrushColor(EBRUSHOBJ *pebo, ULONG iSolidColor)
{
/* Never use with non-solid brushes */
ASSERT(pebo->flattrs & GDIBRUSH_IS_SOLID);
pebo->BrushObject.iSolidColor = iSolidColor;
}
BOOL
FASTCALL
EBRUSHOBJ_bRealizeBrush(EBRUSHOBJ *pebo)
{
BOOL bResult;
PFN_DrvRealizeBrush pfnRealzizeBrush;
PSURFACE psurfTrg, psurfPattern, psurfMask;
PPDEVOBJ ppdev;
XLATEOBJ *pxlo;
psurfTrg = pebo->psurfTrg; // FIXME: all EBRUSHOBJs need a surface
ppdev = (PPDEVOBJ)psurfTrg->SurfObj.hdev; // FIXME: all SURFACEs need a PDEV
pfnRealzizeBrush = ppdev->DriverFunctions.RealizeBrush;
if (!pfnRealzizeBrush)
{
pfnRealzizeBrush = EngRealizeBrush;
}
psurfPattern = SURFACE_LockSurface(pebo->pbrush->hbmPattern);
/* FIXME: implement mask */
psurfMask = NULL;
// FIXME
pxlo = NULL;
bResult = pfnRealzizeBrush(&pebo->BrushObject,
&pebo->psurfTrg->SurfObj,
psurfPattern ? &psurfPattern->SurfObj : NULL,
psurfMask ? &psurfMask->SurfObj : NULL,
pxlo,
-1); // FIXME: what about hatch brushes?
if (psurfPattern)
SURFACE_UnlockSurface(psurfPattern);
if (psurfMask)
SURFACE_UnlockSurface(psurfMask);
return bResult;
}
VOID
FASTCALL
EBRUSHOBJ_vUnrealizeBrush(EBRUSHOBJ *pebo)
{
/* Check if it's a GDI realisation */
if (pebo->pengbrush)
{
}
else if (pebo->BrushObject.pvRbrush)
{
/* Free allocated driver memory */
EngFreeMem(pebo->BrushObject.pvRbrush);
}
}
VOID
FASTCALL
EBRUSHOBJ_vUpdate(EBRUSHOBJ *pebo, PBRUSH pbrush, XLATEOBJ *pxlo)
{
/* Unrealize the brush */
EBRUSHOBJ_vUnrealizeBrush(pebo);
EBRUSHOBJ_vInit(pebo, pbrush, pxlo);
}
/** Exported DDI functions ****************************************************/
@ -48,30 +156,34 @@ EBRUSHOBJ_vInit(EBRUSHOBJ *pebo, PBRUSH pbrush, XLATEOBJ *pxlo)
* @implemented
*/
PVOID APIENTRY
BRUSHOBJ_pvAllocRbrush(IN BRUSHOBJ *BrushObj,
IN ULONG ObjSize)
BRUSHOBJ_pvAllocRbrush(
IN BRUSHOBJ *pbo,
IN ULONG cj)
{
BrushObj->pvRbrush=EngAllocMem(0, ObjSize, 0);
return(BrushObj->pvRbrush);
pbo->pvRbrush = EngAllocMem(0, cj, 'rbdG');
return pbo->pvRbrush;
}
/*
* @implemented
*/
PVOID APIENTRY
BRUSHOBJ_pvGetRbrush(IN BRUSHOBJ *BrushObj)
BRUSHOBJ_pvGetRbrush(
IN BRUSHOBJ *pbo)
{
// FIXME: this is wrong! Read msdn.
return(BrushObj->pvRbrush);
return pbo->pvRbrush;
}
/*
* @implemented
*/
ULONG APIENTRY
BRUSHOBJ_ulGetBrushColor(IN BRUSHOBJ *BrushObj)
BRUSHOBJ_ulGetBrushColor(
IN BRUSHOBJ *pbo)
{
return BrushObj->iSolidColor;
EBRUSHOBJ *pebo = CONTAINING_RECORD(pbo, EBRUSHOBJ, BrushObject);
return pebo->ulRGBColor;
}
/* EOF */

View file

@ -530,9 +530,9 @@ IntEngLineTo(SURFOBJ *psoDest,
EBRUSHOBJ,
BrushObject);
ASSERT(GdiBrush);
ASSERT(GdiBrush->GdiBrushObject);
ASSERT(GdiBrush->pbrush);
if (GdiBrush->GdiBrushObject->flAttrs & GDIBRUSH_IS_NULL)
if (GdiBrush->pbrush->flAttrs & GDIBRUSH_IS_NULL)
return TRUE;
/* No success yet */

View file

@ -506,27 +506,33 @@ EngCreateDeviceSurface(IN DHSURF dhsurf,
/*
* @implemented
*/
BOOL APIENTRY
EngAssociateSurface(IN HSURF hsurf,
IN HDEV hdev,
IN ULONG Hooks)
BOOL
APIENTRY
EngAssociateSurface(
IN HSURF hsurf,
IN HDEV hdev,
IN FLONG flHooks)
{
SURFOBJ *pso;
PSURFACE psurf;
PDEVOBJ* Device;
PDEVOBJ* ppdev;
Device = (PDEVOBJ*)hdev;
ppdev = (PDEVOBJ*)hdev;
/* Lock the surface */
psurf = SURFACE_LockSurface(hsurf);
ASSERT(psurf);
if (!psurf)
{
return FALSE;
}
pso = &psurf->SurfObj;
/* Associate the hdev */
pso->hdev = hdev;
pso->dhpdev = Device->hPDev;
pso->dhpdev = ppdev->hPDev;
/* Hook up specified functions */
psurf->flHooks = Hooks;
psurf->flHooks = flHooks;
SURFACE_UnlockSurface(psurf);
@ -548,25 +554,29 @@ EngModifySurface(
IN VOID *pvReserved)
{
SURFOBJ *pso;
PSURFACE psurf;
PDEVOBJ* ppdev;
pso = EngLockSurface(hsurf);
if (pso == NULL)
psurf = SURFACE_LockSurface(hsurf);
if (psurf == NULL)
{
return FALSE;
}
if (!EngAssociateSurface(hsurf, hdev, flHooks))
{
EngUnlockSurface(pso);
return FALSE;
}
ppdev = (PDEVOBJ*)hdev;
pso = &psurf->SurfObj;
pso->dhsurf = dhsurf;
pso->lDelta = lDelta;
pso->pvScan0 = pvScan0;
EngUnlockSurface(pso);
/* Associate the hdev */
pso->hdev = hdev;
pso->dhpdev = ppdev->hPDev;
/* Hook up specified functions */
psurf->flHooks = flHooks;
SURFACE_UnlockSurface(psurf);
return TRUE;
}

View file

@ -15,7 +15,7 @@
* A MAILING LIST FIRST.
*/
typedef struct
typedef struct _BRUSH
{
/* Header for all gdi objects in the handle table.
Do not (re)move this. */
@ -44,11 +44,33 @@ typedef struct
ULONG Unknown6C;
} BRUSH, *PBRUSH;
typedef struct
typedef struct _EBRUSHOBJ
{
BRUSHOBJ BrushObject;
PBRUSH GdiBrushObject;
XLATEOBJ *XlateObject;
BRUSHOBJ BrushObject;
COLORREF crRealize;
ULONG ulRGBColor;
DWORD pengbrush;
ULONG ulSurfPalTime;
ULONG ulDCPalTime;
COLORREF crCurrentText;
COLORREF crCurrentBack;
COLORADJUSTMENT *pca;
// DWORD dwUnknown2c;
// DWORD dwUnknown30;
SURFACE * psurfTrg;
// PALETTE * ppalSurf;
// PALETTE * ppalDC;
// PALETTE * ppal3;
// DWORD dwUnknown44;
BRUSH * pbrush;
FLONG flattrs;
DWORD ulUnique;
// DWORD dwUnknown54;
// DWORD dwUnknown58;
/* Ros specific */
XLATEOBJ *XlateObject;
} EBRUSHOBJ, *PEBRUSHOBJ;
/* GDI Brush Attributes */
@ -78,10 +100,25 @@ typedef struct
#define BRUSH_LockBrush(hBrush) ((PBRUSH)GDIOBJ_LockObj((HGDIOBJ)hBrush, GDI_OBJECT_TYPE_BRUSH))
#define BRUSH_UnlockBrush(pBrush) GDIOBJ_UnlockObjByPtr((POBJ)pBrush)
#define BRUSH_ShareLockBrush(hBrush) ((PBRUSH)GDIOBJ_ShareLockObj((HGDIOBJ)hBrush, GDI_OBJECT_TYPE_BRUSH))
#define BRUSH_ShareUnlockBrush(pBrush) GDIOBJ_ShareUnlockObjByPtr((POBJ)pBrush)
INT FASTCALL BRUSH_GetObject (PBRUSH GdiObject, INT Count, LPLOGBRUSH Buffer);
BOOL INTERNAL_CALL BRUSH_Cleanup(PVOID ObjectBody);
VOID FASTCALL
EBRUSHOBJ_vInit(EBRUSHOBJ *BrushInst, PBRUSH BrushObj, XLATEOBJ *XlateObj);
VOID
FASTCALL
EBRUSHOBJ_vSetSolidBrushColor(EBRUSHOBJ *pebo, ULONG iSolidColor);
VOID
FASTCALL
EBRUSHOBJ_vUpdate(EBRUSHOBJ *pebo, PBRUSH pbrush, XLATEOBJ *pxlo);
BOOL
FASTCALL
EBRUSHOBJ_bRealizeBrush(EBRUSHOBJ *pebo);
#endif

View file

@ -190,10 +190,10 @@ typedef struct _DC
PVOID prgnVis;
PVOID prgnRao;
POINTL ptlFillOrigin;
unsigned eboFill_[23]; /* EBRUSHOBJ */
unsigned eboLine_[23];
unsigned eboText_[23];
unsigned eboBackground_[23];
EBRUSHOBJ eboFill;
EBRUSHOBJ eboLine;
EBRUSHOBJ eboText;
EBRUSHOBJ eboBackground;
HFONT hlfntCur;
FLONG flSimulationFlags;
LONG lEscapement;

View file

@ -61,7 +61,7 @@ BOOL INTERNAL_CALL GDIOBJ_OwnedByCurrentProcess(HGDIOBJ ObjectHandle);
BOOL INTERNAL_CALL GDIOBJ_SetOwnership(HGDIOBJ ObjectHandle, PEPROCESS Owner);
BOOL INTERNAL_CALL GDIOBJ_CopyOwnership(HGDIOBJ CopyFrom, HGDIOBJ CopyTo);
BOOL INTERNAL_CALL GDIOBJ_ConvertToStockObj(HGDIOBJ *hObj);
VOID INTERNAL_CALL GDIOBJ_ShareUnlockObjByPtr(POBJ Object);
//VOID INTERNAL_CALL GDIOBJ_ShareUnlockObjByPtr(POBJ Object);
BOOL INTERNAL_CALL GDIOBJ_ValidateHandle(HGDIOBJ hObj, ULONG ObjectType);
POBJ INTERNAL_CALL GDIOBJ_AllocObj(UCHAR ObjectType);
POBJ INTERNAL_CALL GDIOBJ_AllocObjWithHandle(ULONG ObjectType);
@ -99,4 +99,22 @@ GDIOBJ_UnlockObjByPtr(POBJ Object)
return cLocks;
}
ULONG
FORCEINLINE
GDIOBJ_ShareUnlockObjByPtr(POBJ Object)
{
INT cLocks = InterlockedDecrement((PLONG)&Object->ulShareCount);
ASSERT(cLocks >= 0);
return cLocks;
}
ULONG
FORCEINLINE
GDIOBJ_IncrementShareCount(POBJ Object)
{
INT cLocks = InterlockedIncrement((PLONG)&Object->ulShareCount);
ASSERT(cLocks >= 1);
return cLocks;
}
#endif

View file

@ -6,26 +6,30 @@
/* Internal interface */
#define PENOBJ_AllocPen() ((HPEN)GDIOBJ_AllocObj(GDIObjType_BRUSH_TYPE))
#define PENOBJ_AllocPenWithHandle() ((PBRUSH)GDIOBJ_AllocObjWithHandle(GDI_OBJECT_TYPE_PEN))
#define PEN_AllocPen() ((HPEN)GDIOBJ_AllocObj(GDIObjType_BRUSH_TYPE))
#define PEN_AllocPenWithHandle() ((PBRUSH)GDIOBJ_AllocObjWithHandle(GDI_OBJECT_TYPE_PEN))
#define PENOBJ_FreePen(pBMObj) GDIOBJ_FreeObj((POBJ) pBMObj, GDIObjType_BRUSH_TYPE)
#define PENOBJ_FreePenByHandle(hBMObj) GDIOBJ_FreeObjByHandle((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_PEN)
#define PEN_FreePen(pBMObj) GDIOBJ_FreeObj((POBJ) pBMObj, GDIObjType_BRUSH_TYPE)
#define PEN_FreePenByHandle(hBMObj) GDIOBJ_FreeObjByHandle((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_PEN)
//#define PENOBJ_LockPen(hBMObj) ((PBRUSH)GDIOBJ_LockObj((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_PEN))
//#define PEN_LockPen(hBMObj) ((PBRUSH)GDIOBJ_LockObj((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_PEN))
#define PENOBJ_AllocExtPen() ((PBRUSH)GDIOBJ_AllocObj(GDIObjType_BRUSH_TYPE))
#define PENOBJ_AllocExtPenWithHandle() ((PBRUSH)GDIOBJ_AllocObjWithHandle(GDI_OBJECT_TYPE_EXTPEN))
#define PEN_AllocExtPen() ((PBRUSH)GDIOBJ_AllocObj(GDIObjType_BRUSH_TYPE))
#define PEN_AllocExtPenWithHandle() ((PBRUSH)GDIOBJ_AllocObjWithHandle(GDI_OBJECT_TYPE_EXTPEN))
#define PENOBJ_FreeExtPen(pBMObj) GDIOBJ_FreeObj((POBJ) pBMObj, GDIObjType_BRUSH_TYPE)
#define PENOBJ_FreeExtPenByHandle(hBMObj) GDIOBJ_FreeObjByHandle((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_EXTPEN)
#define PEN_FreeExtPen(pBMObj) GDIOBJ_FreeObj((POBJ) pBMObj, GDIObjType_BRUSH_TYPE)
#define PEN_FreeExtPenByHandle(hBMObj) GDIOBJ_FreeObjByHandle((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_EXTPEN)
//#define PENOBJ_LockExtPen(hBMObj) ((PBRUSH)GDIOBJ_LockObj((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_EXTPEN))
//#define PEN_LockExtPen(hBMObj) ((PBRUSH)GDIOBJ_LockObj((HGDIOBJ) hBMObj, GDI_OBJECT_TYPE_EXTPEN))
#define PENOBJ_UnlockPen(pPenObj) GDIOBJ_UnlockObjByPtr((POBJ)pPenObj)
#define PEN_UnlockPen(pPenObj) GDIOBJ_UnlockObjByPtr((POBJ)pPenObj)
#define PEN_ShareUnlockPen(ppen) GDIOBJ_ShareUnlockObjByPtr((POBJ)ppen)
PBRUSH FASTCALL PENOBJ_LockPen(HGDIOBJ);
PBRUSH FASTCALL PEN_LockPen(HGDIOBJ);
PBRUSH FASTCALL PEN_ShareLockPen(HGDIOBJ);
INT APIENTRY PEN_GetObject(PBRUSH pPen, INT Count, PLOGPEN Buffer);
#endif

View file

@ -45,7 +45,6 @@ IntArc( DC *dc,
PDC_ATTR pdcattr;
RECTL RectBounds, RectSEpts;
PBRUSH pbrushPen;
EBRUSHOBJ eboPen;
SURFACE *psurf;
BOOL ret = TRUE;
LONG PenWidth, PenOrigWidth;
@ -70,7 +69,7 @@ IntArc( DC *dc,
pdcattr = dc->pdcattr;
pbrushPen = PENOBJ_LockPen(pdcattr->hpen);
pbrushPen = PEN_LockPen(pdcattr->hpen);
if (!pbrushPen)
{
DPRINT1("Arc Fail 1\n");
@ -161,24 +160,24 @@ IntArc( DC *dc,
if (NULL == psurf)
{
DPRINT1("Arc Fail 2\n");
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
SetLastWin32Error(ERROR_INTERNAL_ERROR);
return FALSE;
}
EBRUSHOBJ_vInit(&eboPen, pbrushPen, dc->rosdc.XlatePen);
EBRUSHOBJ_vInit(&dc->eboLine, pbrushPen, dc->rosdc.XlatePen);
if (arctype == GdiTypePie)
{
PUTLINE(CenterX, CenterY, SfCx + CenterX, SfCy + CenterY, eboPen);
PUTLINE(EfCx + CenterX, EfCy + CenterY, CenterX, CenterY, eboPen);
PUTLINE(CenterX, CenterY, SfCx + CenterX, SfCy + CenterY, dc->eboLine);
PUTLINE(EfCx + CenterX, EfCy + CenterY, CenterX, CenterY, dc->eboLine);
}
if (arctype == GdiTypeChord)
PUTLINE(EfCx + CenterX, EfCy + CenterY, SfCx + CenterX, SfCy + CenterY, eboPen);
PUTLINE(EfCx + CenterX, EfCy + CenterY, SfCx + CenterX, SfCy + CenterY, dc->eboLine);
pbrushPen->ptPenWidth.x = PenOrigWidth;
SURFACE_UnlockSurface(psurf);
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
DPRINT("IntArc Exit.\n");
return ret;
}

View file

@ -960,11 +960,15 @@ NtGdiSelectBitmap(
DC_UnlockDc(pDC);
return NULL;
}
hOrgBmp = pDC->rosdc.hBitmap;
/* Release the old bitmap, lock the new one and convert it to a SURF */
pDC->rosdc.hBitmap = hBmp;
/* Release the old bitmap */
if (pDC->dclevel.pSurface)
SURFACE_ShareUnlockSurface(pDC->dclevel.pSurface);
// If Info DC this is zero and pSurface is moved to DC->pSurfInfo.
pDC->dclevel.pSurface = psurfBmp;
psurfBmp->hDC = hDC;
@ -985,6 +989,9 @@ NtGdiSelectBitmap(
0,
psurfBmp->SurfObj.sizlBitmap.cx,
psurfBmp->SurfObj.sizlBitmap.cy);
/* Keep a shared reference on the bitmap */
GDIOBJ_IncrementShareCount((POBJ)psurfBmp);
SURFACE_UnlockSurface(psurfBmp);
/* Regenerate the XLATEOBJs. */
@ -999,7 +1006,7 @@ NtGdiSelectBitmap(
BRUSH_UnlockBrush(pbrush);
}
pbrush = PENOBJ_LockPen(pdcattr->hpen);
pbrush = PEN_LockPen(pdcattr->hpen);
if (pbrush)
{
if (pDC->rosdc.XlatePen)
@ -1007,7 +1014,7 @@ NtGdiSelectBitmap(
EngDeleteXlate(pDC->rosdc.XlatePen);
}
pDC->rosdc.XlatePen = IntGdiCreateBrushXlate(pDC, pbrush, &bFailed);
PENOBJ_UnlockPen(pbrush);
PEN_UnlockPen(pbrush);
}
DC_UnlockDc(pDC);

View file

@ -2422,8 +2422,6 @@ DC_AllocDC(PUNICODE_STRING Driver)
}
pdcattr = NewDC->pdcattr;
NewDC->BaseObject.hHmgr = (HGDIOBJ) hDC; // Save the handle for this DC object.
xformTemplate.eM11 = 1.0f;
xformTemplate.eM12 = 0.0f;
xformTemplate.eM21 = 0.0f;
@ -2461,9 +2459,18 @@ DC_AllocDC(PUNICODE_STRING Driver)
pdcattr->crBrushClr = RGB( 255, 255, 255 );
//// This fixes the default brush and pen settings. See DC_InitDC.
/* Create the default fill brush */
pdcattr->hbrush = NtGdiGetStockObject( WHITE_BRUSH );
NewDC->dclevel.pbrFill = BRUSH_ShareLockBrush(pdcattr->hbrush);
EBRUSHOBJ_vInit(&NewDC->eboFill, NewDC->dclevel.pbrFill, NULL);
/* Create the default pen / line brush */
pdcattr->hpen = NtGdiGetStockObject( BLACK_PEN );
////
NewDC->dclevel.pbrLine = PEN_ShareLockPen(pdcattr->hpen);
EBRUSHOBJ_vInit(&NewDC->eboLine, NewDC->dclevel.pbrFill, NULL);
pdcattr->hlfntNew = NtGdiGetStockObject(SYSTEM_FONT);
TextIntRealizeFont(pdcattr->hlfntNew,NULL);
@ -2743,7 +2750,7 @@ IntIsPrimarySurface(SURFOBJ *SurfObj)
{
return FALSE;
}
return SurfObj->hsurf == PrimarySurface.pSurface;
return SurfObj->hsurf == PrimarySurface.pSurface; // <- FIXME: WTF?
}
//
@ -3466,4 +3473,157 @@ NtGdiMakeInfoDC(
return FALSE;
}
VOID
FASTCALL
DC_vUpdateFillBrush(PDC pdc)
{
PDC_ATTR pdcattr = pdc->pdcattr;
PBRUSH pbrFill;
XLATEOBJ *pxlo;
ULONG iSolidColor;
/* Check if update of eboFill is needed */
if (pdcattr->ulDirty_ & DIRTY_FILL)
{
/* ROS HACK, should use surf xlate */
pxlo = pdc->rosdc.XlatePen;
/* Check if the brush handle has changed */
if (pdcattr->hbrush != pdc->dclevel.pbrFill->BaseObject.hHmgr)
{
/* Try to lock the new brush */
pbrFill = BRUSH_ShareLockBrush(pdcattr->hbrush);
if (pbrFill)
{
/* Unlock old brush, set new brush */
BRUSH_ShareUnlockBrush(pdc->dclevel.pbrFill);
pdc->dclevel.pbrFill = pbrFill;
/* Update eboFill, realizing it, if needed */
EBRUSHOBJ_vUpdate(&pdc->eboFill, pbrFill, pxlo);
}
else
{
/* Invalid brush handle, restore old one */
pdcattr->hbrush = pdc->dclevel.pbrFill->BaseObject.hHmgr;
}
}
/* Check for DC brush */
if (pdcattr->hbrush == StockObjects[DC_BRUSH])
{
/* Translate the color to the target format */
iSolidColor = XLATEOBJ_iXlate(pxlo, pdcattr->crPenClr);
/* Update the eboFill's solid color */
EBRUSHOBJ_vSetSolidBrushColor(&pdc->eboFill, iSolidColor);
}
/* Clear flag */
pdcattr->ulDirty_ &= ~DIRTY_FILL;
}
}
VOID
FASTCALL
DC_vUpdateLineBrush(PDC pdc)
{
PDC_ATTR pdcattr = pdc->pdcattr;
PBRUSH pbrLine;
XLATEOBJ *pxlo;
ULONG iSolidColor;
/* Check if update of eboLine is needed */
if (pdcattr->ulDirty_ & DIRTY_LINE)
{
/* ROS HACK, should use surf xlate */
pxlo = pdc->rosdc.XlatePen;
/* Check if the pen handle has changed */
if (pdcattr->hpen != pdc->dclevel.pbrLine->BaseObject.hHmgr)
{
/* Try to lock the new pen */
pbrLine = BRUSH_ShareLockBrush(pdcattr->hpen);
if (pbrLine)
{
/* Unlock old brush, set new brush */
BRUSH_ShareUnlockBrush(pdc->dclevel.pbrLine);
pdc->dclevel.pbrLine = pbrLine;
/* Update eboLine, realizing it, if needed */
EBRUSHOBJ_vUpdate(&pdc->eboLine, pbrLine, pxlo);
}
else
{
/* Invalid pen handle, restore old one */
pdcattr->hpen = pdc->dclevel.pbrLine->BaseObject.hHmgr;
}
}
/* Check for DC pen */
if (pdcattr->hpen == StockObjects[DC_PEN])
{
/* Translate the color to the target format */
iSolidColor = XLATEOBJ_iXlate(pxlo, pdcattr->crPenClr);
/* Update the eboLine's solid color */
EBRUSHOBJ_vSetSolidBrushColor(&pdc->eboLine, iSolidColor);
}
/* Clear flag */
pdcattr->ulDirty_ &= ~DIRTY_LINE;
}
}
VOID
FASTCALL
DC_vUpdateTextBrush(PDC pdc)
{
PDC_ATTR pdcattr = pdc->pdcattr;
XLATEOBJ *pxlo;
ULONG iSolidColor;
/* Check if update of eboText is needed */
if (pdcattr->ulDirty_ & DIRTY_TEXT)
{
/* ROS HACK, should use surf xlate */
pxlo = pdc->rosdc.XlatePen;
/* Translate the color to the target format */
iSolidColor = XLATEOBJ_iXlate(pxlo, pdcattr->crForegroundClr);
/* Update the eboText's solid color */
EBRUSHOBJ_vSetSolidBrushColor(&pdc->eboText, iSolidColor);
/* Clear flag */
pdcattr->ulDirty_ &= ~DIRTY_TEXT;
}
}
VOID
FASTCALL
DC_vUpdateBackgroundBrush(PDC pdc)
{
PDC_ATTR pdcattr = pdc->pdcattr;
XLATEOBJ *pxlo;
ULONG iSolidColor;
/* Check if update of eboBackground is needed */
if (pdcattr->ulDirty_ & DIRTY_BACKGROUND)
{
/* ROS HACK, should use surf xlate */
pxlo = pdc->rosdc.XlatePen;
/* Translate the color to the target format */
iSolidColor = XLATEOBJ_iXlate(pxlo, pdcattr->crBackgroundClr);
/* Update the eboBackground's solid color */
EBRUSHOBJ_vSetSolidBrushColor(&pdc->eboBackground, iSolidColor);
/* Clear flag */
pdcattr->ulDirty_ &= ~DIRTY_BACKGROUND;
}
}
/* EOF */

View file

@ -96,7 +96,7 @@ IntGdiPolygon(PDC dc,
/* Special locking order to avoid lock-ups */
pbrushFill = BRUSH_LockBrush(pdcattr->hbrush);
pbrushLine = PENOBJ_LockPen(pdcattr->hpen);
pbrushLine = PEN_LockPen(pdcattr->hpen);
psurf = SURFACE_LockSurface(dc->rosdc.hBitmap);
/* FIXME - psurf can be NULL!!!! don't assert but handle this case gracefully! */
ASSERT(psurf);
@ -154,7 +154,7 @@ IntGdiPolygon(PDC dc,
}
}
if (pbrushLine)
PENOBJ_UnlockPen(pbrushLine);
PEN_UnlockPen(pbrushLine);
}
SURFACE_UnlockSurface(psurf);
@ -252,7 +252,7 @@ NtGdiEllipse(
if (pdcattr->ulDirty_ & DC_PEN_DIRTY)
IntGdiSelectPen(dc,pdcattr->hpen);
pbrush = PENOBJ_LockPen(pdcattr->hpen);
pbrush = PEN_LockPen(pdcattr->hpen);
if (!pbrush)
{
DPRINT1("Ellipse Fail 1\n");
@ -333,7 +333,7 @@ NtGdiEllipse(
pbrush);
pbrush->ptPenWidth.x = PenOrigWidth;
PENOBJ_UnlockPen(pbrush);
PEN_UnlockPen(pbrush);
DC_UnlockDc(dc);
DPRINT("Ellipse Exit.\n");
return ret;
@ -580,7 +580,7 @@ IntRectangle(PDC dc,
/* Special locking order to avoid lock-ups! */
pbrushFill = BRUSH_LockBrush(pdcattr->hbrush);
pbrushLine = PENOBJ_LockPen(pdcattr->hpen);
pbrushLine = PEN_LockPen(pdcattr->hpen);
if (!pbrushLine)
{
ret = FALSE;
@ -658,7 +658,7 @@ cleanup:
BRUSH_UnlockBrush(pbrushFill);
if (pbrushLine)
PENOBJ_UnlockPen(pbrushLine);
PEN_UnlockPen(pbrushLine);
if (psurf)
SURFACE_UnlockSurface(psurf);
@ -746,7 +746,7 @@ IntRoundRect(
if (pdcattr->ulDirty_ & DC_PEN_DIRTY)
IntGdiSelectPen(dc,pdcattr->hpen);
pbrushLine = PENOBJ_LockPen(pdcattr->hpen);
pbrushLine = PEN_LockPen(pdcattr->hpen);
if (!pbrushLine)
{
/* Nothing to do, as we don't have a bitmap */
@ -816,7 +816,7 @@ IntRoundRect(
pbrushLine);
pbrushLine->ptPenWidth.x = PenOrigWidth;
PENOBJ_UnlockPen(pbrushLine);
PEN_UnlockPen(pbrushLine);
return ret;
}

View file

@ -1013,16 +1013,6 @@ GDIOBJ_ShareLockObj(HGDIOBJ hObj, DWORD ExpectedType)
return Object;
}
VOID INTERNAL_CALL
GDIOBJ_ShareUnlockObjByPtr(POBJ Object)
{
if (InterlockedDecrement((PLONG)&Object->ulShareCount) < 0)
{
DPRINT1("Trying to unlock non-existant object\n");
}
}
BOOL INTERNAL_CALL
GDIOBJ_OwnedByCurrentProcess(HGDIOBJ ObjectHandle)
{

View file

@ -144,11 +144,11 @@ IntGdiLineTo(DC *dc,
Bounds.bottom = max(Points[0].y, Points[1].y);
/* get BRUSH from current pen. */
pbrushLine = PENOBJ_LockPen( pdcattr->hpen );
pbrushLine = PEN_LockPen( pdcattr->hpen );
if (!pbrushLine)
{
/* default to BLACK_PEN */
pbrushLine = PENOBJ_LockPen(NtGdiGetStockObject(BLACK_PEN));
pbrushLine = PEN_LockPen(NtGdiGetStockObject(BLACK_PEN));
ASSERT(pbrushLine);
}
@ -165,7 +165,7 @@ IntGdiLineTo(DC *dc,
}
SURFACE_UnlockSurface(psurf);
PENOBJ_UnlockPen( pbrushLine );
PEN_UnlockPen( pbrushLine );
}
if (Ret)
@ -268,7 +268,7 @@ IntGdiPolyline(DC *dc,
IntGdiSelectPen(dc,pdcattr->hpen);
/* Get BRUSHOBJ from current pen. */
pbrushLine = PENOBJ_LockPen(pdcattr->hpen);
pbrushLine = PEN_LockPen(pdcattr->hpen);
/* FIXME - pbrushLine can be NULL! Don't assert here! */
ASSERT(pbrushLine);
@ -309,7 +309,7 @@ IntGdiPolyline(DC *dc,
}
}
PENOBJ_UnlockPen(pbrushLine);
PEN_UnlockPen(pbrushLine);
return Ret;
}

View file

@ -29,7 +29,7 @@
PBRUSH
FASTCALL
PENOBJ_LockPen(HGDIOBJ hBMObj)
PEN_LockPen(HGDIOBJ hBMObj)
{
if (GDI_HANDLE_GET_TYPE(hBMObj) == GDI_OBJECT_TYPE_EXTPEN)
return GDIOBJ_LockObj( hBMObj, GDI_OBJECT_TYPE_EXTPEN);
@ -37,6 +37,16 @@ PENOBJ_LockPen(HGDIOBJ hBMObj)
return GDIOBJ_LockObj( hBMObj, GDI_OBJECT_TYPE_PEN);
}
PBRUSH
FASTCALL
PEN_ShareLockPen(HGDIOBJ hBMObj)
{
if (GDI_HANDLE_GET_TYPE(hBMObj) == GDI_OBJECT_TYPE_EXTPEN)
return GDIOBJ_ShareLockObj( hBMObj, GDI_OBJECT_TYPE_EXTPEN);
else
return GDIOBJ_ShareLockObj( hBMObj, GDI_OBJECT_TYPE_PEN);
}
HPEN APIENTRY
IntGdiExtCreatePen(
DWORD dwPenStyle,
@ -68,11 +78,11 @@ IntGdiExtCreatePen(
if (bOldStylePen)
{
pbrushPen = PENOBJ_AllocPenWithHandle();
pbrushPen = PEN_AllocPenWithHandle();
}
else
{
pbrushPen = PENOBJ_AllocExtPenWithHandle();
pbrushPen = PEN_AllocExtPenWithHandle();
}
if (!pbrushPen)
@ -173,17 +183,17 @@ IntGdiExtCreatePen(
default:
DPRINT1("IntGdiExtCreatePen unknown penstyle %x\n", dwPenStyle);
}
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
return hPen;
ExitCleanup:
SetLastWin32Error(ERROR_INVALID_PARAMETER);
pbrushPen->pStyle = NULL;
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
if (bOldStylePen)
PENOBJ_FreePenByHandle(hPen);
PEN_FreePenByHandle(hPen);
else
PENOBJ_FreeExtPenByHandle(hPen);
PEN_FreeExtPenByHandle(hPen);
return NULL;
}
@ -192,14 +202,14 @@ IntGdiSetSolidPenColor(HPEN hPen, COLORREF Color)
{
PBRUSH pbrushPen;
pbrushPen = PENOBJ_LockPen(hPen);
pbrushPen = PEN_LockPen(hPen);
if (pbrushPen)
{
if (pbrushPen->flAttrs & GDIBRUSH_IS_SOLID)
{
pbrushPen->BrushAttr.lbColor = Color & 0xFFFFFF;
}
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
}
}
@ -282,14 +292,14 @@ IntGdiSelectPen(
pdcattr = pDC->pdcattr;
pbrushPen = PENOBJ_LockPen(hPen);
pbrushPen = PEN_LockPen(hPen);
if (pbrushPen == NULL)
{
return NULL;
}
XlateObj = IntGdiCreateBrushXlate(pDC, pbrushPen, &bFailed);
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
if (bFailed)
{
SetLastWin32Error(ERROR_NO_SYSTEM_RESOURCES);

View file

@ -118,7 +118,7 @@ IntCreateStockPen( DWORD dwPenStyle,
ULONG ulColor)
{
HPEN hPen;
PBRUSH pbrushPen = PENOBJ_AllocPenWithHandle();
PBRUSH pbrushPen = PEN_AllocPenWithHandle();
if ((dwPenStyle & PS_STYLE_MASK) == PS_NULL) dwWidth = 1;
@ -143,7 +143,7 @@ IntCreateStockPen( DWORD dwPenStyle,
break;
}
hPen = pbrushPen->BaseObject.hHmgr;
PENOBJ_UnlockPen(pbrushPen);
PEN_UnlockPen(pbrushPen);
return hPen;
}