staging: dgap: Fix BUG in processing config file
authorMark Hounschell <markh@compro.net>
Wed, 23 Apr 2014 14:33:45 +0000 (10:33 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 16 May 2014 19:15:18 +0000 (12:15 -0700)
This patch fixes an OOPS caused by a pointer being
changed between the malloc and free.

Signed-off-by: Mark Hounschell <markh@compro.net>
Tested-by: Mark Hounschell <markh@compro.net>
Reported-by: Mark Hounschell <markh@compro.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/dgap/dgap.c

index e0b8d0f051ccec3b1a0ac99d777d6d5a9de95d3d..55a23b051e86c63699dab0cfd28babdde822a7c6 100644 (file)
@@ -820,6 +820,7 @@ static int dgap_firmware_load(struct pci_dev *pdev, int card_type)
 {
        struct board_t *brd = dgap_Board[dgap_NumBoards - 1];
        const struct firmware *fw;
+       char *tmp_ptr;
        int ret;
 
        dgap_get_vpd(brd);
@@ -843,7 +844,14 @@ static int dgap_firmware_load(struct pci_dev *pdev, int card_type)
                memcpy(dgap_config_buf, fw->data, fw->size);
                release_firmware(fw);
 
-               if (dgap_parsefile(&dgap_config_buf, TRUE) != 0) {
+               /*
+                * preserve dgap_config_buf
+                * as dgap_parsefile would
+                * otherwise alter it.
+                */
+               tmp_ptr = dgap_config_buf;
+
+               if (dgap_parsefile(&tmp_ptr, TRUE) != 0) {
                        kfree(dgap_config_buf);
                        return -EINVAL;
                }