| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 89 m_kernels[i]->process(source->channel(i)->data(), | 89 m_kernels[i]->process(source->channel(i)->data(), |
| 90 destination->channel(i)->mutableData(), | 90 destination->channel(i)->mutableData(), |
| 91 framesToProcess); | 91 framesToProcess); |
| 92 } else { | 92 } else { |
| 93 // Unfortunately, the kernel is being processed by another thread. | 93 // Unfortunately, the kernel is being processed by another thread. |
| 94 // See also ConvolverNode::process(). | 94 // See also ConvolverNode::process(). |
| 95 destination->zero(); | 95 destination->zero(); |
| 96 } | 96 } |
| 97 } | 97 } |
| 98 | 98 |
| 99 void AudioDSPKernelProcessor::processOnlyAudioParams(size_t framesToProcess) { |
| 100 if (!isInitialized()) |
| 101 return; |
| 102 |
| 103 MutexTryLocker tryLocker(m_processLock); |
| 104 // Only update the AudioParams if we can get the lock. If not, some |
| 105 // other thread is updating the kernels, so we'll have to skip it |
| 106 // this time. |
| 107 if (tryLocker.locked()) { |
| 108 for (unsigned i = 0; i < m_kernels.size(); ++i) |
| 109 m_kernels[i]->processOnlyAudioParams(framesToProcess); |
| 110 } |
| 111 } |
| 112 |
| 99 // Resets filter state | 113 // Resets filter state |
| 100 void AudioDSPKernelProcessor::reset() { | 114 void AudioDSPKernelProcessor::reset() { |
| 101 ASSERT(isMainThread()); | 115 ASSERT(isMainThread()); |
| 102 if (!isInitialized()) | 116 if (!isInitialized()) |
| 103 return; | 117 return; |
| 104 | 118 |
| 105 // Forces snap to parameter values - first time. | 119 // Forces snap to parameter values - first time. |
| 106 // Any processing depending on this value must set it to false at the | 120 // Any processing depending on this value must set it to false at the |
| 107 // appropriate time. | 121 // appropriate time. |
| 108 m_hasJustReset = true; | 122 m_hasJustReset = true; |
| (...skipping 30 matching lines...) Expand all Loading... |
| 139 if (tryLocker.locked()) { | 153 if (tryLocker.locked()) { |
| 140 // It is expected that all the kernels have the same latencyTime. | 154 // It is expected that all the kernels have the same latencyTime. |
| 141 return !m_kernels.isEmpty() ? m_kernels.front()->latencyTime() : 0; | 155 return !m_kernels.isEmpty() ? m_kernels.front()->latencyTime() : 0; |
| 142 } | 156 } |
| 143 // Since we don't want to block the Audio Device thread, we return a large | 157 // Since we don't want to block the Audio Device thread, we return a large |
| 144 // value instead of trying to acquire the lock. | 158 // value instead of trying to acquire the lock. |
| 145 return std::numeric_limits<double>::infinity(); | 159 return std::numeric_limits<double>::infinity(); |
| 146 } | 160 } |
| 147 | 161 |
| 148 } // namespace blink | 162 } // namespace blink |
| OLD | NEW |