Skip to content

Commit 1338fc9

Browse files
jrhackertiwai
authored andcommitted
ALSA: emu8000: fix emu8000 DRAM sized 512 KiB too small
v2: Fixed result still wrong in the case of 512 KiB DRAM. Oops. Applicable to 3.5.3 mainline. In emu8000.c, size_dram determines the amount of memory on the sound card by doing write/readback tests starting at 512 KiB and incrementing by 512 KiB. On success, detected_size is updated to the successful address and testing continues. On failure, the loop is immediately exited. The resulting detected_size is 512 KiB too small except in two special cases: 1. If there is no memory, the initial 0 value of detected_size is used, which is correct. 2. If the address space wraps around, detected_size is updated before the bailout, so the result is correct. The patch corrects all cases and was tested with an AWE64 Gold. Before: EMU8000 [0x620]: 3584 Kb on-board memory detected asfxload 4GMGSMT.SF2 (4174814 B) fails. After: EMU8000 [0x620]: 4096 Kb on-board memory detected asfxload 4GMGSMT.SF2 succeeds. I do not have a card with 512 KiB to test with, but by forcibly enabling the added conditional I verified on the AWE64 Gold that it detects 512 KiB (successfully reading from the first memory location) and does not hang the card. C.f. Bug 46451 https://bugzilla.kernel.org/show_bug.cgi?id=46451 Signed-off-by: David Flater <[email protected]> Signed-off-by: Takashi Iwai <[email protected]>
1 parent a184d4e commit 1338fc9

File tree

1 file changed

+12
-3
lines changed

1 file changed

+12
-3
lines changed

sound/isa/sb/emu8000.c

Lines changed: 12 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -417,9 +417,6 @@ size_dram(struct snd_emu8000 *emu)
417417
EMU8000_SMLD_READ(emu); /* discard stale data */
418418
if (EMU8000_SMLD_READ(emu) != UNIQUE_ID2)
419419
break; /* no memory at this address */
420-
421-
detected_size = size;
422-
423420
snd_emu8000_read_wait(emu);
424421

425422
/*
@@ -432,6 +429,18 @@ size_dram(struct snd_emu8000 *emu)
432429
if (EMU8000_SMLD_READ(emu) != UNIQUE_ID1)
433430
break; /* we must have wrapped around */
434431
snd_emu8000_read_wait(emu);
432+
433+
/* Otherwise, it's valid memory. */
434+
detected_size = size + 512 * 1024;
435+
}
436+
437+
/* Distinguish 512 KiB from 0. */
438+
if (detected_size == 0) {
439+
snd_emu8000_read_wait(emu);
440+
EMU8000_SMALR_WRITE(emu, EMU8000_DRAM_OFFSET);
441+
EMU8000_SMLD_READ(emu); /* discard stale data */
442+
if (EMU8000_SMLD_READ(emu) == UNIQUE_ID1)
443+
detected_size = 512 * 1024;
435444
}
436445

437446
/* wait until FULL bit in SMAxW register is false */

0 commit comments

Comments
 (0)