Correct more improper use of malloc(), zalloc(), and free()
malloc() and free() should never be used within the OS. This will work in the FLAT build because there is only a single heap, but will cause problems in PROTECTED and KERNEL build modes where there are separate heaps for user and kernel memory. Typically kmm_malloc(), kmm_zalloc(), and kmm_free() should be called within the kernel in those build modes to use the kernel heap. Memory is never free. Possible memory leak: ./boards/arm/cxd56xx/common/src/cxd56_crashdump.c: pdump = malloc(sizeof(fullcontext_t)); Memory allocated with malloc(), but freed with kmm_free(): ./drivers/usbhost/usbhost_composite.c: cfgbuffer = (FAR uint8_t *)malloc(CUSTOM_CONFIG_BUFSIZE); Memory is never freed in these cases. It is allocated in the driver initialization logic, but there is no corresponding uninitialization logic; memory is not freed on error conditions: ./arch/arm/src/lc823450/lc823450_i2s.c: priv = (struct lc823450_i2s_s *)zalloc(sizeof(struct lc823450_i2s_s)); ./arch/arm/src/sam34/sam_spi.c: spics = (struct sam_spics_s *)zalloc(sizeof(struct sam_spics_s)); ./arch/arm/src/sama5/sam_spi.c: spics = (struct sam_spics_s *)zalloc(sizeof(struct sam_spics_s)); ./arch/arm/src/samv7/sam_spi.c: spics = (struct sam_spics_s *)zalloc(sizeof(struct sam_spics_s)); Memory is allocated with zalloc() but freed on error conditions with kmm_free(): ./arch/arm/src/sama5/sam_ssc.c: priv = (struct sam_ssc_s *)zalloc(sizeof(struct sam_ssc_s)); ./arch/arm/src/samv7/sam_ssc.c: priv = (struct sam_ssc_s *)zalloc(sizeof(struct sam_ssc_s)); ./arch/arm/src/stm32/stm32_i2s.c: priv = (struct stm32_i2s_s *)zalloc(sizeof(struct stm32_i2s_s)); Memory is never freed: ./drivers/spi/spi_bitbang.c: priv = (FAR struct spi_bitbang_s *)zalloc(sizeof(struct spi_bitbang_s));
This commit is contained in:
parent
2dae970ec6
commit
d09f6aaa72
10 changed files with 84 additions and 97 deletions
|
@ -1017,7 +1017,7 @@ FAR struct i2s_dev_s *lc823450_i2sdev_initialize(void)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
priv = (struct lc823450_i2s_s *)zalloc(sizeof(struct lc823450_i2s_s));
|
||||
priv = (struct lc823450_i2s_s *)kmm_zalloc(sizeof(struct lc823450_i2s_s));
|
||||
if (!priv)
|
||||
{
|
||||
i2serr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
|
|
@ -54,6 +54,7 @@
|
|||
|
||||
#include <nuttx/irq.h>
|
||||
#include <nuttx/arch.h>
|
||||
#include <nuttx/kmalloc.h>
|
||||
#include <nuttx/wdog.h>
|
||||
#include <nuttx/clock.h>
|
||||
#include <nuttx/semaphore.h>
|
||||
|
@ -1745,7 +1746,7 @@ struct spi_dev_s *sam_spibus_initialize(int port)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
spics = (struct sam_spics_s *)zalloc(sizeof(struct sam_spics_s));
|
||||
spics = (struct sam_spics_s *)kmm_zalloc(sizeof(struct sam_spics_s));
|
||||
if (!spics)
|
||||
{
|
||||
spierr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
@ -1753,7 +1754,7 @@ struct spi_dev_s *sam_spibus_initialize(int port)
|
|||
}
|
||||
|
||||
/* Set up the initial state for this chip select structure. Other fields
|
||||
* were zeroed by zalloc().
|
||||
* were zeroed by kmm_zalloc().
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_SAM34_SPI_DMA
|
||||
|
|
|
@ -57,6 +57,7 @@
|
|||
|
||||
#include <nuttx/irq.h>
|
||||
#include <nuttx/arch.h>
|
||||
#include <nuttx/kmalloc.h>
|
||||
#include <nuttx/wdog.h>
|
||||
#include <nuttx/clock.h>
|
||||
#include <nuttx/semaphore.h>
|
||||
|
@ -1674,7 +1675,7 @@ struct spi_dev_s *sam_spibus_initialize(int port)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
spics = (struct sam_spics_s *)zalloc(sizeof(struct sam_spics_s));
|
||||
spics = (struct sam_spics_s *)kmm_zalloc(sizeof(struct sam_spics_s));
|
||||
if (!spics)
|
||||
{
|
||||
spierr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
@ -1682,7 +1683,7 @@ struct spi_dev_s *sam_spibus_initialize(int port)
|
|||
}
|
||||
|
||||
/* Set up the initial state for this chip select structure. Other fields
|
||||
* were zeroed by zalloc().
|
||||
* were zeroed by kmm_zalloc().
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_SAMA5_SPI_DMA
|
||||
|
|
|
@ -3424,7 +3424,7 @@ struct i2s_dev_s *sam_ssc_initialize(int port)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
priv = (struct sam_ssc_s *)zalloc(sizeof(struct sam_ssc_s));
|
||||
priv = (struct sam_ssc_s *)kmm_zalloc(sizeof(struct sam_ssc_s));
|
||||
if (!priv)
|
||||
{
|
||||
i2serr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
@ -3432,7 +3432,7 @@ struct i2s_dev_s *sam_ssc_initialize(int port)
|
|||
}
|
||||
|
||||
/* Set up the initial state for this chip select structure. Other fields
|
||||
* were zeroed by zalloc().
|
||||
* were zeroed by kmm_zalloc().
|
||||
*/
|
||||
|
||||
/* Initialize the common parts for the SSC device structure */
|
||||
|
|
|
@ -53,6 +53,7 @@
|
|||
|
||||
#include <nuttx/irq.h>
|
||||
#include <nuttx/arch.h>
|
||||
#include <nuttx/kmalloc.h>
|
||||
#include <nuttx/wdog.h>
|
||||
#include <nuttx/clock.h>
|
||||
#include <nuttx/semaphore.h>
|
||||
|
@ -2020,7 +2021,7 @@ FAR struct spi_dev_s *sam_spibus_initialize(int port)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
spics = (struct sam_spics_s *)zalloc(sizeof(struct sam_spics_s));
|
||||
spics = (struct sam_spics_s *)kmm_zalloc(sizeof(struct sam_spics_s));
|
||||
if (!spics)
|
||||
{
|
||||
spierr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
@ -2028,7 +2029,7 @@ FAR struct spi_dev_s *sam_spibus_initialize(int port)
|
|||
}
|
||||
|
||||
/* Set up the initial state for this chip select structure. Other fields
|
||||
* were zeroed by zalloc().
|
||||
* were zeroed by kmm_zalloc().
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_SAMV7_SPI_DMA
|
||||
|
|
|
@ -3407,7 +3407,7 @@ struct i2s_dev_s *sam_ssc_initialize(int port)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
priv = (struct sam_ssc_s *)zalloc(sizeof(struct sam_ssc_s));
|
||||
priv = (struct sam_ssc_s *)kmm_zalloc(sizeof(struct sam_ssc_s));
|
||||
if (!priv)
|
||||
{
|
||||
i2serr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
|
|
@ -72,17 +72,15 @@
|
|||
|
||||
#include <nuttx/arch.h>
|
||||
#include <nuttx/semaphore.h>
|
||||
#include <nuttx/spi/spi.h>
|
||||
|
||||
#include <arch/board/board.h>
|
||||
|
||||
#include <nuttx/arch.h>
|
||||
#include <nuttx/kmalloc.h>
|
||||
#include <nuttx/wdog.h>
|
||||
#include <nuttx/wqueue.h>
|
||||
#include <nuttx/spi/spi.h>
|
||||
#include <nuttx/audio/audio.h>
|
||||
#include <nuttx/audio/i2s.h>
|
||||
|
||||
#include <arch/board/board.h>
|
||||
|
||||
#include "arm_internal.h"
|
||||
#include "arm_arch.h"
|
||||
|
||||
|
@ -2632,7 +2630,7 @@ FAR struct i2s_dev_s *stm32_i2sbus_initialize(int port)
|
|||
* chip select structures.
|
||||
*/
|
||||
|
||||
priv = (struct stm32_i2s_s *)zalloc(sizeof(struct stm32_i2s_s));
|
||||
priv = (struct stm32_i2s_s *)kmm_zalloc(sizeof(struct stm32_i2s_s));
|
||||
if (!priv)
|
||||
{
|
||||
i2serr("ERROR: Failed to allocate a chip select structure\n");
|
||||
|
@ -2640,7 +2638,7 @@ FAR struct i2s_dev_s *stm32_i2sbus_initialize(int port)
|
|||
}
|
||||
|
||||
/* Set up the initial state for this chip select structure. Other fields
|
||||
* were zeroed by zalloc().
|
||||
* were zeroed by kmm_zalloc().
|
||||
*/
|
||||
|
||||
/* Initialize the common parts for the I2S device structure */
|
||||
|
|
|
@ -47,6 +47,8 @@
|
|||
#include <debug.h>
|
||||
#include <time.h>
|
||||
|
||||
#include <nuttx/kmalloc.h>
|
||||
|
||||
#include <arch/chip/backuplog.h>
|
||||
#include <arch/chip/crashdump.h>
|
||||
#include "cxd56_wdt.h"
|
||||
|
@ -125,7 +127,7 @@ void board_crashdump(uintptr_t currentsp, FAR void *tcb,
|
|||
#ifdef CONFIG_CXD56_BACKUPLOG
|
||||
pdump = up_backuplog_alloc("crash", sizeof(fullcontext_t));
|
||||
#else
|
||||
pdump = malloc(sizeof(fullcontext_t));
|
||||
pdump = kmm_malloc(sizeof(fullcontext_t));
|
||||
#endif
|
||||
if (!pdump)
|
||||
{
|
||||
|
|
|
@ -1,35 +1,20 @@
|
|||
/****************************************************************************
|
||||
* drivers/spi/spi_bitbang.c
|
||||
*
|
||||
* Copyright (C) 2013, 2016-2017 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership. The
|
||||
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance with the
|
||||
* License. You may obtain a copy of the License at
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
* License for the specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
|
@ -44,6 +29,7 @@
|
|||
#include <errno.h>
|
||||
#include <debug.h>
|
||||
|
||||
#include <nuttx/kmalloc.h>
|
||||
#include <nuttx/spi/spi.h>
|
||||
#include <nuttx/spi/spi_bitbang.h>
|
||||
|
||||
|
@ -537,7 +523,8 @@ FAR struct spi_dev_s *spi_create_bitbang(FAR const struct
|
|||
|
||||
/* Allocate an instance of the SPI bit bang structure */
|
||||
|
||||
priv = (FAR struct spi_bitbang_s *)zalloc(sizeof(struct spi_bitbang_s));
|
||||
priv = (FAR struct spi_bitbang_s *)
|
||||
kmm_zalloc(sizeof(struct spi_bitbang_s));
|
||||
if (!priv)
|
||||
{
|
||||
spierr("ERROR: Failed to allocate the device structure\n");
|
||||
|
|
|
@ -1,35 +1,20 @@
|
|||
/****************************************************************************
|
||||
* drivers/usbhost/usbhost_composite.c
|
||||
*
|
||||
* Copyright (C) 2016 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership. The
|
||||
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance with the
|
||||
* License. You may obtain a copy of the License at
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
* License for the specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
|
@ -196,11 +181,11 @@ static void usbhost_disconnect_all(FAR struct usbhost_composite_s *priv)
|
|||
* desclen - The length in bytes of the configuration descriptor.
|
||||
*
|
||||
* Returned Value:
|
||||
* On success, zero (OK) is returned. On a failure, a negated errno value is
|
||||
* returned indicating the nature of the failure
|
||||
* On success, zero (OK) is returned. On a failure, a negated errno value
|
||||
* is returned indicating the nature of the failure
|
||||
*
|
||||
* NOTE that the class instance remains valid upon return with a failure. It is
|
||||
* the responsibility of the higher level enumeration logic to call
|
||||
* NOTE that the class instance remains valid upon return with a failure.
|
||||
* It is the responsibility of the higher level enumeration logic to call
|
||||
* CLASS_DISCONNECTED to free up the class driver resources.
|
||||
*
|
||||
* Assumptions:
|
||||
|
@ -240,7 +225,8 @@ static int usbhost_connect(FAR struct usbhost_class_s *usbclass,
|
|||
|
||||
static int usbhost_disconnected(struct usbhost_class_s *usbclass)
|
||||
{
|
||||
FAR struct usbhost_composite_s *priv = (FAR struct usbhost_composite_s *)usbclass;
|
||||
FAR struct usbhost_composite_s *priv =
|
||||
(FAR struct usbhost_composite_s *)usbclass;
|
||||
|
||||
DEBUGASSERT(priv != NULL);
|
||||
|
||||
|
@ -287,7 +273,8 @@ static int usbhost_disconnected(struct usbhost_class_s *usbclass)
|
|||
****************************************************************************/
|
||||
|
||||
static int usbhost_copyinterface(uint8_t ifno, FAR const uint8_t *configdesc,
|
||||
int desclen, FAR uint8_t *buffer, int buflen)
|
||||
int desclen, FAR uint8_t *buffer,
|
||||
int buflen)
|
||||
{
|
||||
FAR struct usb_desc_s *desc;
|
||||
FAR struct usb_ifdesc_s *ifdesc;
|
||||
|
@ -383,20 +370,25 @@ static int usbhost_copyinterface(uint8_t ifno, FAR const uint8_t *configdesc,
|
|||
buflen -= len;
|
||||
retsize += len;
|
||||
|
||||
/* And reduce the number of endpoints we are looking for */
|
||||
/* And reduce the number of endpoints we are looking
|
||||
* for.
|
||||
*/
|
||||
|
||||
if (--neps <= 0)
|
||||
{
|
||||
/* That is all of them! Return the total size copied */
|
||||
/* That is all of them! Return the total size
|
||||
* copied.
|
||||
*/
|
||||
|
||||
return retsize;
|
||||
}
|
||||
}
|
||||
|
||||
/* The endpoint descriptors following the interface descriptor
|
||||
* should all be contiguous. But we will complain only if another
|
||||
* interface descriptor is encountered before all of the endpoint
|
||||
* descriptors have been found.
|
||||
/* The endpoint descriptors following the interface
|
||||
* descriptor should all be contiguous. But we will
|
||||
* complain only if another interface descriptor is
|
||||
* encountered before all of the endpoint descriptors have
|
||||
* been found.
|
||||
*/
|
||||
|
||||
else if (desc->type == USB_DESC_TYPE_INTERFACE)
|
||||
|
@ -614,7 +606,8 @@ int usbhost_composite(FAR struct usbhost_hubport_s *hport,
|
|||
|
||||
else if (desc->type == USB_DESC_TYPE_INTERFACEASSOCIATION)
|
||||
{
|
||||
FAR struct usb_iaddesc_s *iad = (FAR struct usb_iaddesc_s *)desc;
|
||||
FAR struct usb_iaddesc_s *iad =
|
||||
(FAR struct usb_iaddesc_s *)desc;
|
||||
uint32_t mask;
|
||||
|
||||
/* Keep count of the number of interfaces that will be merged */
|
||||
|
@ -721,7 +714,8 @@ int usbhost_composite(FAR struct usbhost_hubport_s *hport,
|
|||
* lookup information from the interface descriptor.
|
||||
*/
|
||||
|
||||
member = (FAR struct usbhost_member_s *)&priv->members[i];
|
||||
member = (FAR struct usbhost_member_s *)
|
||||
&priv->members[i];
|
||||
member->id.base = ifdesc->classid;
|
||||
member->id.subclass = ifdesc->subclass;
|
||||
member->id.proto = ifdesc->protocol;
|
||||
|
@ -744,11 +738,13 @@ int usbhost_composite(FAR struct usbhost_hubport_s *hport,
|
|||
|
||||
else if (desc->type == USB_DESC_TYPE_INTERFACEASSOCIATION)
|
||||
{
|
||||
FAR struct usb_iaddesc_s *iad = (FAR struct usb_iaddesc_s *)desc;
|
||||
FAR struct usb_iaddesc_s *iad =
|
||||
(FAR struct usb_iaddesc_s *)desc;
|
||||
|
||||
/* Yes.. Save the registry lookup information from the IAD. */
|
||||
|
||||
member = (FAR struct usbhost_member_s *)&priv->members[i];
|
||||
member = (FAR struct usbhost_member_s *)
|
||||
&priv->members[i];
|
||||
member->id.base = iad->classid;
|
||||
member->id.subclass = iad->subclass;
|
||||
member->id.proto = iad->protocol;
|
||||
|
@ -777,7 +773,7 @@ int usbhost_composite(FAR struct usbhost_hubport_s *hport,
|
|||
* configuration descriptor for each member class.
|
||||
*/
|
||||
|
||||
cfgbuffer = (FAR uint8_t *)malloc(CUSTOM_CONFIG_BUFSIZE);
|
||||
cfgbuffer = (FAR uint8_t *)kmm_malloc(CUSTOM_CONFIG_BUFSIZE);
|
||||
if (cfgbuffer == NULL)
|
||||
{
|
||||
uerr("ERROR: Failed to allocate configuration buffer");
|
||||
|
@ -877,6 +873,7 @@ errout_with_members:
|
|||
}
|
||||
|
||||
errout_with_container:
|
||||
|
||||
/* Then free the composite container itself */
|
||||
|
||||
kmm_free(priv);
|
||||
|
|
Loading…
Reference in a new issue