OLD | NEW |
| (Empty) |
1 /* | |
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. | |
3 * | |
4 * Use of this source code is governed by a BSD-style license | |
5 * that can be found in the LICENSE file in the root of the source | |
6 * tree. An additional intellectual property rights grant can be found | |
7 * in the file PATENTS. All contributing project authors may | |
8 * be found in the AUTHORS file in the root of the source tree. | |
9 */ | |
10 | |
11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_AEC_AEC_LOGGING_ | |
12 #define WEBRTC_MODULES_AUDIO_PROCESSING_AEC_AEC_LOGGING_ | |
13 | |
14 #include <stdio.h> | |
15 | |
16 #include "webrtc/modules/audio_processing/logging/aec_logging_file_handling.h" | |
17 | |
18 // To enable AEC logging, invoke GYP with -Daec_debug_dump=1. | |
19 #ifdef WEBRTC_AEC_DEBUG_DUMP | |
20 // Dumps a wav data to file. | |
21 #define RTC_AEC_DEBUG_WAV_WRITE(file, data, num_samples) \ | |
22 do { \ | |
23 rtc_WavWriteSamples(file, data, num_samples); \ | |
24 } while (0) | |
25 | |
26 // (Re)opens a wav file for writing using the specified sample rate. | |
27 #define RTC_AEC_DEBUG_WAV_REOPEN(name, instance_index, process_rate, \ | |
28 sample_rate, wav_file) \ | |
29 do { \ | |
30 WebRtcAec_ReopenWav(name, instance_index, process_rate, sample_rate, \ | |
31 wav_file); \ | |
32 } while (0) | |
33 | |
34 // Closes a wav file. | |
35 #define RTC_AEC_DEBUG_WAV_CLOSE(wav_file) \ | |
36 do { \ | |
37 rtc_WavClose(wav_file); \ | |
38 } while (0) | |
39 | |
40 // Dumps a raw data to file. | |
41 #define RTC_AEC_DEBUG_RAW_WRITE(file, data, data_size) \ | |
42 do { \ | |
43 (void) fwrite(data, data_size, 1, file); \ | |
44 } while (0) | |
45 | |
46 // Dumps a raw scalar int32 to file. | |
47 #define RTC_AEC_DEBUG_RAW_WRITE_SCALAR_INT32(file, data) \ | |
48 do { \ | |
49 int32_t value_to_store = data; \ | |
50 (void) fwrite(&value_to_store, sizeof(value_to_store), 1, file); \ | |
51 } while (0) | |
52 | |
53 // Dumps a raw scalar double to file. | |
54 #define RTC_AEC_DEBUG_RAW_WRITE_SCALAR_DOUBLE(file, data) \ | |
55 do { \ | |
56 double value_to_store = data; \ | |
57 (void) fwrite(&value_to_store, sizeof(value_to_store), 1, file); \ | |
58 } while (0) | |
59 | |
60 // Opens a raw data file for writing using the specified sample rate. | |
61 #define RTC_AEC_DEBUG_RAW_OPEN(name, instance_counter, file) \ | |
62 do { \ | |
63 WebRtcAec_RawFileOpen(name, instance_counter, file); \ | |
64 } while (0) | |
65 | |
66 // Closes a raw data file. | |
67 #define RTC_AEC_DEBUG_RAW_CLOSE(file) \ | |
68 do { \ | |
69 fclose(file); \ | |
70 } while (0) | |
71 | |
72 #else // RTC_AEC_DEBUG_DUMP | |
73 #define RTC_AEC_DEBUG_WAV_WRITE(file, data, num_samples) \ | |
74 do { \ | |
75 } while (0) | |
76 | |
77 #define RTC_AEC_DEBUG_WAV_REOPEN(wav_file, name, instance_index, process_rate, \ | |
78 sample_rate) \ | |
79 do { \ | |
80 } while (0) | |
81 | |
82 #define RTC_AEC_DEBUG_WAV_CLOSE(wav_file) \ | |
83 do { \ | |
84 } while (0) | |
85 | |
86 #define RTC_AEC_DEBUG_RAW_WRITE(file, data, data_size) \ | |
87 do { \ | |
88 } while (0) | |
89 | |
90 #define RTC_AEC_DEBUG_RAW_WRITE_SCALAR_INT32(file, data) \ | |
91 do { \ | |
92 } while (0) | |
93 | |
94 #define RTC_AEC_DEBUG_RAW_WRITE_SCALAR_DOUBLE(file, data) \ | |
95 do { \ | |
96 } while (0) | |
97 | |
98 #define RTC_AEC_DEBUG_RAW_OPEN(file, name, instance_counter) \ | |
99 do { \ | |
100 } while (0) | |
101 | |
102 #define RTC_AEC_DEBUG_RAW_CLOSE(file) \ | |
103 do { \ | |
104 } while (0) | |
105 | |
106 #endif // WEBRTC_AEC_DEBUG_DUMP | |
107 | |
108 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_AEC_AEC_LOGGING_ | |
OLD | NEW |