Home > Mac OS X > Porting Multithreaded Apps from Win32 to Mac OS XPorting Multithreaded Apps from Win32 to Mac OS X Eugenia Loli 2005-06-29 Mac OS X 14 CommentsThis article provides details on how OS X handles multithreading to help port your Win32 application.About The Author Eugenia LoliEx-programmer, ex-editor in chief at OSNews.com, now a visual artist/filmmaker.Follow me on Twitter @EugeniaLoli 14 Comments 2005-06-30 12:02 am Not a bad article. Those in the Linux world who haven’t used threads much might find this a good primer too… 2005-06-30 2:00 am Apple is bringing their hardware right under the more massive x86 code base.A triple OS box is just too irresistible for professionals to ignore.Apple is giving away WebObjects for free, a previously $50,000 programhttp://www.macworld.co.uk/news/index.cfm?NewsID=11860 2005-06-30 5:11 am nice summery of the subject, didn’t go into alot of the finer details but did a good job.it suprizes me that developers don’t use more cross platform api’s.its quite simple to write threads apps that run on BeOS, QNX, fBSD, Sun, AtheOS, Windows and a hand full of other OS’ without much work.with toolkits like Qt and hand rolled ones (like the one i’ve done for my company) its odd that some devs still shy away from writing cross platform frendly code.i have made it our companies policy to have at least 3 OS impimentations. It not only provides a good way to Objectify code but it also is a extreamly helpfull debuging tool. I have found that many OS’s implementations fo thread libs, mutex, time, etc are verry differant in what types of “errors” they catch and what type of debug info they offer up.it also teaches one the value of seperation of GUI and logic … which i am a big fan of 2005-06-30 5:28 am Excuse me, bludger, but did you imagine for a second that maybe Doom 3, UT, quake may be limited by something more than the CPU? From my experience, it seems like part of the problem with Mac games has been unoptimized porting, the quality of the video drivers compared to Wintel drivers, and the Mach-O kernel that OSX is based on.Also, if you look up Quake 3, you’ll see that the Quake port was highly optimized, and runs better on macs than comparable pcs. I haven’t tested this, since I’m not really a gamer, but this is what I’ve read.And furthermore, can you imagine that there are people who aren’t buying computers purely for videogames? I know I didn’t get my mac mini for that…Lastly, OSX runs on x86, so your whole arguement goes out the window.Have fun in the dark, buddy… 2005-06-30 9:09 am No the biggest problem with porting games from Windows to OSX is the fact a lot of them require DirectX now and not OpenGL. If you want them to run on OSX you need to have them be able to use OpenGL such as World of Warcraft. Which as anyone can tell you at least on Windows if you edit your Config.wtf to use OpenGL it is much slower which is why it is slower on OSX. 2005-06-30 10:25 am Open GL is also rooted in the kernel, which gives us benefts of running a game in a window for instance, but at a performance penalty.On my DP G5 I can actively play 2 3D games at once over 40 fps each, naturally I can only use one keyboard so one game is in spectator mode.http://homepage.mac.com/hogfish/PhotoAlbum2.htmlOther pictures where I got 3 3D games going is just rotating between each at will, it pays to have plenty of RAM and a DP. 2005-06-30 10:47 am I know it’s considered bad form to point out spelling errors, but jeez – here is a list from Y’s post.suprizesalot (ok, a typo)impimentationsextreamlyhelpfulldebugingverry differantseperationPeace 2005-06-30 10:49 am I missed one:summery 2005-06-30 12:23 pm Not a bad article. Those in the Linux world who haven’t used threads much might find this a good primer too…>>You’re assuming someone would be interested in porting anything to OSX 2005-06-30 12:27 pm “its quite simple to write threads apps that run on BeOS, QNX, fBSD, Sun, AtheOS, Windows and a hand full of other OS’ without much work.”You are right, except for BeOS — BeOS has no pthreads, so unless we are talking for a project that doesn’t do much thread synchronisation (and then you could easily add a BeOS native threads code path), threading code written in pthreads does indeed work on every operating system you listed (not sure about AtheOS, but its Syllable derivative does have pthreads now), but with the exception of BeOS.I’d like your input though — it’s interesting how you support BeOS. 2005-06-30 4:27 pm I think that MacOs X have support for pthreads library… but I don’t know if MS Widows have this support too….Does Windows support pthreads library?BSDero 2005-06-30 5:40 pm MacOS X pthreads support has been fairly broken prior to 10.3; Windows has through (thanks to open source programmers) http://sources.redhat.com/pthreads-win32/ 2005-07-01 12:01 am No, I wasn’t assuming that at all…This article gives you a good look at how threads in Win32, *nix (POSIX) & 2 flavours of Apple, and gives you a pretty good “intro” of each. If I was just starting Linux dev and needed a quick look at how threads work, esp. if porting from Win32, then this article wouldn’t be a waste of time to look at. I wasn’t saying it was the article to look at, there are plenty of good ones out there.I’ve coded threads on Win32 (C++ and Delphi (native and Win32 style depending on the circumstance or how lazy I was) and Java), so appreciated some of the areas raised by this article, that’s all I was saying I guess… 2005-07-01 7:36 pm Hm, no response re BeOS.I agree and can relate to your other points re multiple OS porting and separation of GUI logic and core functionality logic. This is the error-proof and scalable way to go when possible.