ioctl(cdfile, CDIOCALLOW);
if (ioctl(cdfile, CDIOCEJECT) == -1)
- Con_DPrintf("ioctl CDIOCEJECT failed\n");
+ Con_DPrint("ioctl CDIOCEJECT failed\n");
}
ioctl(cdfile, CDIOCALLOW);
if (ioctl(cdfile, CDIOCCLOSE) == -1)
- Con_DPrintf("ioctl CDIOCCLOSE failed\n");
+ Con_DPrint("ioctl CDIOCCLOSE failed\n");
}
int CDAudio_SysGetAudioDiskInfo (void)
{
struct ioc_toc_header tochdr;
+ if (cdfile == -1)
+ return -1;
+
if (ioctl(cdfile, CDIOREADTOCHEADER, &tochdr) == -1)
{
- Con_DPrintf("ioctl CDIOREADTOCHEADER failed\n");
+ Con_DPrint("ioctl CDIOREADTOCHEADER failed\n");
return -1;
}
if (tochdr.starting_track < 1)
{
- Con_DPrintf("CDAudio: no music tracks\n");
+ Con_DPrint("CDAudio: no music tracks\n");
return -1;
}
}
+float CDAudio_SysGetVolume (void)
+{
+ struct ioc_vol vol;
+
+ if (cdfile == -1)
+ return -1.0f;
+
+ if (ioctl (cdfile, CDIOCGETVOL, &vol) == -1)
+ {
+ Con_DPrint("ioctl CDIOCGETVOL failed\n");
+ return -1.0f;
+ }
+
+ return (vol.vol[0] + vol.vol[1]) / 2.0f / 255.0f;
+}
+
+
+void CDAudio_SysSetVolume (float volume)
+{
+ struct ioc_vol vol;
+
+ if (cdfile == -1)
+ return;
+
+ vol.vol[0] = vol.vol[1] = volume * 255;
+ vol.vol[2] = vol.vol[3] = 0;
+
+ if (ioctl (cdfile, CDIOCSETVOL, &vol) == -1)
+ Con_DPrintf ("ioctl CDIOCSETVOL failed\n");
+}
+
+
int CDAudio_SysPlay (qbyte track)
{
struct ioc_read_toc_entry rte;
rte.data = &entry;
if (ioctl(cdfile, CDIOREADTOCENTRYS, &rte) == -1)
{
- Con_DPrintf("ioctl CDIOREADTOCENTRYS failed\n");
+ Con_DPrint("ioctl CDIOREADTOCENTRYS failed\n");
return -1;
}
if (entry.control & 4) // if it's a data track
if (ioctl(cdfile, CDIOCPLAYTRACKS, &ti) == -1)
{
- Con_DPrintf("ioctl CDIOCPLAYTRACKS failed\n");
+ Con_DPrint("ioctl CDIOCPLAYTRACKS failed\n");
return -1;
}
if (ioctl(cdfile, CDIOCRESUME) == -1)
{
- Con_DPrintf("ioctl CDIOCRESUME failed\n");
+ Con_DPrint("ioctl CDIOCRESUME failed\n");
return -1;
}
if (ioctl(cdfile, CDIOCPAUSE) == -1)
{
- Con_DPrintf("ioctl CDIOCPAUSE failed\n");
+ Con_DPrint("ioctl CDIOCPAUSE failed\n");
return -1;
}
return -1;
if (ioctl(cdfile, CDIOCRESUME) == -1)
- Con_DPrintf("ioctl CDIOCRESUME failed\n");
+ Con_DPrint("ioctl CDIOCRESUME failed\n");
return 0;
}
if (ioctl(cdfile, CDIOCREADSUBCHANNEL, &subchnl) == -1)
{
- Con_DPrintf("ioctl CDIOCREADSUBCHANNEL failed\n");
+ Con_DPrint("ioctl CDIOCREADSUBCHANNEL failed\n");
cdPlaying = false;
return -1;
}
{
int i;
+// COMMANDLINEOPTION: BSD Sound: -cddev <devicepath> chooses which CD drive to use
if ((i = COM_CheckParm("-cddev")) != 0 && i < com_argc - 1)
strlcpy(cd_dev, com_argv[i + 1], sizeof(cd_dev));
}