Hi,
I have been experimenting with some patchsets for Wine -> based on an implementation of Wine originally developed By Muse Research. It has improved support for a bunch of stuff, fixes (most) bottlenecks for Linux proaudio folks making use of Wine + Jack, and also contains some bug fixes for wine (that may or may not be acceptable to wine-devs.)
I have a project that now lives on SF.net, but has been running for months now, on my machine(s), locally. It's called L-ProAudio, and the version of wine (L_pa-Wine) is geared towards proaudio users. We also have support in 1 linux application ~ which now properly handles the new method of mapping win/prio -> linux/prio. Some of the patchset fixes synchronization issues (with jack), disk geomtery-io-syscl, fixes rendering bugs in VSTs (probably other apps too) and a bunch of other improvements (geared for proaudio users).
L_ProAudio SF.net Page: https://sourceforge.net/projects/l-proaudio/
-> Wine-L_Proaudio_Arch_n_patches.tar.gz contains a pkgbuild for Archlinux (like gentoo' ebuild) + all patches (and probably one or two others, not used in my builds).
But please note: this is NOT a fork of Wine. It is necessary for me to be able to run the applications that i want with Wine. I am just carrying patchwork and re-basing it, as time passes. But i decided to release it - since it benefits the larger community who uses this stuff (greatly).
note 2: I am posting, in order to shed light on any improvements/bug fixes that _might_ be suitable for upstream. ~ If so, once a given stable release of Wine is issued, I would then be able to remove them from my patchset, minimizing duplicate efforts, among other things.
The original patches/sources (that i have based my version on, are found here: http://www.museresearch.com/support/receptor-faq.php
...at the bottom of the page / last link: http://www.museresearch.com/support/receptor-faq.php
these patches fix Wine problems (in most areas) for people using linux(-rt) + jack + ProAudio ... but may have other benefits/bug-fixes for wine. It's Gpl'd (obviously), so it would be worthwhile to have a look anyway. - didn't include every patch (some of them aren't of interest to me, outdated, etc).
Take care
Jordan
On Thu, Jan 03, 2013 at 05:22:14PM -0500, jordan wrote:
Hi,
I have been experimenting with some patchsets for Wine -> based on an implementation of Wine originally developed By Muse Research. It has improved support for a bunch of stuff, fixes (most) bottlenecks for Linux proaudio folks making use of Wine + Jack, and also contains some bug fixes for wine (that may or may not be acceptable to wine-devs.)
I have a project that now lives on SF.net, but has been running for months now, on my machine(s), locally. It's called L-ProAudio, and the version of wine (L_pa-Wine) is geared towards proaudio users. We also have support in 1 linux application ~ which now properly handles the new method of mapping win/prio -> linux/prio. Some of the patchset fixes synchronization issues (with jack), disk geomtery-io-syscl, fixes rendering bugs in VSTs (probably other apps too) and a bunch of other improvements (geared for proaudio users).
L_ProAudio SF.net Page: https://sourceforge.net/projects/l-proaudio/
-> Wine-L_Proaudio_Arch_n_patches.tar.gz contains a pkgbuild for Archlinux (like gentoo' ebuild) + all patches (and probably one or two others, not used in my builds).
But please note: this is NOT a fork of Wine. It is necessary for me to be able to run the applications that i want with Wine. I am just carrying patchwork and re-basing it, as time passes. But i decided to release it - since it benefits the larger community who uses this stuff (greatly).
note 2: I am posting, in order to shed light on any improvements/bug fixes that _might_ be suitable for upstream. ~ If so, once a given stable release of Wine is issued, I would then be able to remove them from my patchset, minimizing duplicate efforts, among other things.
The original patches/sources (that i have based my version on, are found here: http://www.museresearch.com/support/receptor-faq.php
...at the bottom of the page / last link: http://www.museresearch.com/support/receptor-faq.php
these patches fix Wine problems (in most areas) for people using linux(-rt) + jack + ProAudio ... but may have other benefits/bug-fixes for wine. It's Gpl'd (obviously), so it would be worthwhile to have a look anyway. - didn't include every patch (some of them aren't of interest to me, outdated, etc).
I looked over them briefly.
0005-Expand-dos-has-entropy-in-order-to-make-collision-le.patch Not sure why this is needed?
0010-If-a-child-of-the-window-being-disabled-is-the-captu.patch a user32.EnableWindow 2008 patch ... is it still needed for you, as quite some enhancements have happened...
Would need review (likely from julliard or other user32 guru) and testcases.
0012-ntdll-Use-pipes-for-synchronization-objects.patch 0050-pipe-check-and-thread-safe-read.patch
A new synchronization method using UNIX pipe(2)s. This is definitely not going in as is...
It would be interesting to know what deficit in regular Wine is fixed by it. wineserver overhead?
0023-improve-IoRegisterDeviceInterface.patch
Remove the MUSE specific fixmes and use the same FIXME() style for stub parameters as in the other FIXME()s. Then its ready for wine-patches I would say.
0025-Add-stub-for-IoSetDeviceInterfaceState.patch Use same FIXME() style as used for other stub functions, then ready for submission.
0027-Add-stub-for-PoSetPowerState.patch Good for submission as-is.
0033-overridable-default-filesystem-type.patch Not submittable as-is ... It would be good to know the reason and/or what MUSE expects.
0044-get-windows-label-from-registry.patch Smells like the wrong place to do it. Perhaps mountmgr.sys, but perhaps different. Also unclear if Alexandre likes it.
0052-NI-drag-and-drop.patch Looks already good for submission to me.
0054-set-realtime-priority-without-wineserver.patch wine-rt-101107.patch Needs design and discussion... So far a RT solution was not accepted for Wine yet.
0061-fix-broken-cross-compiled-winegcc.patch 0063-disable-winedbg-auto-crash-dialog.patch local hacks
0062-disable-crashing-alpha-bitmaps-for-gdb.patch Seems like a mistaken patch that was needed as we had the old DIB sections.
gdb would have accepted "continue" here.
Should not be necessary anymore these days with the DIBENGINE.
add-implementation-setProcessWorkingSetSize.patch Might be submittable as-is.
Might need autoconf checks for non-Linux.
Fix-disk-geometry-ioctl.patch Alexandre usually does not like override files like this unless necessary.
What is actually expected? you mentioned rendering issues?
fix-obscured-windows.patch Hmm, needs user32 windowing guru review.
menu-border-color.patch If this is not just a hack, could be submitted as-is.
prevent-runtime-conntrack-changes.patch A Linux kernel patch? Likely wrong here.
The original patches/sources (that i have based my version on, are found here: http://www.museresearch.com/support/receptor-faq.php
...at the bottom of the page / last link: http://www.museresearch.com/support/receptor-faq.php
these patches fix Wine problems (in most areas) for people using linux(-rt) + jack + ProAudio ... but may have other benefits/bug-fixes for wine. It's Gpl'd (obviously), so it would be worthwhile to have a look anyway. - didn't include every patch (some of them aren't of interest to me, outdated, etc).
I looked over them briefly.
0005-Expand-dos-has-entropy-in-order-to-make-collision-le.patch Not sure why this is needed?
I'm not sure why either, but i am guessing it improves things in a linux-rt/VST setting (in fact, removing it causes regressions on my L_pa systems - so i am keeping it.
0010-If-a-child-of-the-window-being-disabled-is-the-captu.patch a user32.EnableWindow 2008 patch ... is it still needed for you, as quite some enhancements have happened...
Would need review (likely from julliard or other user32 guru) and testcases.
Seems to be, yeah.
0012-ntdll-Use-pipes-for-synchronization-objects.patch 0050-pipe-check-and-thread-safe-read.patch
A new synchronization method using UNIX pipe(2)s. This is definitely not going in as is...
Figured as much :) (that was pretty obvious lol.)
It would be interesting to know what deficit in regular Wine is fixed by it. wineserver overhead?
Yeah, Wineserver is probably the number one thing that slows down when, when you are looking for low-latency / high-performance. (ext4 is also terrible on stock settings).
0023-improve-IoRegisterDeviceInterface.patch
Remove the MUSE specific fixmes and use the same FIXME() style for stub parameters as in the other FIXME()s. Then its ready for wine-patches I would say.
Awesome :) I must have missed that ~ you will notice that i removed them from the new variables used by L_ (didn't want any hassles/trademark issues with Muse).
0025-Add-stub-for-IoSetDeviceInterfaceState.patch Use same FIXME() style as used for other stub functions, then ready for submission.
Great.
0027-Add-stub-for-PoSetPowerState.patch Good for submission as-is.
Great. :)
0033-overridable-default-filesystem-type.patch Not submittable as-is ... It would be good to know the reason and/or what MUSE expects.
You can contact them. They don't seem to get the idea of FOSS - by having our help, they could have _Less_ of a delta they are keeping. But as far as this patch is concerned, i am not sure. (this is why i got in touch with you guys).
0044-get-windows-label-from-registry.patch Smells like the wrong place to do it. Perhaps mountmgr.sys, but perhaps different. Also unclear if Alexandre likes it.
I think for their purposes it probably is though, so i have kept it as well (for now, unless told that i shouldn't for good reason).
0052-NI-drag-and-drop.patch Looks already good for submission to me.
Yeah, it fixes BIG hassles for N.I users like myself.
0054-set-realtime-priority-without-wineserver.patch wine-rt-101107.patch Needs design and discussion... So far a RT solution was not accepted for Wine yet.
Yeah - that is in fact, one of the most important patches for us (linuxaudio folks). The FSThost developer (wraps wineVSTs, single hosted) said it is the 'holy grail' for fixing his software to properly handle windows VSTs and it does so very well :) ~ windows VSTs are highly performant, synchronized and run like normal Jack_cleints without wineserver getting in the way.
0061-fix-broken-cross-compiled-winegcc.patch 0063-disable-winedbg-auto-crash-dialog.patch local hacks
k.
0062-disable-crashing-alpha-bitmaps-for-gdb.patch Seems like a mistaken patch that was needed as we had the old DIB sections.
gdb would have accepted "continue" here. Should not be necessary anymore these days with the DIBENGINE.
Okay, i will try reverting it locally and make sure everything is good.
add-implementation-setProcessWorkingSetSize.patch Might be submittable as-is.
Might need autoconf checks for non-Linux.
good. but i am not the guy to do this ~ i have a _ton_ of work right now, both professionally and for my own projects. I just wanted to make sure anything that _should_ be in wine goes into Wine to improve the experience for everyone.
Fix-disk-geometry-ioctl.patch Alexandre usually does not like override files like this unless necessary.
What is actually expected? you mentioned rendering issues?
I am not sure about this one. it needs investigating but i have it applied. As far as rendering issues, yes upstream wine causes ugly flickering in some apps/VSTs, while L_pa-Wine does not (at all, ever).
fix-obscured-windows.patch Hmm, needs user32 windowing guru review.
probably.
menu-border-color.patch If this is not just a hack, could be submitted as-is.
It's my hack. If using themes in wine (like windows themes) the custom menus often don't work properly, andthe line color often is tied into a color the user cannot change within winecfg ~ so i added a hack to tie it into the desktop color so my themes don't look horrible.
prevent-runtime-conntrack-changes.patch
A Linux kernel patch? Likely wrong here.
yup. (i must have accidently added that).
Thanks Marcus.
I hope some of this stuff is helpful to Wine and CodeWeavers ~ I'm just trying to be a good FOSS citizen :)
Let me know if there is anything more you need from me...
I'll keep my own on release info ~ to see when i can remove certain patches.
Jordan
Also, as a general note Marcus (and any other wine-developer who may be reading this).
If you guys ever happen to come accross patches that may fix issues for me, but aren't suitable for upstream ~ please contact me and pass them along.
since i am targeting a much smaller audience with 'particular' needs, i would like to improve the experience, as best as i can for those purposes.
Thanks again.
Jordan