mirror of
https://github.com/openjdk/jdk.git
synced 2026-02-16 21:35:25 +00:00
6801206: SoundTestSuite: test050 fails
Reviewed-by: stayer
This commit is contained in:
parent
601f9c0fea
commit
8fa35f419c
@ -395,11 +395,7 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
protected volatile boolean noService = false; // do not run the nService method
|
||||
|
||||
// Guards all native calls.
|
||||
protected Object lockNative = new Object();
|
||||
// Guards the lastOpened static variable in implOpen and implClose.
|
||||
protected static Object lockLast = new Object();
|
||||
// Keeps track of last opened line, see implOpen "trick".
|
||||
protected static DirectDL lastOpened;
|
||||
protected final Object lockNative = new Object();
|
||||
|
||||
// CONSTRUCTOR
|
||||
protected DirectDL(DataLine.Info info,
|
||||
@ -501,48 +497,21 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
// align buffer to full frames
|
||||
bufferSize = ((int) bufferSize / format.getFrameSize()) * format.getFrameSize();
|
||||
|
||||
synchronized(lockLast) {
|
||||
id = nOpen(mixerIndex, deviceID, isSource,
|
||||
encoding,
|
||||
hardwareFormat.getSampleRate(),
|
||||
hardwareFormat.getSampleSizeInBits(),
|
||||
hardwareFormat.getFrameSize(),
|
||||
hardwareFormat.getChannels(),
|
||||
hardwareFormat.getEncoding().equals(
|
||||
AudioFormat.Encoding.PCM_SIGNED),
|
||||
hardwareFormat.isBigEndian(),
|
||||
bufferSize);
|
||||
id = nOpen(mixerIndex, deviceID, isSource,
|
||||
encoding,
|
||||
hardwareFormat.getSampleRate(),
|
||||
hardwareFormat.getSampleSizeInBits(),
|
||||
hardwareFormat.getFrameSize(),
|
||||
hardwareFormat.getChannels(),
|
||||
hardwareFormat.getEncoding().equals(
|
||||
AudioFormat.Encoding.PCM_SIGNED),
|
||||
hardwareFormat.isBigEndian(),
|
||||
bufferSize);
|
||||
|
||||
if (id == 0) {
|
||||
// Bah... Dirty trick. The most likely cause is an application
|
||||
// already having a line open for this particular hardware
|
||||
// format and forgetting about it. If so, silently close that
|
||||
// implementation and try again. Unfortuantely we can only
|
||||
// open one line per hardware format currently.
|
||||
if (lastOpened != null
|
||||
&& hardwareFormat.matches(lastOpened.hardwareFormat)) {
|
||||
lastOpened.implClose();
|
||||
lastOpened = null;
|
||||
|
||||
id = nOpen(mixerIndex, deviceID, isSource,
|
||||
encoding,
|
||||
hardwareFormat.getSampleRate(),
|
||||
hardwareFormat.getSampleSizeInBits(),
|
||||
hardwareFormat.getFrameSize(),
|
||||
hardwareFormat.getChannels(),
|
||||
hardwareFormat.getEncoding().equals(
|
||||
AudioFormat.Encoding.PCM_SIGNED),
|
||||
hardwareFormat.isBigEndian(),
|
||||
bufferSize);
|
||||
}
|
||||
|
||||
if (id == 0) {
|
||||
// TODO: nicer error messages...
|
||||
throw new LineUnavailableException(
|
||||
"line with format "+format+" not supported.");
|
||||
}
|
||||
}
|
||||
lastOpened = this;
|
||||
if (id == 0) {
|
||||
// TODO: nicer error messages...
|
||||
throw new LineUnavailableException(
|
||||
"line with format "+format+" not supported.");
|
||||
}
|
||||
|
||||
this.bufferSize = nGetBufferSize(id, isSource);
|
||||
@ -615,14 +584,13 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
}
|
||||
synchronized (lockNative) {
|
||||
nStop(id, isSource);
|
||||
|
||||
}
|
||||
// wake up any waiting threads
|
||||
synchronized(lock) {
|
||||
// need to set doIO to false before notifying the
|
||||
// read/write thread, that's why isStartedRunning()
|
||||
// cannot be used
|
||||
doIO = false;
|
||||
}
|
||||
// wake up any waiting threads
|
||||
synchronized(lock) {
|
||||
lock.notifyAll();
|
||||
}
|
||||
setActive(false);
|
||||
@ -649,12 +617,8 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
doIO = false;
|
||||
long oldID = id;
|
||||
id = 0;
|
||||
synchronized (lockLast) {
|
||||
synchronized (lockNative) {
|
||||
nClose(oldID, isSource);
|
||||
if (lastOpened == this)
|
||||
lastOpened = null;
|
||||
}
|
||||
synchronized (lockNative) {
|
||||
nClose(oldID, isSource);
|
||||
}
|
||||
bytePosition = 0;
|
||||
softwareConversionSize = 0;
|
||||
@ -667,10 +631,9 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
if (id == 0) {
|
||||
return 0;
|
||||
}
|
||||
int a = 0;
|
||||
int a;
|
||||
synchronized (lockNative) {
|
||||
if (doIO)
|
||||
a = nAvailable(id, isSource);
|
||||
a = nAvailable(id, isSource);
|
||||
}
|
||||
return a;
|
||||
}
|
||||
@ -726,7 +689,7 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
lock.notifyAll();
|
||||
}
|
||||
synchronized (lockNative) {
|
||||
if (id != 0 && doIO) {
|
||||
if (id != 0) {
|
||||
// then flush native buffers
|
||||
nFlush(id, isSource);
|
||||
}
|
||||
@ -737,10 +700,9 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
|
||||
// replacement for getFramePosition (see AbstractDataLine)
|
||||
public long getLongFramePosition() {
|
||||
long pos = 0;
|
||||
long pos;
|
||||
synchronized (lockNative) {
|
||||
if (doIO)
|
||||
pos = nGetBytePosition(id, isSource, bytePosition);
|
||||
pos = nGetBytePosition(id, isSource, bytePosition);
|
||||
}
|
||||
// hack because ALSA sometimes reports wrong framepos
|
||||
if (pos < 0) {
|
||||
@ -786,12 +748,11 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
}
|
||||
int written = 0;
|
||||
while (!flushing) {
|
||||
int thisWritten = 0;
|
||||
int thisWritten;
|
||||
synchronized (lockNative) {
|
||||
if (doIO)
|
||||
thisWritten = nWrite(id, b, off, len,
|
||||
softwareConversionSize,
|
||||
leftGain, rightGain);
|
||||
thisWritten = nWrite(id, b, off, len,
|
||||
softwareConversionSize,
|
||||
leftGain, rightGain);
|
||||
if (thisWritten < 0) {
|
||||
// error in native layer
|
||||
break;
|
||||
@ -1014,10 +975,9 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
}
|
||||
int read = 0;
|
||||
while (doIO && !flushing) {
|
||||
int thisRead = 0;
|
||||
int thisRead;
|
||||
synchronized (lockNative) {
|
||||
if (doIO)
|
||||
thisRead = nRead(id, b, off, len, softwareConversionSize);
|
||||
thisRead = nRead(id, b, off, len, softwareConversionSize);
|
||||
if (thisRead < 0) {
|
||||
// error in native layer
|
||||
break;
|
||||
@ -1252,8 +1212,7 @@ class DirectAudioDevice extends AbstractMixer {
|
||||
// set new native position (if necessary)
|
||||
// this must come after the flush!
|
||||
synchronized (lockNative) {
|
||||
if (doIO)
|
||||
nSetBytePosition(id, isSource, frames * frameSize);
|
||||
nSetBytePosition(id, isSource, frames * frameSize);
|
||||
}
|
||||
|
||||
if (Printer.debug) Printer.debug(" DirectClip.setFramePosition: "
|
||||
|
||||
90
jdk/test/javax/sound/sampled/Clip/ClipSetPos.java
Normal file
90
jdk/test/javax/sound/sampled/Clip/ClipSetPos.java
Normal file
@ -0,0 +1,90 @@
|
||||
/*
|
||||
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation. Oracle designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Oracle in the LICENSE file that accompanied this code.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @test
|
||||
* @bug 6801206
|
||||
* @summary Tests that Clip sets frame position
|
||||
* @author Alex Menkov
|
||||
*/
|
||||
|
||||
import javax.sound.sampled.AudioFormat;
|
||||
import javax.sound.sampled.AudioSystem;
|
||||
import javax.sound.sampled.Clip;
|
||||
import javax.sound.sampled.LineUnavailableException;
|
||||
|
||||
public class ClipSetPos {
|
||||
|
||||
final static AudioFormat audioFormat = new AudioFormat(44100f, 16, 2, true, true);
|
||||
final static int frameLength = 44100 * 2; // 2 seconds
|
||||
final static byte[] dataBuffer
|
||||
= new byte[frameLength * (audioFormat.getSampleSizeInBits()/8)
|
||||
* audioFormat.getChannels()];
|
||||
final static int MAX_FRAME_DELTA = 20;
|
||||
|
||||
public static void main(String[] args) {
|
||||
boolean testPassed = true;
|
||||
Clip clip = null;
|
||||
try {
|
||||
clip = AudioSystem.getClip();
|
||||
clip.open(audioFormat, dataBuffer, 0, dataBuffer.length);
|
||||
} catch (LineUnavailableException ex) {
|
||||
log(ex);
|
||||
log("Cannot test (this is not failure)");
|
||||
return;
|
||||
}
|
||||
|
||||
log("clip: " + clip.getClass().getName());
|
||||
|
||||
int len = clip.getFrameLength();
|
||||
for (int pos=0; pos < len; pos += (len /100)) {
|
||||
clip.setFramePosition(pos);
|
||||
int curPos = clip.getFramePosition();
|
||||
if (Math.abs(pos - curPos) > MAX_FRAME_DELTA) {
|
||||
log("Tried to set pos to " + pos + ", but got back " + curPos);
|
||||
testPassed = false;
|
||||
} else {
|
||||
log("Sucessfully set pos to " + pos);
|
||||
}
|
||||
}
|
||||
clip.close();
|
||||
|
||||
if (testPassed) {
|
||||
log("Test PASSED.");
|
||||
} else {
|
||||
log("Test FAILED.");
|
||||
throw new RuntimeException("Test FAILED (see log)");
|
||||
}
|
||||
}
|
||||
|
||||
static void log(String s) {
|
||||
System.out.println(s);
|
||||
}
|
||||
|
||||
static void log(Exception ex) {
|
||||
ex.printStackTrace(System.out);
|
||||
}
|
||||
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user