qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [Qemu-devel] [4696] Fix some signedness issues caught by gcc 4.3
@ 2008-06-08  1:42 malc
  0 siblings, 0 replies; only message in thread
From: malc @ 2008-06-08  1:42 UTC (permalink / raw)
  To: qemu-devel

Revision: 4696
          http://svn.sv.gnu.org/viewvc/?view=rev&root=qemu&revision=4696
Author:   malc
Date:     2008-06-08 01:42:47 +0000 (Sun, 08 Jun 2008)

Log Message:
-----------
Fix some signedness issues caught by gcc 4.3

Modified Paths:
--------------
    trunk/hw/gus.c
    trunk/hw/gusemu.h
    trunk/hw/gusemu_mixer.c

Modified: trunk/hw/gus.c
===================================================================
--- trunk/hw/gus.c	2008-06-08 01:09:01 UTC (rev 4695)
+++ trunk/hw/gus.c	2008-06-08 01:42:47 UTC (rev 4696)
@@ -58,7 +58,7 @@
     QEMUSoundCard card;
     int freq;
     int pos, left, shift, irqs;
-    uint16_t *mixbuf;
+    GUSsample *mixbuf;
     uint8_t himem[1024 * 1024 + 32 + 4096];
     int samples;
     SWVoiceOut *voice;
@@ -198,7 +198,7 @@
 int GUS_read_DMA (void *opaque, int nchan, int dma_pos, int dma_len)
 {
     GUSState *s = opaque;
-    int8_t tmpbuf[4096];
+    char tmpbuf[4096];
     int pos = dma_pos, mode, left = dma_len - dma_pos;
 
     ldebug ("read DMA %#x %d\n", dma_pos, dma_len);

Modified: trunk/hw/gusemu.h
===================================================================
--- trunk/hw/gusemu.h	2008-06-08 01:09:01 UTC (rev 4695)
+++ trunk/hw/gusemu.h	2008-06-08 01:42:47 UTC (rev 4696)
@@ -32,12 +32,14 @@
  typedef unsigned short GUSword;
  typedef unsigned int GUSdword;
  typedef signed char GUSchar;
+ typedef signed short GUSsample;
 #else
  #include <stdint.h>
  typedef int8_t GUSchar;
  typedef uint8_t GUSbyte;
  typedef uint16_t GUSword;
  typedef uint32_t GUSdword;
+ typedef int16_t GUSsample;
 #endif
 
 typedef struct _GUSEmuState
@@ -91,7 +93,7 @@
 /* If the interrupts are asynchronous, it may be needed to use a separate thread mixing into a temporary */
 /* audio buffer in order to avoid quality loss caused by large numsamples and elapsed_time values. */
 
-void gus_mixvoices(GUSEmuState *state, unsigned int playback_freq, unsigned int numsamples, short *bufferpos);
+void gus_mixvoices(GUSEmuState *state, unsigned int playback_freq, unsigned int numsamples, GUSsample *bufferpos);
 /* recommended range: 10 < numsamples < 100 */
 /* lower values may result in increased rounding error, higher values often cause audible timing delays */
 

Modified: trunk/hw/gusemu_mixer.c
===================================================================
--- trunk/hw/gusemu_mixer.c	2008-06-08 01:09:01 UTC (rev 4695)
+++ trunk/hw/gusemu_mixer.c	2008-06-08 01:42:47 UTC (rev 4696)
@@ -33,7 +33,7 @@
 
 /* samples are always 16bit stereo (4 bytes each, first right then left interleaved) */
 void gus_mixvoices(GUSEmuState * state, unsigned int playback_freq, unsigned int numsamples,
-                   short *bufferpos)
+                   GUSsample *bufferpos)
 {
     /* note that byte registers are stored in the upper half of each voice register! */
     GUSbyte        *gusptr;
@@ -170,8 +170,8 @@
                 }
 
                 /* mix samples into buffer */
-                *(bufferpos + 2 * sample)     += (short) ((sample1 * PanningPos) >> 4);        /* right */
-                *(bufferpos + 2 * sample + 1) += (short) ((sample1 * (15 - PanningPos)) >> 4); /* left */
+                *(bufferpos + 2 * sample)     += (GUSsample) ((sample1 * PanningPos) >> 4);        /* right */
+                *(bufferpos + 2 * sample + 1) += (GUSsample) ((sample1 * (15 - PanningPos)) >> 4); /* left */
             }
             /* write back voice and volume */
             GUSvoice(wVSRCurrVol)   = Volume32 / 32;

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2008-06-08  1:42 UTC | newest]

Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-06-08  1:42 [Qemu-devel] [4696] Fix some signedness issues caught by gcc 4.3 malc

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).