⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mempfix.c

📁 嵌入式系统开发 TOPPERS and JSP Kernel Release 1.3 TOPPERS = Toyohashi Open Platform for Embedded Real-Tim
💻 C
字号:
/* *  TOPPERS/JSP Kernel *      Toyohashi Open Platform for Embedded Real-Time Systems/ *      Just Standard Profile Kernel *  *  Copyright (C) 2000,2001 by Embedded and Real-Time Systems Laboratory *                              Toyohashi Univ. of Technology, JAPAN *  *  惧淡螟侯涪荚は·Free Software Foundation によって给山されている  *  GNU General Public License の Version 2 に淡揭されている掘凤か·笆 *  布の(1)×(4)の掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェ *  アを猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· *  网脱と钙ぶ∷することを痰浸で钓满するˉ *  (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 *      涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 *      スコ〖ド面に崔まれていることˉ *  (2) 塑ソフトウェアを浩网脱材墙なバイナリコ〖ド∈リロケ〖タブルオブ *      ジェクトファイルやライブラリなど∷の妨で网脱する眷圭には·网脱 *      に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟侯涪山绩· *      この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ *  (3) 塑ソフトウェアを浩网脱稍材墙なバイナリコ〖ドの妨または怠达に寥 *      み哈んだ妨で网脱する眷圭には·肌のいずれかの掘凤を塔たすことˉ *    (a) 网脱に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟侯 *        涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ *    (b) 网脱の妨轮を·侍に年める数恕によって·惧淡螟侯涪荚に鼠桂する *        ことˉ *  (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 *      巢からも·惧淡螟侯涪荚を倘勒することˉ *  *  塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚は· *  塑ソフトウェアに簇して·その努脱材墙拉も崔めて·いかなる瘦沮も乖わ *  ないˉまた·塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じたい *  かなる禄巢に簇しても·その勒扦を砷わないˉ *  *  @(#) $Id: mempfix.c,v 1.7 2002/03/26 08:19:38 hiro Exp $ *//* *	盖年墓メモリプ〖ル怠墙 */#include "jsp_kernel.h"#include "check.h"#include "task.h"#include "wait.h"#include "mempfix.h"/* *  盖年墓メモリプ〖ルIDの呵络猛∈kernel_cfg.c∷ */extern const ID	tmax_mpfid;/* *  盖年墓メモリプ〖ル介袋步ブロックのエリア∈kernel_cfg.c∷ */extern const MPFINIB	mpfinib_table[];/* *  盖年墓メモリプ〖ル瓷妄ブロックのエリア∈kernel_cfg.c∷ */extern MPFCB	mpfcb_table[];/* *  盖年墓メモリプ〖ルIDから盖年墓メモリプ〖ル瓷妄ブロックを艰り叫すた *  めのマクロ */#define INDEX_MPF(mpfid)	((mpfid) - TMIN_MPFID)#define get_mpfcb(mpfid)	(&(mpfcb_table[INDEX_MPF(mpfid)]))/* *  盖年墓メモリプ〖ル略ち攫鼠ブロックの年盗 */typedef struct fixed_memorypool_waiting_information {	WINFO	winfo;		/* 筛洁の略ち攫鼠ブロック */	WOBJCB	*wobjcb;	/* 略ちオブジェクトのコントロ〖ルブロック */	VP	blk;		/* 惩评したメモリブロック */} WINFO_MPF;/*  *  盖年墓メモリプ〖ル怠墙の介袋步 */voidmempfix_initialize(){	INT	i;	MPFCB	*mpfcb;	for (mpfcb = mpfcb_table, i = 0; i < tmax_mpfid; mpfcb++, i++) {		queue_initialize(&(mpfcb->wait_queue));		mpfcb->mpfinib = &(mpfinib_table[i]);		mpfcb->unused = mpfcb->mpfinib->mpf;		mpfcb->freelist = NULL;	}}/* *  盖年墓メモリプ〖ルからブロックを惩评 */static BOOLget_block(MPFCB *mpfcb, VP *p_blk){	FREEL	*free;	if (mpfcb->freelist != NULL) {		free = mpfcb->freelist;		mpfcb->freelist = free->next;		*p_blk = (VP) free;		return(TRUE);	}	else if (mpfcb->unused < mpfcb->mpfinib->limit) {		*p_blk = mpfcb->unused;		mpfcb->unused = (VB *)(mpfcb->unused) + mpfcb->mpfinib->blksz;		return(TRUE);	}	return(FALSE);}/* *  盖年墓メモリブロックの惩评 */SYSCALL ERget_mpf(ID mpfid, VP *p_blk){	MPFCB	*mpfcb;	WINFO_MPF winfo;	ER	ercd;	CHECK_DISPATCH();	CHECK_MPFID(mpfid);	mpfcb = get_mpfcb(mpfid);	t_lock_cpu();	if (get_block(mpfcb, p_blk)) {		ercd = E_OK;	}	else {		wobj_make_wait((WOBJCB *) mpfcb, (WINFO_WOBJ *) &winfo);		dispatch();		ercd = winfo.winfo.wercd;		if (ercd == E_OK) {			*p_blk = winfo.blk;		}	}	t_unlock_cpu();	return(ercd);}/* *  盖年墓メモリブロックの惩评∈ポ〖リング∷ */SYSCALL ERpget_mpf(ID mpfid, VP *p_blk){	MPFCB	*mpfcb;	ER	ercd;	CHECK_TSKCTX_UNL();	CHECK_MPFID(mpfid);	mpfcb = get_mpfcb(mpfid);	t_lock_cpu();	if (get_block(mpfcb, p_blk)) {		ercd = E_OK;	}	else {		ercd = E_TMOUT;	}	t_unlock_cpu();	return(ercd);}/* *  盖年墓メモリブロックの惩评∈タイムアウトあり∷ */SYSCALL ERtget_mpf(ID mpfid, VP *p_blk, TMO tmout){	MPFCB	*mpfcb;	WINFO_MPF winfo;	TMEVTB	tmevtb;	ER	ercd;	CHECK_DISPATCH();	CHECK_MPFID(mpfid);	CHECK_TMOUT(tmout);	mpfcb = get_mpfcb(mpfid);	t_lock_cpu();	if (get_block(mpfcb, p_blk)) {		ercd = E_OK;	}	else if (tmout == TMO_POL) {		ercd = E_TMOUT;	}	else {		wobj_make_wait_tmout((WOBJCB *) mpfcb, (WINFO_WOBJ *) &winfo,						&tmevtb, tmout);		dispatch();		ercd = winfo.winfo.wercd;		if (ercd == E_OK) {			*p_blk = winfo.blk;		}	}	t_unlock_cpu();	return(ercd);}/* *  盖年墓メモリブロックの手笛 */SYSCALL ERrel_mpf(ID mpfid, VP blk){	MPFCB	*mpfcb;	TCB	*tcb;	FREEL	*free;	ER	ercd;    	CHECK_TSKCTX_UNL();	CHECK_MPFID(mpfid);	mpfcb = get_mpfcb(mpfid);	CHECK_PAR(mpfcb->mpfinib->mpf <= blk			&& blk < mpfcb->mpfinib->limit			&& (((VB *) blk) - ((VB *)(mpfcb->mpfinib->mpf)))					% mpfcb->mpfinib->blksz == 0);	t_lock_cpu();	if (!(queue_empty(&(mpfcb->wait_queue)))) {		tcb = (TCB *) queue_delete_next(&(mpfcb->wait_queue));		((WINFO_MPF *)(tcb->winfo))->blk = blk;		if (wait_complete(tcb)) {			dispatch();		}		ercd = E_OK;	}	else {		free = (FREEL *) blk;		free->next = mpfcb->freelist;		mpfcb->freelist = free;		ercd = E_OK;	}	t_unlock_cpu();	return(ercd);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -