📄 mms.c
字号:
/*-----------------------------------------------------------------------------*/
/* */
/* Copyright (C) 1993-2003 by Texas Instruments, Inc. All rights reserved. */
/* Copyright (C) 2001-2003 Telogy Networks, Inc. */
/* */
/* IMPORTANT - READ CAREFULLY BEFORE PROCEEDING TO USE SOFTWARE. */
/* */
/* This document is displayed for you to read prior to using the software */
/* and documentation. By using the software and documentation, or opening */
/* the sealed packet containing the software, or proceeding to download the */
/* software from a Bulletin Board System(BBS) or a WEB Server, you agree to */
/* abide by the following Texas Instruments License Agreement. If you choose */
/* not to agree with these provisions, promptly discontinue use of the */
/* software and documentation and return the material to the place you */
/* obtained it. */
/* */
/* *** NOTE *** */
/* */
/* The licensed materials contain MIPS Technologies, Inc. confidential */
/* information which is protected by the appropriate MIPS Technologies, Inc. */
/* license agreement. It is your responsibility to comply with these */
/* licenses. */
/* */
/* Texas Instruments License Agreement */
/* */
/* 1. License - Texas Instruments (hereinafter "TI"), grants you a license */
/* to use the software program and documentation in this package ("Licensed */
/* Materials") for Texas Instruments broadband products. */
/* */
/* 2. Restrictions - You may not reverse-assemble or reverse-compile the */
/* Licensed Materials provided in object code or executable format. You may */
/* not sublicense, transfer, assign, rent, or lease the Licensed Materials */
/* or this Agreement without written permission from TI. */
/* */
/* 3. Copyright - The Licensed Materials are copyrighted. Accordingly, you */
/* may either make one copy of the Licensed Materials for backup and/or */
/* archival purposes or copy the Licensed Materials to another medium and */
/* keep the original Licensed Materials for backup and/or archival purposes. */
/* */
/* 4. Runtime and Applications Software - You may create modified or */
/* derivative programs of software identified as Runtime Libraries or */
/* Applications Software, which, in source code form, remain subject to this */
/* Agreement, but object code versions of such derivative programs are not */
/* subject to this Agreement. */
/* */
/* 5. Warranty - TI warrants the media to be free from defects in material */
/* and workmanship and that the software will substantially conform to the */
/* related documentation for a period of ninety (90) days after the date of */
/* your purchase. TI does not warrant that the Licensed Materials will be */
/* free from error or will meet your specific requirements. */
/* */
/* 6. Remedies - If you find defects in the media or that the software does */
/* not conform to the enclosed documentation, you may return the Licensed */
/* Materials along with the purchase receipt, postage prepaid, to the */
/* following address within the warranty period and receive a refund. */
/* */
/* TEXAS INSTRUMENTS */
/* Application Specific Products, MS 8650 */
/* c/o ADAM2 Application Manager */
/* 12500 TI Boulevard */
/* Dallas, TX 75243 - U.S.A. */
/* */
/* 7. Limitations - TI makes no warranty or condition, either expressed or */
/* implied, including, but not limited to, any implied warranties of */
/* merchantability and fitness for a particular purpose, regarding the */
/* licensed materials. */
/* */
/* Neither TI nor any applicable licensor will be liable for any indirect, */
/* incidental or consequential damages, including but not limited to loss of */
/* profits. */
/* */
/* 8. Term - The license is effective until terminated. You may terminate */
/* it at any other time by destroying the program together with all copies, */
/* modifications and merged portions in any form. It also will terminate if */
/* you fail to comply with any term or condition of this Agreement. */
/* */
/* 9. Export Control - The re-export of United States origin software and */
/* documentation is subject to the U.S. Export Administration Regulations or */
/* your equivalent local regulations. Compliance with such regulations is */
/* your responsibility. */
/* */
/* *** IMPORTANT NOTICE *** */
/* */
/* Texas Instruments (TI) reserves the right to make changes to or to */
/* discontinue any semiconductor product or service identified in this */
/* publication without notice. TI advises its customers to obtain the latest */
/* version of the relevant information to verify, before placing orders, */
/* that the information being relied upon is current. */
/* */
/* TI warrants performance of its semiconductor products and related */
/* software to current specifications in accordance with TI's standard */
/* warranty. Testing and other quality control techniques are utilized to */
/* the extent TI deems necessary to support this warranty. Unless mandated */
/* by government requirements, specific testing of all parameters of each */
/* device is not necessarily performed. */
/* */
/* Please be aware that Texas Instruments products are not intended for use */
/* in life-support appliances, devices, or systems. Use of a TI product in */
/* such applications without the written approval of the appropriate TI */
/* officer is prohibited. Certain applications using semiconductor devices */
/* may involve potential risks of injury, property damage, or loss of life. */
/* In order to minimize these risks, adequate design and operating */
/* safeguards should be provided by the customer to minimize inherent or */
/* procedural hazards. Inclusion of TI products in such applications is */
/* understood to be fully at the risk of the customer using TI devices or */
/* systems. */
/* */
/* TI assumes no liability for TI applications assistance, customer product */
/* design, software performance, or infringement of patents or services */
/* described herein. Nor does TI warrant or represent that license, either */
/* expressed or implied, is granted under any patent right, copyright, mask */
/* work right, or other intellectual property right of TI covering or */
/* relating to any combination, machine, or process in which such */
/* semiconductor products or services might be or are used. */
/* */
/* All company and/or product names are trademarks and/or registered */
/* trademarks of their respective manaufacturers. */
/* */
/*-----------------------------------------------------------------------------*/
/* */
/* This module contains the functions which implement the dynamic memory */
/* management routines. The following assumptions/rules apply: */
/* */
/* 1) Packets are allocated a minimum of MIN_BLOCK + BLOCK_OVERHEAD bytes. */
/* 2) The size of the heap is set at link time, using the -heap flag */
/* The allocation and sizing of the heap is a cooperative effort */
/* involving the linker, this file, and "sysmem.c". */
/* 3) The heap can be reset at any time by calling the function "minit" */
/* */
/* The following items are defined in this module : */
/* minit(.) : Function to initialize dynamic memory management */
/* malloc(.) : Function to allocate memory from mem mgmt system. */
/* sys_calloc(.) : Allocate an clear memory from mem mgmt system. */
/* sys_realloc(.) : Reallocate a packet */
/* sys_free(.) : Function to free allocated memory. */
/* sys_memalign(.):Function to allocate aligned memory from mem mgmt system.*/
/*-----------------------------------------------------------------------------*/
/* minsert(.) : Insert a packet into free list, sorted by size */
/* mremove(.) : Remove a packet from the free list. */
/* sys_free : Pointer to free list */
/* */
/*******************************************************************************/
#include "_stdio.h"
#include "mms.h"
#ifdef FFS_SUPPORT
#include "files.h"
#endif
#define MALLOC_DEBUG
/*---------------------------------------------------------------------------*/
/* MIN_BLOCK MUST BE A */
/*---------------------------------------------------------------------------*/
#define MIN_BLOCK 16
#define BLOCK_OVERHEAD MIN_BLOCK
#define BLOCK_USED 1
#define BLOCK_MASK (MIN_BLOCK-1)
/*---------------------------------------------------------------------------*/
/* "PACKET" is the template for a data packet. Packet size contains */
/* the number of bytes allocated for the user, excluding the size required */
/* for management of the packet (BLOCK_OVERHEAD bytes). Packets are always */
/* allocated memory in MIN_BLOCK byte chunks. The lowest order bit of the */
/* size field is used to indicate whether the packet is free(0) or used(1). */
/* The next_ptr field is used to manage the free list, and is a pointer */
/* to the next element in the free list. The free list is sorted by size. */
/*---------------------------------------------------------------------------*/
typedef struct pack
{
unsigned int mflag;
unsigned int packet_size; /* number of bytes */
struct pack *next_ptr; /* next elem in free list */
struct pack *this_ptr;
}PACKET;
/*---------------------------------------------------------------------------*/
/* Size of the heap area as defined by the linker. Initialized in sysmem.c */
/*---------------------------------------------------------------------------*/
int _memory_size = 0;
/*---------------------------------------------------------------------------*/
/* SYS_FREE - This variable is a pointer to the free list. */
/*---------------------------------------------------------------------------*/
volatile char* _sys_memory = 0;
PACKET *free = 0;
/*---------------------------------------------------------------------------*/
/* Function declarations */
/*---------------------------------------------------------------------------*/
static void minsert(PACKET *); /* insert a packet into the free list */
static void mremove(PACKET *); /* delete packet from the free list */
extern void minit(unsigned adr, unsigned size);
/*****************************************************************************/
/* */
/* MINSERT - Insert a packet into the free list. This list is sorted by */
/* size in increasing order. */
/* */
/*****************************************************************************/
static void minsert(PACKET *ptr)
{
register PACKET *current = (PACKET *) free;
register PACKET *last = NULL;
/*-----------------------------------------------------------------------*/
/* Setup MMS markers */
/*-----------------------------------------------------------------------*/
ptr->mflag = 0x11111111;
ptr->this_ptr = ptr;
/*-----------------------------------------------------------------------*/
/* CHECK SPECIAL CASE, EMPTY FREE LIST. */
/*-----------------------------------------------------------------------*/
if (current == NULL)
{
free = ptr;
ptr->next_ptr = NULL;
return;
}
/*-----------------------------------------------------------------------*/
/* SCAN THROUGH LIST, LOOKING FOR A LARGER PACKET. */
/*-----------------------------------------------------------------------*/
while (current && current->packet_size < ptr->packet_size)
{
last = current;
current = current->next_ptr;
}
/*-----------------------------------------------------------------------*/
/* LINK THE NEW PACKET INTO THE LIST. THERE ARE THREE CASES : */
/* THE NEW POINTER WILL EITHER BE THE FIRST, THE LAST, OR IN THE */
/* MIDDLE SOMEWHERE. */
/*-----------------------------------------------------------------------*/
if (current == NULL) /* PTR WILL BE LAST IN LIST */
{
last->next_ptr = ptr;
ptr->next_ptr = NULL;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -