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

ASIO: add PaAsio_GetSampleRate() function #971

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

Spacechild1
Copy link

@Spacechild1 Spacechild1 commented Oct 21, 2024

PaAsio_GetSampleRate() returns the current sample rate of the specified device at the time of library initialization.
(If the current sample rate is unknown, a sample rate of 0 will be returned.)

For example, this is useful for people who want to use the current sample rate as the default sample rate (which PA's ASIO implementation does not do.)

Actually, I would rather prefer the solution proposed in #970, but if this is not desired, this PR would be an acceptable workaround.

However, the function would still be useful for other purposes, e.g. to select the "current" sample rate - instead of the "default" sample rate - in a UI dialog.

returns the current sample rate of the specified device at the time of library initialization.
If the current sample rate is unknown, a sample rate of 0 will be returned.
@RossBencina RossBencina added the src-asio Steinberg ASIO Host API /src/hostapi/asio label Oct 28, 2024
@philburk philburk added the P3 Priority: Normal label Oct 28, 2024
@RossBencina
Copy link
Collaborator

Phil and I discussed this PR at length today. I think that an argument can be made for providing a way to query the current ASIO device sample rate irrespective of whether it's the optimal fix for #970. We already have PaAsio_SetStreamSampleRate.

A problem with this PR in its current form is that it does not actually query the current device sample rate. It just returns the cached value retrieved at Pa_Initialize time. Thus if the sample rate is changed asynchronously (e.g a change to a front panel switch, or incoming wordclock) the proposed implementation will return an incorrect value. Thus this PR is not really a perfect fix for #970.

Of course querying the current device sample rate is actually a massive pain (see PaAsio_ShowControlPanel for the implementation and limitations) which comes with its own caveats; and we have used the cached approach for other query functions (e.g, PaAsio_GetInputChannelName). So I am hesitant to request a rewrite to this patch.

@Spacechild1
Copy link
Author

Spacechild1 commented Dec 20, 2024

Thus this PR is not really a perfect fix for #970.

I agree. In the PR description I actually say that I'd prefer to add a flag to Pa_OpenStream and you seemed to agree: #970 (comment). Do you want me to implement that?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
P3 Priority: Normal src-asio Steinberg ASIO Host API /src/hostapi/asio
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants