]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
hw/audio/fmopl: fix segmentation fault
authorVolker Rümelin <vr_qemu@t-online.de>
Tue, 24 Mar 2020 06:18:55 +0000 (07:18 +0100)
committerGerd Hoffmann <kraxel@redhat.com>
Wed, 25 Mar 2020 08:55:40 +0000 (09:55 +0100)
Current code allocates the memory for ENV_CURVE too late. Move
allocation to OPLOpenTable() and deallocation to OPLCloseTable().

To reproduce the bug start qemu with -soundhw adlib.

Fixes 2eea51bd01 "hw/audio/fmopl: Move ENV_CURVE to .heap to save
32KiB of .bss"

Signed-off-by: Volker Rümelin <vr_qemu@t-online.de>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Message-id: 20200324061855.5951-1-vr_qemu@t-online.de
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
hw/audio/fmopl.c

index 356d4dfbcaa6de72a4df327fbbd5267d88ad69aa..8a71a569fab0ecc3424ddc6e1896e24c8beadac1 100644 (file)
@@ -627,6 +627,7 @@ static int OPLOpenTable( void )
                free(AMS_TABLE);
                return 0;
        }
+    ENV_CURVE = g_new(int32_t, 2 * EG_ENT + 1);
        /* make total level table */
        for (t = 0;t < EG_ENT-1 ;t++){
                rate = ((1<<TL_BITS)-1)/pow(10,EG_STEP*t/20);   /* dB -> voltage */
@@ -694,6 +695,7 @@ static int OPLOpenTable( void )
 
 static void OPLCloseTable( void )
 {
+    g_free(ENV_CURVE);
        free(TL_TABLE);
        free(SIN_TABLE);
        free(AMS_TABLE);
@@ -1090,7 +1092,6 @@ FM_OPL *OPLCreate(int clock, int rate)
        OPL->clock = clock;
        OPL->rate  = rate;
        OPL->max_ch = max_ch;
-    ENV_CURVE = g_new(int32_t, 2 * EG_ENT + 1);
        /* init grobal tables */
        OPL_initialize(OPL);
        /* reset chip */
@@ -1128,7 +1129,6 @@ void OPLDestroy(FM_OPL *OPL)
 #endif
        OPL_UnLockTable();
        free(OPL);
-    g_free(ENV_CURVE);
 }
 
 /* ----------  Option handlers ----------       */