On 17-Dec-06, at 12:12 AM, Ian Lynagh wrote:

Hi all,

Is anyone else seeing a failure with the HEAD linking the stage2 GHC on Windows (XP Pro)? This is under cygwin, and I can build 6.6 fine. Anyone
got any idea what's going wrong?

From looking at the code, my guess is that this is a severe case of Calling Convention Confusion.

GetWindowsDirectoryW and GetSystemDirectoryW are declared as ccall, and I think they should be stdcall like everything else.

As far as DeleteObject is concerned, Types.hs has a 'foreign import stdcall unsafe "windows.h &DeleteObject"'; there are two problems with this:

a) The stdcall modifier is ignored by GHC, the compiler generates a ref to DeleteObject, not [EMAIL PROTECTED] as it should. I think this is our link error.

GHC would need to look at the imported thing's FunPtr type to determine the argument size, and complain if a non-function is imported as "stdcall".

b) A pointer to a stdcall function (DeleteObject) is used where a pointer to a ccall function is expected (ForeignPtr finaliser). AFAICT, this is supposed to cause cause quite horrible crashes (stack corruption), and we should really be glad about that link error.

So, I think those Get*DirectoyW functions need to be stdcalled, and DeleteObject needs a ccalled wrapper in cbits.

I have no idea why things worked with ghc-6.6. Are all those functions unused in 6.6?


Hope that helps,

Wolfgang


_______________________________________________
Cvs-ghc mailing list
[EMAIL PROTECTED]
http://www.haskell.org/mailman/listinfo/cvs-ghc

Reply via email to