Skip to content
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

Patches using Single Trigger do not work correctly with Ableton Live 11 Beta and MPE #3776

Closed
sourcebox opened this issue Jan 31, 2021 · 18 comments
Labels
Bug Report Item submitted using the Bug Report template Host Specific Issues related to specific host(s) or host features
Milestone

Comments

@sourcebox
Copy link

Bug Description:
When using the current Live 11 Beta, any patch using single trigger mode will not trigger envelope states correctly when MPE is enabled in Live.

Surge Version
1.8.1

  • Version:
  • Plugin Type: VST3
  • Bitness: 64-bit

Reproduction Steps:
Steps to reproduce the behavior:

  1. Select patch Claes/Basses/Dist Bass 2
  2. Make sure MPE is enabled in Live (shown in upper right corner of the device)
  3. Play some notes with legato
  4. At some point no notes will be triggered anymore, played notes do not release correctly
  5. Disable MPE in Live (with context menu of device - right-click)
  6. Reload the patch at try again. All notes are playing correctly.

Computer Information (please complete the following information):

  • OS: macOS 10.13
  • Host: Ableton Live
  • Version: Live 11.0b25
@sourcebox sourcebox added the Bug Report Item submitted using the Bug Report template label Jan 31, 2021
@baconpaul
Copy link
Collaborator

When you enable MPE in live do you also enable it in surge? Sending MPE messages to a non-MPE surge will give inconsistent behavior. To enable MPE click the button labeled “MPE” next to the patch browser and make sure it is lit.

@sourcebox
Copy link
Author

Enabling MPE in Surge does the job. Unfortunately, MPE seems to be enabled in Live 11 by default when the VST supports it. So I think, more people will run into this issue. Is there a way to dynamically report it to the host?

@baconpaul
Copy link
Collaborator

Maybe! That was the next thing I was going to check.

https://steinbergmedia.github.io/vst3_doc/vstinterfaces/classSteinberg_1_1Vst_1_1IVst3WrapperMPESupport.html

My guess is I have to implement that interface. Lemme tag this into our 182 milestone.

@baconpaul baconpaul added this to the 1.8.2 milestone Jan 31, 2021
@mkruselj
Copy link
Collaborator

This also needs to be reported to Live I think. Live should send certain RPN messages so that plugins that respond to those can automatically set themselves up properly. Surge responds to those RPN messages.

@baconpaul
Copy link
Collaborator

ahh and live 11 beta is only available to owners of live, of which i am not one.

@sourcebox i may ask you to test a nightly in the next week or two. Would you be willing to help with that?

@sourcebox
Copy link
Author

@baconpaul Of course, I will help you as much as I can.

@baconpaul
Copy link
Collaborator

Super; I won't get to it this afternoon but will update with that API above soon.

And as @mkruselj said I think you may want give live beta team feedback that either they didn't send surge an RPN message to trigger MPE or they sent a malformed one or we received a malformed one or we interpreted it wrong (one of those four!). Feel free to point their devs at this ticket too!

@sourcebox
Copy link
Author

@baconpaul I just filed a bug report at their tracker that refers to this thread.

@baconpaul
Copy link
Collaborator

Great
I'm happy to debug it also if they can just get me a copy of the live beta to run. It's either an RPN error, me not implementing that API, or them not sending something. But if they don't, then I"m also happy to try implementing that API in the dark, adding a bit of logging, and sending you a VST3 to test :)

@mkruselj mkruselj added MPE Host Specific Issues related to specific host(s) or host features labels Jan 31, 2021
@sourcebox
Copy link
Author

I got a reply from Ableton that they could reproduce the issue and have tracked it internally. So I suggest we put this on hold and wait if they come up with some fix in one their next updates.

@baconpaul
Copy link
Collaborator

wonderful

@baconpaul
Copy link
Collaborator

Hi @sourcebox - I see the live 11 release is tagged for late Feb. Have you had any luck resolving this with their devs?

Thanks!

@sourcebox
Copy link
Author

@baconpaul There have been some beta releases over the last 2 weeks, but none of them addresses the issue. I made a quick test whenever a new beta came out. The ticket is still open in the their tracker but I can't look into any details.

@baconpaul
Copy link
Collaborator

So I downloaded live 11 trial today

at load time:

  1. It loads surge with live setting it to MPE mode
  2. It sends surge no NPRN messages to activate MPE
  3. It doesn't call the VST3 API to activate MPE

so I suspect this is still a problem. I hear that other plugin devs are also struggling with same so I'll keep my eye out.

@mab-ableton
Copy link

Hi, Ableton dev here. We've implemented a fix which sends the RPN message sequence to plugins when we want them to be in MPE mode. I've tested it with Surge and it seems to work fine (i.e., Surge places itself into MPE mode when we send it the RPN to turn on the lower zone for MPE, and it clears this setting when we send the RPN to deactivate MPE). This was unfortunately too late to make it into the 11.0 release, but it will be in our first bugfix release (most likely version 11.0.5), which should go into beta within a couple weeks.

A couple quick questions:

  1. Do you know of other plugins that respond to this RPN? In my testing, Surge was the only such plugin I found.
  2. Some of the comments above mention a VST3 API which is supposed to get called to activate MPE. Can someone point me at that API, so we can call that as well? (The VST3 version of Surge already seems to respond correctly to the RPN, but we'd like to ideally do everything we can to make sure plugins' MPE mode is correctly synched to Live's).

Thanks!

@baconpaul
Copy link
Collaborator

Hi @mab-ableton thank you for dropping in here! I am not sure, but I think equator may respond to those messages?

https://steinbergmedia.github.io/vst3_doc/vstinterfaces/classSteinberg_1_1Vst_1_1IVst3WrapperMPESupport.html

The VST3 API I tried was that one. But it didn't seem like Live 11 called my function.

I've also pinned a message to our users for now to make sure surge and live MPE are in sync by hand. But when 11.05 ships I can tell them to upgrade instead :)

while I have your attention, by the way: Is there a program for devs to get NFR live copies? I'm a logic pro user myself so have a demo I can't save in for testing. No big deal if not but thought I'd ask.

@baconpaul
Copy link
Collaborator

Oh and to be clear: since live didn't call that function, I didn't merge the change which has an implementation of it. And I wasn't 100% sure it was right (the VST3 api is large and full of corners).

@baconpaul
Copy link
Collaborator

I’m actually going to close this issue since its fixed in 11.05 and we’ve updated our faq and help channels in the interim. Thanks again for the help @mab-ableton and if you do end up coding another approach to indicate MPE pls do let me know and I can mod surge.

Best

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Report Item submitted using the Bug Report template Host Specific Issues related to specific host(s) or host features
Projects
None yet
Development

No branches or pull requests

4 participants