2012-09-11 20:22:27 +02:00
|
|
|
/****************************************************************************
|
2014-09-22 18:33:23 +02:00
|
|
|
* mm/mm_gran/mm_gran.h
|
2012-09-11 20:22:27 +02:00
|
|
|
*
|
2021-02-08 13:50:10 +01:00
|
|
|
* 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
|
2012-09-11 20:22:27 +02:00
|
|
|
*
|
2021-02-08 13:50:10 +01:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2012-09-11 20:22:27 +02:00
|
|
|
*
|
2021-02-08 13:50:10 +01:00
|
|
|
* 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.
|
2012-09-11 20:22:27 +02:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2014-09-23 16:46:31 +02:00
|
|
|
#ifndef __MM_MM_GRAN_MM_GRAN_H
|
|
|
|
#define __MM_MM_GRAN_MM_GRAN_H
|
2012-09-11 20:22:27 +02:00
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
2012-09-11 22:33:58 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2012-09-12 17:18:56 +02:00
|
|
|
#include <arch/types.h>
|
2014-09-24 14:55:26 +02:00
|
|
|
#include <nuttx/mm/gran.h>
|
2022-09-06 08:18:45 +02:00
|
|
|
#include <nuttx/mutex.h>
|
2023-10-21 11:20:02 +02:00
|
|
|
#include <nuttx/spinlock.h>
|
2012-09-11 20:22:27 +02:00
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Pre-processor Definitions
|
|
|
|
****************************************************************************/
|
|
|
|
|
2012-09-11 22:33:58 +02:00
|
|
|
/* Sizes of things */
|
|
|
|
|
2012-09-11 20:22:27 +02:00
|
|
|
#define SIZEOF_GAT(n) \
|
|
|
|
((n + 31) >> 5)
|
|
|
|
#define SIZEOF_GRAN_S(n) \
|
|
|
|
(sizeof(struct gran_s) + sizeof(uint32_t) * (SIZEOF_GAT(n) - 1))
|
|
|
|
|
2012-09-11 22:33:58 +02:00
|
|
|
/* Debug */
|
|
|
|
|
2020-05-04 12:55:11 +02:00
|
|
|
#ifdef CONFIG_DEBUG_GRAM
|
|
|
|
# define granerr _err
|
|
|
|
# define granwarn _warn
|
|
|
|
# define graninfo _info
|
2012-09-11 22:33:58 +02:00
|
|
|
#else
|
2020-05-04 12:55:11 +02:00
|
|
|
# define granerr merr
|
|
|
|
# define granwarn mwarn
|
|
|
|
# define graninfo minfo
|
2012-09-11 22:33:58 +02:00
|
|
|
#endif
|
|
|
|
|
2012-09-11 20:22:27 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Types
|
|
|
|
****************************************************************************/
|
|
|
|
|
2014-09-23 16:46:31 +02:00
|
|
|
/* This structure represents the state of one granule allocation */
|
2012-09-11 20:22:27 +02:00
|
|
|
|
|
|
|
struct gran_s
|
|
|
|
{
|
|
|
|
uint8_t log2gran; /* Log base 2 of the size of one granule */
|
|
|
|
uint16_t ngranules; /* The total number of (aligned) granules in the heap */
|
2012-09-12 17:18:56 +02:00
|
|
|
#ifdef CONFIG_GRAN_INTR
|
|
|
|
irqstate_t irqstate; /* For exclusive access to the GAT */
|
2023-10-21 11:20:02 +02:00
|
|
|
spinlock_t lock;
|
2012-09-12 17:18:56 +02:00
|
|
|
#else
|
2022-09-06 08:18:45 +02:00
|
|
|
mutex_t lock; /* For exclusive access to the GAT */
|
2012-09-12 17:18:56 +02:00
|
|
|
#endif
|
2012-09-11 20:22:27 +02:00
|
|
|
uintptr_t heapstart; /* The aligned start of the granule heap */
|
2012-09-11 22:33:58 +02:00
|
|
|
uint32_t gat[1]; /* Start of the granule allocation table */
|
2012-09-11 20:22:27 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Public Function Prototypes
|
|
|
|
****************************************************************************/
|
|
|
|
|
2012-09-11 23:39:39 +02:00
|
|
|
/****************************************************************************
|
2012-09-12 17:18:56 +02:00
|
|
|
* Name: gran_enter_critical and gran_leave_critical
|
2012-09-11 23:39:39 +02:00
|
|
|
*
|
|
|
|
* Description:
|
2012-09-12 17:18:56 +02:00
|
|
|
* Critical section management for the granule allocator.
|
2012-09-11 23:39:39 +02:00
|
|
|
*
|
|
|
|
* Input Parameters:
|
|
|
|
* priv - Pointer to the gran state
|
|
|
|
*
|
|
|
|
* Returned Value:
|
2020-03-29 19:57:53 +02:00
|
|
|
* gran_enter_critical() may return any error reported by
|
|
|
|
* nxsem_wait_uninterruptible()
|
2012-09-11 23:39:39 +02:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2020-03-29 19:57:53 +02:00
|
|
|
int gran_enter_critical(FAR struct gran_s *priv);
|
2012-09-12 17:18:56 +02:00
|
|
|
void gran_leave_critical(FAR struct gran_s *priv);
|
2012-09-11 23:39:39 +02:00
|
|
|
|
2014-08-23 20:43:21 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: gran_mark_allocated
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Mark a range of granules as allocated.
|
|
|
|
*
|
|
|
|
* Input Parameters:
|
|
|
|
* priv - The granule heap state structure.
|
|
|
|
* alloc - The address of the allocation.
|
|
|
|
* ngranules - The number of granules allocated
|
|
|
|
*
|
|
|
|
* Returned Value:
|
2022-11-17 12:39:17 +01:00
|
|
|
* On success, a non-NULL pointer to the allocated memory is returned;
|
|
|
|
* NULL is returned on failure.
|
2014-08-23 20:43:21 +02:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2022-11-17 12:39:17 +01:00
|
|
|
FAR void *gran_mark_allocated(FAR struct gran_s *priv, uintptr_t alloc,
|
|
|
|
unsigned int ngranules);
|
2014-08-23 20:43:21 +02:00
|
|
|
|
2014-09-23 16:46:31 +02:00
|
|
|
#endif /* __MM_MM_GRAN_MM_GRAN_H */
|