mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
118 lines
2.7 KiB
C
118 lines
2.7 KiB
C
/*
|
|
* Copyright (C) 2018 Inria
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup tests
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Simple memarray module tests
|
|
*
|
|
* @author Tobias Heider <heidert@nm.ifi.lmu.de>
|
|
* @author Raul Fuentes <raul.fuentes-samaniego@inria.fr>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include "memarray.h"
|
|
|
|
#define MAX_NUMBER_BLOCKS (10)
|
|
#define MESSAGE_SIZE (8U)
|
|
#define NUMBER_OF_TESTS (12)
|
|
|
|
extern int _ps_handler(int argc, char **argv);
|
|
|
|
struct block_t {
|
|
struct node *next;
|
|
int number;
|
|
/* static size for the components */
|
|
unsigned char message[MESSAGE_SIZE];
|
|
};
|
|
|
|
struct block_t block_storage_data[MAX_NUMBER_BLOCKS];
|
|
memarray_t block_storage;
|
|
|
|
int total = 0;
|
|
|
|
static void memory_block_init(void)
|
|
{
|
|
memarray_init(&block_storage, block_storage_data, sizeof(struct block_t), MAX_NUMBER_BLOCKS);
|
|
}
|
|
|
|
void fill_memory(struct block_t *head)
|
|
{
|
|
int aux = 0;
|
|
|
|
while ((aux < MAX_NUMBER_BLOCKS) && (head)) {
|
|
memset(head->message, '@', MESSAGE_SIZE - 1);
|
|
head->message[MESSAGE_SIZE - 1] = 0;
|
|
head->number = aux;
|
|
|
|
printf("\t(%i, %s) Allocated %u Bytes at %p, total %d\n",
|
|
head->number, head->message, (unsigned)sizeof(struct block_t),
|
|
(void *)head, total);
|
|
|
|
/* NOTE: If there is not space, memarray_alloc returns zero */
|
|
head->next = memarray_alloc(&block_storage);
|
|
head = (struct block_t *)head->next;
|
|
|
|
total += sizeof(struct block_t);
|
|
aux++;
|
|
}
|
|
}
|
|
|
|
void free_memory(struct block_t *head)
|
|
{
|
|
struct block_t *old;
|
|
|
|
while (head) {
|
|
total -= sizeof(struct block_t);
|
|
printf("\tFree (%i) %u Bytes at %p, total %d\n", \
|
|
head->number, (unsigned)sizeof(struct block_t),
|
|
(void *)head, total);
|
|
|
|
if (head->next) {
|
|
old = head;
|
|
head = (struct block_t *) head->next;
|
|
memarray_free(&block_storage, old);
|
|
}
|
|
else {
|
|
memarray_free(&block_storage, head);
|
|
head = 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
memory_block_init();
|
|
int count = 0;
|
|
|
|
printf("Starting (%d, %u)\n", MAX_NUMBER_BLOCKS, MESSAGE_SIZE);
|
|
_ps_handler(0, NULL);
|
|
|
|
while (count < NUMBER_OF_TESTS) {
|
|
struct block_t *head = (struct block_t *) memarray_alloc(&block_storage);
|
|
|
|
printf("TEST #%i:\n", count + 1 );
|
|
fill_memory(head);
|
|
free_memory(head);
|
|
|
|
count++;
|
|
}
|
|
|
|
printf("Finishing\n");
|
|
_ps_handler(0, NULL);
|
|
|
|
return 0;
|
|
}
|