Mouse code for the MacroRat

Dependencies:   ITG3200 QEI

mbed-dev/targets/TARGET_Silicon_Labs/TARGET_SL_RAIL/efr32-rf-driver/buffer-pool-memory-manager/buffer_pool_allocator.c

Committer:
sahilmgandhi
Date:
2017-06-03
Revision:
46:b156ef445742
Parent:
18:6a4db94011d3

File content as of revision 46:b156ef445742:

/***************************************************************************//**
 * @file buffer_pool_allocator.c
 * @brief The source for a simple memory allocator that statically creates pools
 *        of fixed size buffers to allocate from.
 * @copyright Copyright 2015 Silicon Laboratories, Inc. http://www.silabs.com
 ******************************************************************************/

#include <stdlib.h>

#include "buffer_pool_allocator.h"

#include "em_core.h"

#ifdef CONFIGURATION_HEADER
#include CONFIGURATION_HEADER
#endif

// -----------------------------------------------------------------------------
// Configuration Macros
// -----------------------------------------------------------------------------

#ifndef BUFFER_POOL_SIZE
#define BUFFER_POOL_SIZE 8
#endif
#ifndef MAX_BUFFER_SIZE
#define MAX_BUFFER_SIZE 160
#endif

#define INVALID_BUFFER_OBJ ((void*)0xFFFFFFFF)

typedef struct {
  uint8_t refCount;
  uint8_t data[MAX_BUFFER_SIZE];
} BufferPoolObj_t;

static BufferPoolObj_t memoryObjs[BUFFER_POOL_SIZE];

void* memoryAllocate(uint32_t size)
{
  uint32_t i = 0;
  void *handle = INVALID_BUFFER_OBJ;

  // We can't support sizes greater than the maximum heap buffer size
  if(size > MAX_BUFFER_SIZE) {
    return INVALID_BUFFER_OBJ;
  }

  CORE_DECLARE_IRQ_STATE;
  CORE_ENTER_CRITICAL();
  for(i = 0; i < BUFFER_POOL_SIZE; i++)
  {
    if(memoryObjs[i].refCount == 0)
    {
      memoryObjs[i].refCount = 1;
      handle = (void*)i;
      break;
    }
  }
  CORE_EXIT_CRITICAL();

  return handle;
}

void *memoryPtrFromHandle(void *handle)
{
  void *ptr = NULL;

  // Make sure we were given a valid handle
  if((handle == INVALID_BUFFER_OBJ) || ((uint32_t)handle > BUFFER_POOL_SIZE))
  {
    return NULL;
  }

  CORE_DECLARE_IRQ_STATE;
  CORE_ENTER_CRITICAL();
  if(memoryObjs[(uint32_t)handle].refCount > 0)
  {
    ptr = memoryObjs[(uint32_t)handle].data;
  }
  CORE_EXIT_CRITICAL();

  return ptr;
}

void memoryFree(void *handle)
{
  CORE_DECLARE_IRQ_STATE;
  CORE_ENTER_CRITICAL();
  if(memoryPtrFromHandle(handle) != NULL)
  {
    memoryObjs[(uint32_t)handle].refCount--;
  }
  CORE_EXIT_CRITICAL();
}

void memoryTakeReference(void *handle)
{
  CORE_DECLARE_IRQ_STATE;
  CORE_ENTER_CRITICAL();
  if(memoryPtrFromHandle(handle) != NULL)
  {
    memoryObjs[(uint32_t)handle].refCount++;
  }
  CORE_EXIT_CRITICAL();
}