output/oss: use class FileDescriptor
This commit is contained in:
parent
56cb92fdaf
commit
3c7c0515d8
@ -21,7 +21,7 @@
|
||||
#include "OssOutputPlugin.hxx"
|
||||
#include "../OutputAPI.hxx"
|
||||
#include "mixer/MixerList.hxx"
|
||||
#include "system/fd_util.h"
|
||||
#include "system/UniqueFileDescriptor.hxx"
|
||||
#include "system/Error.hxx"
|
||||
#include "util/ConstBuffer.hxx"
|
||||
#include "util/Domain.hxx"
|
||||
@ -64,7 +64,7 @@ class OssOutput final : AudioOutput {
|
||||
Manual<PcmExport> pcm_export;
|
||||
#endif
|
||||
|
||||
int fd;
|
||||
FileDescriptor fd = FileDescriptor::Undefined();
|
||||
const char *device;
|
||||
|
||||
/**
|
||||
@ -88,7 +88,7 @@ class OssOutput final : AudioOutput {
|
||||
public:
|
||||
explicit OssOutput(const char *_device=nullptr)
|
||||
:AudioOutput(oss_flags),
|
||||
fd(-1), device(_device) {}
|
||||
device(_device) {}
|
||||
|
||||
static AudioOutput *Create(EventLoop &event_loop,
|
||||
const ConfigBlock &block);
|
||||
@ -169,15 +169,10 @@ static const char *const default_devices[] = { "/dev/sound/dsp", "/dev/dsp" };
|
||||
static bool
|
||||
oss_output_test_default_device(void)
|
||||
{
|
||||
int fd, i;
|
||||
|
||||
for (i = ARRAY_SIZE(default_devices); --i >= 0; ) {
|
||||
fd = open_cloexec(default_devices[i], O_WRONLY, 0);
|
||||
|
||||
if (fd >= 0) {
|
||||
close(fd);
|
||||
for (int i = ARRAY_SIZE(default_devices); --i >= 0; ) {
|
||||
UniqueFileDescriptor fd;
|
||||
if (fd.Open(default_devices[i], O_WRONLY, 0))
|
||||
return true;
|
||||
}
|
||||
|
||||
FormatErrno(oss_output_domain,
|
||||
"Error opening OSS device \"%s\"",
|
||||
@ -239,9 +234,8 @@ OssOutput::Create(EventLoop &, const ConfigBlock &block)
|
||||
void
|
||||
OssOutput::DoClose()
|
||||
{
|
||||
if (fd >= 0)
|
||||
close(fd);
|
||||
fd = -1;
|
||||
if (fd.IsDefined())
|
||||
fd.Close();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -258,14 +252,14 @@ enum oss_setup_result {
|
||||
* returned. Any other failure throws std::runtime_error.
|
||||
*/
|
||||
static enum oss_setup_result
|
||||
oss_try_ioctl_r(int fd, unsigned long request, int *value_r,
|
||||
oss_try_ioctl_r(FileDescriptor fd, unsigned long request, int *value_r,
|
||||
const char *msg)
|
||||
{
|
||||
assert(fd >= 0);
|
||||
assert(fd.IsDefined());
|
||||
assert(value_r != nullptr);
|
||||
assert(msg != nullptr);
|
||||
|
||||
int ret = ioctl(fd, request, value_r);
|
||||
int ret = ioctl(fd.Get(), request, value_r);
|
||||
if (ret >= 0)
|
||||
return SUCCESS;
|
||||
|
||||
@ -281,7 +275,7 @@ oss_try_ioctl_r(int fd, unsigned long request, int *value_r,
|
||||
* returned. Any other failure throws std::runtime_error.
|
||||
*/
|
||||
static enum oss_setup_result
|
||||
oss_try_ioctl(int fd, unsigned long request, int value,
|
||||
oss_try_ioctl(FileDescriptor fd, unsigned long request, int value,
|
||||
const char *msg)
|
||||
{
|
||||
return oss_try_ioctl_r(fd, request, &value, msg);
|
||||
@ -294,7 +288,7 @@ oss_try_ioctl(int fd, unsigned long request, int value,
|
||||
* Throws #std::runtime_error on error.
|
||||
*/
|
||||
static void
|
||||
oss_setup_channels(int fd, AudioFormat &audio_format)
|
||||
oss_setup_channels(FileDescriptor fd, AudioFormat &audio_format)
|
||||
{
|
||||
const char *const msg = "Failed to set channel count";
|
||||
int channels = audio_format.channels;
|
||||
@ -343,7 +337,7 @@ oss_setup_channels(int fd, AudioFormat &audio_format)
|
||||
* Throws #std::runtime_error on error.
|
||||
*/
|
||||
static void
|
||||
oss_setup_sample_rate(int fd, AudioFormat &audio_format)
|
||||
oss_setup_sample_rate(FileDescriptor fd, AudioFormat &audio_format)
|
||||
{
|
||||
const char *const msg = "Failed to set sample rate";
|
||||
int sample_rate = audio_format.sample_rate;
|
||||
@ -467,7 +461,7 @@ sample_format_from_oss(int format) noexcept
|
||||
* error
|
||||
*/
|
||||
static enum oss_setup_result
|
||||
oss_probe_sample_format(int fd, SampleFormat sample_format,
|
||||
oss_probe_sample_format(FileDescriptor fd, SampleFormat sample_format,
|
||||
SampleFormat *sample_format_r,
|
||||
int *oss_format_r
|
||||
#ifdef AFMT_S24_PACKED
|
||||
@ -523,7 +517,7 @@ oss_probe_sample_format(int fd, SampleFormat sample_format,
|
||||
* specified format is not supported.
|
||||
*/
|
||||
static void
|
||||
oss_setup_sample_format(int fd, AudioFormat &audio_format,
|
||||
oss_setup_sample_format(FileDescriptor fd, AudioFormat &audio_format,
|
||||
int *oss_format_r
|
||||
#ifdef AFMT_S24_PACKED
|
||||
, PcmExport &pcm_export
|
||||
@ -601,10 +595,9 @@ OssOutput::Setup(AudioFormat &_audio_format)
|
||||
inline void
|
||||
OssOutput::Reopen()
|
||||
try {
|
||||
assert(fd < 0);
|
||||
assert(!fd.IsDefined());
|
||||
|
||||
fd = open_cloexec(device, O_WRONLY, 0);
|
||||
if (fd < 0)
|
||||
if (!fd.Open(device, O_WRONLY))
|
||||
throw FormatErrno("Error opening OSS device \"%s\"", device);
|
||||
|
||||
enum oss_setup_result result;
|
||||
@ -641,8 +634,7 @@ try {
|
||||
void
|
||||
OssOutput::Open(AudioFormat &_audio_format)
|
||||
try {
|
||||
fd = open_cloexec(device, O_WRONLY, 0);
|
||||
if (fd < 0)
|
||||
if (!fd.Open(device, O_WRONLY))
|
||||
throw FormatErrno("Error opening OSS device \"%s\"", device);
|
||||
|
||||
Setup(_audio_format);
|
||||
@ -656,8 +648,8 @@ try {
|
||||
void
|
||||
OssOutput::Cancel() noexcept
|
||||
{
|
||||
if (fd >= 0) {
|
||||
ioctl(fd, SNDCTL_DSP_RESET, 0);
|
||||
if (fd.IsDefined()) {
|
||||
ioctl(fd.Get(), SNDCTL_DSP_RESET, 0);
|
||||
DoClose();
|
||||
}
|
||||
|
||||
@ -674,7 +666,7 @@ OssOutput::Play(const void *chunk, size_t size)
|
||||
assert(size > 0);
|
||||
|
||||
/* reopen the device since it was closed by dropBufferedAudio */
|
||||
if (fd < 0)
|
||||
if (!fd.IsDefined())
|
||||
Reopen();
|
||||
|
||||
#ifdef AFMT_S24_PACKED
|
||||
@ -686,7 +678,7 @@ OssOutput::Play(const void *chunk, size_t size)
|
||||
assert(size > 0);
|
||||
|
||||
while (true) {
|
||||
ret = write(fd, chunk, size);
|
||||
ret = fd.Write(chunk, size);
|
||||
if (ret > 0) {
|
||||
#ifdef AFMT_S24_PACKED
|
||||
ret = pcm_export->CalcSourceSize(ret);
|
||||
|
Loading…
Reference in New Issue
Block a user