view src/cs/riviera/rvf/rvf_mem_pool.c @ 268:f2e52cab0a73

abb_inth.c: check all interrupt causes, not just one The original code used if - else if - else if etc constructs, thus the first detected interrupt was the only one handled. However, Iota ITSTATREG is a clear-on-read register, thus if we only handle the first detected interrupt and skip checking the others, then the other interrupts will be lost, if more than one interrupt happened to occur in one ABB interrupt handling cycle - a form of rare race condition. Change the code to check all interrupts that were read in this cycle.
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 13 Jun 2021 18:17:53 +0000
parents 4e78acac3d88
children
line wrap: on
line source

/****************************************************************************/
/*                                                                          */
/*  Name        rvf_mem_pool.c                                              */
/*                                                                          */
/*  Function    this file contains the definition of main memory pool       */
/*                                                                          */
/*  Version		0.1															             */
/*																			                   */
/* 	Date       	Modification												          */
/*  ------------------------------------									          */
/*  06/08/02		Create														          */
/*																			                   */
/*	Author		Laurent Sollier (l-sollier@ti.com)						          */
/*																			                   */
/* (C) Copyright 2002 by Texas Instruments Incorporated, All Rights Reserved*/
/****************************************************************************/

#include "rvf/rvf_pool_size.h"
#include "rvf/rvf_cust.h"

/******** MEMORY POOLS ******************/
/* Define the buffer pools */
T_RVF_POOL _rvf_pools[RVF_NB_POOLS];


/* allocated static buffer pools */
UINT8 Buf0[RVF_POOL_0_SIZE];

#if (RVF_NB_POOLS > 1)
UINT8 Buf1[RVF_POOL_1_SIZE];
#endif

/*******************************************************************************
**
** Function         _rvf_init_mem_pool
**
** Description      This function is called to initialize the different memory
**                  pool.
**
** Returns          void
**
*******************************************************************************/
void _rvf_init_mem_pool(void)
{
	/* initialize buffer pools */
   _rvf_init_free_queue(0, RVF_POOL_0_SIZE, (UINT8 *)Buf0);

#if (RVF_NB_POOLS > 1)
   _rvf_init_free_queue(1, RVF_POOL_1_SIZE, (UINT8 *)Buf1);
#endif
}

/*******************************************************************************
**
** Function         _rvf_get_mem_usage_ratio
**
** Description      This function is called to have the value of
**                  RVF_MEM_USAGE_RATIO.
**
** Returns          The value of RVF_MEM_USAGE_RATIO (see details of this value
**                  in rvf_pool_size.h)
**
*******************************************************************************/
UINT16 _rvf_get_mem_usage_ratio(void)
{
   return RVF_MEM_USAGE_RATIO;
}

/*******************************************************************************
**
** Function         _rvf_get_number_of_pool
**
** Description      This function is called to have the number of memory pool.
**
** Returns          The number of available different pool
**
*******************************************************************************/
UINT16 _rvf_get_number_of_pool(void)
{
   return RVF_NB_POOLS;
}