mirror of
https://github.com/kanjitalk755/macemu.git
synced 2025-01-21 15:31:50 +00:00
- renamed main_volume to speaker_volume and dac_volume to main_volume
(same for mute) - added defines for headphone volume/mute
This commit is contained in:
parent
9818250a47
commit
00aabbe812
@ -279,12 +279,12 @@ uint32 audio_get_main_volume(void)
|
||||
return 0x01000100;
|
||||
}
|
||||
|
||||
bool audio_get_dac_mute(void)
|
||||
bool audio_get_speaker_mute(void)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
uint32 audio_get_dac_volume(void)
|
||||
uint32 audio_get_speaker_volume(void)
|
||||
{
|
||||
return 0x01000100;
|
||||
}
|
||||
@ -297,10 +297,10 @@ void audio_set_main_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_mute(bool mute)
|
||||
void audio_set_speaker_mute(bool mute)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_volume(uint32 vol)
|
||||
void audio_set_speaker_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
@ -306,12 +306,12 @@ uint32 audio_get_main_volume(void)
|
||||
return 0x01000100;
|
||||
}
|
||||
|
||||
bool audio_get_dac_mute(void)
|
||||
bool audio_get_speaker_mute(void)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
uint32 audio_get_dac_volume(void)
|
||||
uint32 audio_get_speaker_volume(void)
|
||||
{
|
||||
return 0x01000100;
|
||||
}
|
||||
@ -329,10 +329,10 @@ void audio_set_main_volume(uint32 vol)
|
||||
}
|
||||
}
|
||||
|
||||
void audio_set_dac_mute(bool mute)
|
||||
void audio_set_speaker_mute(bool mute)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_volume(uint32 vol)
|
||||
void audio_set_speaker_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
@ -315,7 +315,7 @@ uint32 audio_get_main_volume(void)
|
||||
{
|
||||
if (mixer_fd >= 0) {
|
||||
int vol;
|
||||
if (ioctl(mixer_fd, SOUND_MIXER_READ_VOLUME, &vol) == 0) {
|
||||
if (ioctl(mixer_fd, SOUND_MIXER_READ_PCM, &vol) == 0) {
|
||||
int left = vol >> 8;
|
||||
int right = vol & 0xff;
|
||||
return ((left * 256 / 100) << 16) | (right * 256 / 100);
|
||||
@ -324,16 +324,16 @@ uint32 audio_get_main_volume(void)
|
||||
return 0x01000100;
|
||||
}
|
||||
|
||||
bool audio_get_dac_mute(void)
|
||||
bool audio_get_speaker_mute(void)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
uint32 audio_get_dac_volume(void)
|
||||
uint32 audio_get_speaker_volume(void)
|
||||
{
|
||||
if (mixer_fd >= 0) {
|
||||
int vol;
|
||||
if (ioctl(mixer_fd, SOUND_MIXER_READ_PCM, &vol) == 0) {
|
||||
if (ioctl(mixer_fd, SOUND_MIXER_READ_SPEAKER, &vol) == 0) {
|
||||
int left = vol >> 8;
|
||||
int right = vol & 0xff;
|
||||
return ((left * 256 / 100) << 16) | (right * 256 / 100);
|
||||
@ -352,20 +352,20 @@ void audio_set_main_volume(uint32 vol)
|
||||
int left = vol >> 16;
|
||||
int right = vol & 0xffff;
|
||||
int p = ((left * 100 / 256) << 8) | (right * 100 / 256);
|
||||
ioctl(mixer_fd, SOUND_MIXER_WRITE_VOLUME, &p);
|
||||
ioctl(mixer_fd, SOUND_MIXER_WRITE_PCM, &p);
|
||||
}
|
||||
}
|
||||
|
||||
void audio_set_dac_mute(bool mute)
|
||||
void audio_set_speaker_mute(bool mute)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_volume(uint32 vol)
|
||||
void audio_set_speaker_volume(uint32 vol)
|
||||
{
|
||||
if (mixer_fd >= 0) {
|
||||
int left = vol >> 16;
|
||||
int right = vol & 0xffff;
|
||||
int p = ((left * 100 / 256) << 8) | (right * 100 / 256);
|
||||
ioctl(mixer_fd, SOUND_MIXER_WRITE_PCM, &p);
|
||||
ioctl(mixer_fd, SOUND_MIXER_WRITE_SPEAKER, &p);
|
||||
}
|
||||
}
|
||||
|
@ -296,12 +296,12 @@ uint32 audio_get_main_volume(void)
|
||||
return 0x01000100;
|
||||
}
|
||||
|
||||
bool audio_get_dac_mute(void)
|
||||
bool audio_get_speaker_mute(void)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
uint32 audio_get_dac_volume(void)
|
||||
uint32 audio_get_speaker_volume(void)
|
||||
{
|
||||
return 0x01000100;
|
||||
}
|
||||
@ -314,10 +314,10 @@ void audio_set_main_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_mute(bool mute)
|
||||
void audio_set_speaker_mute(bool mute)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_volume(uint32 vol)
|
||||
void audio_set_speaker_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
@ -113,29 +113,41 @@ static int32 AudioGetInfo(uint32 infoPtr, uint32 selector, uint32 sourceID)
|
||||
}
|
||||
|
||||
case siSpeakerMute:
|
||||
WriteMacInt16(infoPtr, audio_get_main_mute());
|
||||
WriteMacInt16(infoPtr, audio_get_speaker_mute());
|
||||
break;
|
||||
|
||||
case siSpeakerVolume:
|
||||
WriteMacInt32(infoPtr, audio_get_main_volume());
|
||||
WriteMacInt32(infoPtr, audio_get_speaker_volume());
|
||||
break;
|
||||
|
||||
case siHeadphoneMute:
|
||||
WriteMacInt16(infoPtr, 0);
|
||||
break;
|
||||
|
||||
case siHeadphoneVolume:
|
||||
WriteMacInt32(infoPtr, 0x01000100);
|
||||
break;
|
||||
|
||||
case siHeadphoneVolumeSteps:
|
||||
WriteMacInt16(infoPtr, 13);
|
||||
break;
|
||||
|
||||
case siHardwareMute:
|
||||
WriteMacInt16(infoPtr, audio_get_dac_mute());
|
||||
WriteMacInt16(infoPtr, audio_get_main_mute());
|
||||
break;
|
||||
|
||||
case siHardwareVolume:
|
||||
WriteMacInt32(infoPtr, audio_get_dac_volume());
|
||||
WriteMacInt32(infoPtr, audio_get_main_volume());
|
||||
break;
|
||||
|
||||
case siHardwareVolumeSteps:
|
||||
WriteMacInt16(infoPtr, 13);
|
||||
break;
|
||||
|
||||
case siHardwareBusy:
|
||||
WriteMacInt16(infoPtr, AudioStatus.num_sources != 0);
|
||||
break;
|
||||
|
||||
case siHardwareVolumeSteps:
|
||||
WriteMacInt16(infoPtr, 64);
|
||||
break;
|
||||
|
||||
default: // Delegate to Apple Mixer
|
||||
if (AudioStatus.mixer == 0)
|
||||
return badComponentSelector;
|
||||
@ -197,21 +209,25 @@ static int32 AudioSetInfo(uint32 infoPtr, uint32 selector, uint32 sourceID)
|
||||
return badChannel;
|
||||
|
||||
case siSpeakerMute:
|
||||
audio_set_main_mute((uint16)infoPtr);
|
||||
audio_set_speaker_mute((uint16)infoPtr);
|
||||
break;
|
||||
|
||||
case siSpeakerVolume:
|
||||
D(bug(" set speaker volume %08lx\n", infoPtr));
|
||||
audio_set_main_volume(infoPtr);
|
||||
audio_set_speaker_volume(infoPtr);
|
||||
break;
|
||||
|
||||
case siHeadphoneMute:
|
||||
case siHeadphoneVolume:
|
||||
break;
|
||||
|
||||
case siHardwareMute:
|
||||
audio_set_dac_mute((uint16)infoPtr);
|
||||
audio_set_main_mute((uint16)infoPtr);
|
||||
break;
|
||||
|
||||
case siHardwareVolume:
|
||||
D(bug(" set hardware volume %08lx\n", infoPtr));
|
||||
audio_set_dac_volume(infoPtr);
|
||||
audio_set_main_volume(infoPtr);
|
||||
break;
|
||||
|
||||
default: // Delegate to Apple Mixer
|
||||
@ -351,7 +367,7 @@ adat_error: printf("FATAL: audio component data block initialization error\n");
|
||||
return noErr;
|
||||
|
||||
case kComponentVersionSelect:
|
||||
return 0x00010002;
|
||||
return 0x00010003;
|
||||
|
||||
case kComponentCloseSelect:
|
||||
open_count--;
|
||||
|
@ -131,12 +131,12 @@ uint32 audio_get_main_volume(void)
|
||||
return 0x01000100;
|
||||
}
|
||||
|
||||
bool audio_get_dac_mute(void)
|
||||
bool audio_get_speaker_mute(void)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
uint32 audio_get_dac_volume(void)
|
||||
uint32 audio_get_speaker_volume(void)
|
||||
{
|
||||
return 0x01000100;
|
||||
}
|
||||
@ -149,10 +149,10 @@ void audio_set_main_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_mute(bool mute)
|
||||
void audio_set_speaker_mute(bool mute)
|
||||
{
|
||||
}
|
||||
|
||||
void audio_set_dac_volume(uint32 vol)
|
||||
void audio_set_speaker_volume(uint32 vol)
|
||||
{
|
||||
}
|
||||
|
@ -19,16 +19,19 @@
|
||||
*/
|
||||
|
||||
/*
|
||||
TODO:
|
||||
LockRng
|
||||
UnlockRng
|
||||
(CatSearch)
|
||||
(MakeFSSpec)
|
||||
(GetVolMountInfoSize)
|
||||
(GetVolMountInfo)
|
||||
(GetForeignPrivs)
|
||||
(SetForeignPrivs)
|
||||
*/
|
||||
* SEE ALSO
|
||||
* Guide to the File System Manager (from FSM 1.2 SDK)
|
||||
*
|
||||
* TODO
|
||||
* LockRng
|
||||
* UnlockRng
|
||||
* (CatSearch)
|
||||
* (MakeFSSpec)
|
||||
* (GetVolMountInfoSize)
|
||||
* (GetVolMountInfo)
|
||||
* (GetForeignPrivs)
|
||||
* (SetForeignPrivs)
|
||||
*/
|
||||
|
||||
#include "sysdeps.h"
|
||||
|
||||
@ -379,15 +382,19 @@ void InstallExtFS(void)
|
||||
r.d[0] = gestaltFSAttr;
|
||||
Execute68kTrap(0xa1ad, &r); // Gestalt()
|
||||
D(bug("FSAttr %ld, %08lx\n", r.d[0], r.a[0]));
|
||||
if ((r.d[0] & 0xffff) || !(r.a[0] & (1 << gestaltHasFileSystemManager)))
|
||||
if ((r.d[0] & 0xffff) || !(r.a[0] & (1 << gestaltHasFileSystemManager))) {
|
||||
printf("WARNING: No FSM present, disabling ExtFS\n");
|
||||
return;
|
||||
}
|
||||
|
||||
// Yes, version >=1.2?
|
||||
r.d[0] = gestaltFSMVersion;
|
||||
Execute68kTrap(0xa1ad, &r); // Gestalt()
|
||||
D(bug("FSMVersion %ld, %08lx\n", r.d[0], r.a[0]));
|
||||
if ((r.d[0] & 0xffff) || (r.a[0] < 0x0120))
|
||||
if ((r.d[0] & 0xffff) || (r.a[0] < 0x0120)) {
|
||||
printf("WARNING: FSM <1.2 found, disabling ExtFS\n");
|
||||
return;
|
||||
}
|
||||
|
||||
D(bug("FSM present\n"));
|
||||
|
||||
|
@ -40,12 +40,12 @@ extern void audio_set_channels(int index);
|
||||
|
||||
extern bool audio_get_main_mute(void);
|
||||
extern uint32 audio_get_main_volume(void);
|
||||
extern bool audio_get_dac_mute(void);
|
||||
extern uint32 audio_get_dac_volume(void);
|
||||
extern bool audio_get_speaker_mute(void);
|
||||
extern uint32 audio_get_speaker_volume(void);
|
||||
extern void audio_set_main_mute(bool mute);
|
||||
extern void audio_set_main_volume(uint32 vol);
|
||||
extern void audio_set_dac_mute(bool mute);
|
||||
extern void audio_set_dac_volume(uint32 vol);
|
||||
extern void audio_set_speaker_mute(bool mute);
|
||||
extern void audio_set_speaker_volume(uint32 vol);
|
||||
|
||||
// Current audio status
|
||||
struct audio_status {
|
||||
|
@ -60,18 +60,21 @@ enum {
|
||||
|
||||
// Sound information selectors
|
||||
enum {
|
||||
siNumberChannels = 'chan', // current number of channels
|
||||
siChannelAvailable = 'chav', // number of channels available
|
||||
siSampleRate = 'srat', // current sample rate
|
||||
siSampleRateAvailable = 'srav', // sample rates available
|
||||
siSampleSize = 'ssiz', // current sample size
|
||||
siSampleSizeAvailable = 'ssav', // sample sizes available
|
||||
siNumberChannels = 'chan', // current number of channels
|
||||
siChannelAvailable = 'chav', // number of channels available
|
||||
siSpeakerMute = 'smut', // mute state of all built-in speaker
|
||||
siSpeakerVolume = 'svol', // volume level of built-in speaker
|
||||
siHardwareMute = 'hmut', // mute state of all hardware
|
||||
siHardwareVolume = 'hvol', // volume level of all hardware
|
||||
siHardwareVolumeSteps = 'hstp', // number of volume steps for hardware
|
||||
siHardwareBusy = 'hwbs' // sound hardware is in use
|
||||
siHardwareBusy = 'hwbs', // sound hardware is in use
|
||||
siHeadphoneMute = 'pmut', // mute state of headphone
|
||||
siHeadphoneVolume = 'pvol', // volume level of headphone
|
||||
siHeadphoneVolumeSteps = 'hdst', // number of volume steps for headphone
|
||||
siSpeakerMute = 'smut', // mute state of all built-in speakers
|
||||
siSpeakerVolume = 'svol' // volume level of built-in speaker
|
||||
};
|
||||
|
||||
enum { // ComponentResource struct
|
||||
|
Loading…
x
Reference in New Issue
Block a user