[Xquartz-dev] Porting XCopyArea to plain OS X

Jeremy Huddleston jeremyhu at apple.com
Wed May 13 08:06:37 PDT 2009


I just realized I forgot to ask...

have you tried the SIMD accelerated blt in pixman?

On May 13, 2009, at 07:45, Jeremy Huddleston wrote:

> XPlugin is really a quick and dirty way for us to get access to some  
> of CoreGraphics internals.  There are bits of the CoreGraphics API  
> that are not public and fluctuate between OS releases.  Xplugin  
> gives us an abstraction layer for these parts of the CoreGraphics  
> API as well as other similar internal API that the Xserver needs  
> access to.
>
> xp_copy_bytes just does a CG blt/copy (one buffer to the other).    
> Similarly, xp_fill_bytes just asks CG to blt/fill (set all 4byte  
> words to a given value).
>
> The buffer format conversion used to also be accelerated (in  
> rlAccel), but that is now handled in by pixman.  Furthermore, it  
> looks like only ppc benefitted from our image conversion  
> acceleration since it required a ppc codepath.
>
> This code came from a time when the Xserver didn't have decent blt  
> or image conversion.  I think pixman's SIMD format conversion is  
> good enough that we can continue using it by default.  Furthermore,  
> if CG can give us an edge on the buffer format conversion, then we  
> should accelerate pixman directly so cairo/quartz gets the benefit  
> as well.
>
> As for your "what to do for native apps" ... well the reason we need  
> libXplugin is because there isn't an exposed fast path in the public  
> CoreGraphics API (atleast not that I know of in Leopard).  You can  
> always use libXplugin if you're hacking something together for your  
> own use and don't mind if the API changes on you and you need to  
> recompile (see the warning in the header file).  That being said,  
> Codeweavers relies on Xplugin for their Xserver, so the API won't  
> change unless both CW and Apple don't need certain functionality any  
> more.
>
> libXplugin is really *FOR* the Xserver.  If you try using it for  
> something else, I won't intentionally break your app, but I won't  
> support its use either.
>
>
> On May 13, 2009, at 02:25, Platon Fomichev wrote:
>
>> Dear Jeremy
>>
>> Here is a bit more wordy explanation about what I am interested in:
>>
>> First of all I am completely oblivious to internal X server code  
>> structure so please bare with me. What I am looking at is at xorg- 
>> server-1.4.2-apple42/hw/xquartz/xpr/xprFrame.c file where there is  
>> a pointer callback structure:
>> static RootlessFrameProcsRec xprRootlessProcs, where there is a  
>> xp_copy_bytes function supplied as an accelerated version for  
>> blitting stuff. All in all the code in xorg-server-1.4.2-apple42/hw/ 
>> xquartz is heavily filled with xp_ funcs. So I guess the first  
>> question is - what code I should be looking at?
>>
>> Next one is as follows: if not xp* funcs what technology do you use  
>> to blit fast to screen? I don't think you're allocating and  
>> dropping CImage's or something in that way - it's too slow, thus  
>> you're probably using something to do quick drawings and you can  
>> somehow get to the 'raw' pixel data for window backing store  
>> somehow. Am I right? If yes, how do you do this?
>>
>> The last question was about not XCopyArea for X11 which is O.K. but  
>> about an analogue of XCopyArea written for OS X without any X11  
>> support. Suppose I am porting X11 application to pure OS X what can  
>> you advise me to use to emulate XCopyArea with source being the  
>> window. Here I desperately need your expertise because there does  
>> not seem to be a convinient way to do so on OS X (or may be I am  
>> mistaken).
>>
>> Last question how do I get very quickly the bitmap bits for the  
>> particular window on screen? Getting it using Cocoa is very slow.  
>> Using QuickDraw is not an option.. So what to do?
>>
>> Best regards,
>>           Platon
>>
>> _______________________________________________
>> Xquartz-dev mailing list
>> Xquartz-dev at lists.macosforge.org
>> http://lists.macosforge.org/mailman/listinfo.cgi/xquartz-dev
>
> _______________________________________________
> Xquartz-dev mailing list
> Xquartz-dev at lists.macosforge.org
> http://lists.macosforge.org/mailman/listinfo.cgi/xquartz-dev



More information about the Xquartz-dev mailing list