mirror of https://github.com/xemu-project/xemu.git
audio: two intel-hda fixes.
-----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.22 (GNU/Linux) iQIcBAABAgAGBQJTfGijAAoJEEy22O7T6HE4tjwP/04IFQXzupdGsOSYpn6vZjXh v/G/j0CV6qCcmbqdbkP58EdDFnDCs++aWeXPmtN/R9V4XigEKlI9BUKLX+ZfTJC4 GuW5lcqE2PkGb26l1TTS+aU3HFLyx+xLurhAXqhHy21WUWduWnSe2xTTaL4dIVv7 YjfAncn8byAXcSNzyCMWoAA4uPVjIW8VcM/YfdJR1WLgrPbwgZ+i83Pm+xtn65sq slvH0adBM3wt1nfk5zuwcCkih9sI2R1BtimQvSF19Vt4wolUrknyrwaGlzoaJOB0 etrp4nAhL70dzT77hComyXPb5FFPdlSxGw9fYQT7I//QMduxA+FTUZjlCr7sLd+r xuQMo5ySxU+yttIEb2u7efybKJKcFT9ykz1X46Z56/XypKKX6XYJ5npQgpH+V8qY 1WaXjOQkgpEjjzFmJA4mbxl54LZfE/BJeU5VS9TMy1hHPsncw1zekZb/+NaUGU1b ta8wDkYZMri4fE+arUoTPuKY0bDiNDrRoTjoZDhV+Hj8poV694hlyLOTluOzmX0H iAgASm6jDm2mwp0MTHx/Un4MObqg/53QQ1sb23tBOxU8ANtn6MV9qZkfyVrFBg16 rSpL3oogz2S+KZXSMxD7USHYm361d7N9AY0jZJgIKfJjj23PGtLVK6a4QdIrHoK/ eYKFKWFPBxYMmJ0G3JPx =EfQz -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/kraxel/tags/pull-audio-5' into staging audio: two intel-hda fixes. # gpg: Signature made Wed 21 May 2014 09:49:39 BST using RSA key ID D3E87138 # gpg: Good signature from "Gerd Hoffmann (work) <kraxel@redhat.com>" # gpg: aka "Gerd Hoffmann <gerd@kraxel.org>" # gpg: aka "Gerd Hoffmann (private) <kraxel@gmail.com>" * remotes/kraxel/tags/pull-audio-5: hw/audio/intel-hda: Avoid shift into sign bit audio/intel-hda: support FIFORDY Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
5118dc5975
|
@ -245,7 +245,7 @@ static void intel_hda_update_int_sts(IntelHDAState *d)
|
|||
|
||||
/* update global status */
|
||||
if (sts & d->int_ctl) {
|
||||
sts |= (1 << 31);
|
||||
sts |= (1U << 31);
|
||||
}
|
||||
|
||||
d->int_sts = sts;
|
||||
|
@ -257,7 +257,7 @@ static void intel_hda_update_irq(IntelHDAState *d)
|
|||
int level;
|
||||
|
||||
intel_hda_update_int_sts(d);
|
||||
if (d->int_sts & (1 << 31) && d->int_ctl & (1 << 31)) {
|
||||
if (d->int_sts & (1U << 31) && d->int_ctl & (1U << 31)) {
|
||||
level = 1;
|
||||
} else {
|
||||
level = 0;
|
||||
|
@ -574,7 +574,7 @@ static void intel_hda_set_st_ctl(IntelHDAState *d, const IntelHDAReg *reg, uint3
|
|||
if (st->ctl & 0x01) {
|
||||
/* reset */
|
||||
dprint(d, 1, "st #%d: reset\n", reg->stream);
|
||||
st->ctl = 0;
|
||||
st->ctl = SD_STS_FIFO_READY << 24;
|
||||
}
|
||||
if ((st->ctl & 0x02) != (old & 0x02)) {
|
||||
uint32_t stnr = (st->ctl >> 20) & 0x0f;
|
||||
|
@ -829,6 +829,7 @@ static const struct IntelHDAReg regtab[] = {
|
|||
.wclear = 0x1c000000, \
|
||||
.offset = offsetof(IntelHDAState, st[_i].ctl), \
|
||||
.whandler = intel_hda_set_st_ctl, \
|
||||
.reset = SD_STS_FIFO_READY << 24 \
|
||||
}, \
|
||||
[ ST_REG(_i, ICH6_REG_SD_LPIB) ] = { \
|
||||
.stream = _i, \
|
||||
|
|
Loading…
Reference in New Issue