cras_input.h revision a36e5920737c6adbddd3e43b760e5de8431db6e0
1// Copyright (c) 2012 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef MEDIA_AUDIO_CRAS_CRAS_INPUT_H_
6#define MEDIA_AUDIO_CRAS_CRAS_INPUT_H_
7
8#include <cras_client.h>
9
10#include <string>
11
12#include "base/compiler_specific.h"
13#include "base/memory/scoped_ptr.h"
14#include "base/memory/weak_ptr.h"
15#include "media/audio/agc_audio_stream.h"
16#include "media/audio/audio_io.h"
17#include "media/audio/audio_parameters.h"
18
19namespace media {
20
21class AudioManagerCras;
22
23// Provides an input stream for audio capture based on CRAS, the ChromeOS Audio
24// Server.  This object is not thread safe and all methods should be invoked in
25// the thread that created the object.
26class CrasInputStream : public AgcAudioStream<AudioInputStream> {
27 public:
28  // The ctor takes all the usual parameters, plus |manager| which is the
29  // audio manager who is creating this object.
30  CrasInputStream(const AudioParameters& params, AudioManagerCras* manager,
31                  const std::string& device_id);
32
33  // The dtor is typically called by the AudioManager only and it is usually
34  // triggered by calling AudioOutputStream::Close().
35  virtual ~CrasInputStream();
36
37  // Implementation of AudioInputStream.
38  virtual bool Open() OVERRIDE;
39  virtual void Start(AudioInputCallback* callback) OVERRIDE;
40  virtual void Stop() OVERRIDE;
41  virtual void Close() OVERRIDE;
42  virtual double GetMaxVolume() OVERRIDE;
43  virtual void SetVolume(double volume) OVERRIDE;
44  virtual double GetVolume() OVERRIDE;
45
46 private:
47  // Handles requests to get samples from the provided buffer.  This will be
48  // called by the audio server when it has samples ready.
49  static int SamplesReady(cras_client* client,
50                          cras_stream_id_t stream_id,
51                          uint8* samples,
52                          size_t frames,
53                          const timespec* sample_ts,
54                          void* arg);
55
56  // Handles notificaiton that there was an error with the playback stream.
57  static int StreamError(cras_client* client,
58                         cras_stream_id_t stream_id,
59                         int err,
60                         void* arg);
61
62  // Reads one or more buffers of audio from the device, passes on to the
63  // registered callback. Called from SamplesReady().
64  void ReadAudio(size_t frames, uint8* buffer, const timespec* sample_ts);
65
66  // Deals with an error that occured in the stream.  Called from StreamError().
67  void NotifyStreamError(int err);
68
69  // Convert from dB * 100 to a volume ratio.
70  double GetVolumeRatioFromDecibels(double dB) const;
71
72  // Convert from a volume ratio to dB.
73  double GetDecibelsFromVolumeRatio(double volume_ratio) const;
74
75  // Non-refcounted pointer back to the audio manager.
76  // The AudioManager indirectly holds on to stream objects, so we don't
77  // want circular references.  Additionally, stream objects live on the audio
78  // thread, which is owned by the audio manager and we don't want to addref
79  // the manager from that thread.
80  AudioManagerCras* const audio_manager_;
81
82  // Size of frame in bytes.
83  uint32 bytes_per_frame_;
84
85  // Callback to pass audio samples too, valid while recording.
86  AudioInputCallback* callback_;
87
88  // The client used to communicate with the audio server.
89  cras_client* client_;
90
91  // PCM parameters for the stream.
92  const AudioParameters params_;
93
94  // True if the stream has been started.
95  bool started_;
96
97  // ID of the playing stream.
98  cras_stream_id_t stream_id_;
99
100  // Direction of the stream.
101  const CRAS_STREAM_DIRECTION stream_direction_;
102
103  DISALLOW_COPY_AND_ASSIGN(CrasInputStream);
104};
105
106}  // namespace media
107
108#endif  // MEDIA_AUDIO_CRAS_ALSA_INPUT_H_
109