-
-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
msvc #4384
msvc #4384
Conversation
+locale: using path instead of individual files to reduce command line size +remotevstplugin: changed order return type & calling convention (compiler error) +lmmsobj: removed single quotes for command line defines
+added toolchain file +added toolset
+carla: exports header +package_linux: corrected RemoteVstPlugin name +vstbase: toolchain file conditional on MSVC
todo: volume too loud? clipping
*switched temp switched zynaddsubfx submodule *updated code to work with msvc
-dependency jackaudio & jackmidi (caused crash on exit) +jack midi out
Parroting one comment from the PR on lmms's zyn fork. std::vector should NOT appear in realtime code. LMMS has numerous problems in terms of realtime safety already and it should not make the situation worse for itself. |
Right, std::vector internally calls malloc() while original code uses stack pointer advance. |
Or just use MSVC 2017, which to the best of my knowledge supports VLAs. |
If I recall correctly, MSVC 2017 doesn't support VLAs either, which is also what the documentation says. We can use |
@lukas-w the linked page is dated 11/04/2016. |
@fundamental Good catch. :) |
Additionally QVarLengthArray does fall back onto using malloc()/free() in some cases. |
@fundamental I'd argue that falling back to |
It doesn't. edit: not making a judgement call whether this is good/bad or anything. |
We're getting a bit off track by focusing on the details. I did this in the first place to have debug symbols. (feel free to skip the rest, it's only an example why debug symbols are important to me) The latest commit to lmms in this PR is an example of that (jack midi thing), it took me literally less than 5 minutes to find the cause. Lmms crashed on exit, I attached visual studio and I could navigate the call stack with source code displayed. I've compiled all the libs lmms is using with debug information. It crashed inside jack, I have jack compiled with debug info so I know where it crashed in jack. Going up the stack frame, I saw it was called from a destructor of MidiJack (typing from memory, so the names might be wrong). Further up the stack: mixer destructor was called which destroyed audiojack first and midijack shared the connection with audiojack. |
Build with -g -rdynamic should produce good call stacks on linux too. But I think it's good to support msvc using alloca. |
Here's the latest. It's flawed (read TODO notes). It works with 2015. Depending on the merge in zynaddsubfx repo, you might have to change some links.
I'll make a new branch, so you can pick and choose what modification you accept (if any). I haven't tested it on linux.