skeleton for lab1

Dependencies:   AvailableMemory mbed-rtos mbed

Fork of helloaabbc by 32314 mbed

Committer:
mbed36372
Date:
Fri Apr 04 21:31:22 2014 +0000
Revision:
1:55e99f6e2aa5
Parent:
0:1c8f2727e9f5
SP14_lab1

Who changed what in which revision?

UserRevisionLine numberNew contents of line
y7jin 0:1c8f2727e9f5 1 /*----------------------------------------------------------------------------
y7jin 0:1c8f2727e9f5 2 * RL-ARM - RTX
y7jin 0:1c8f2727e9f5 3 *----------------------------------------------------------------------------
y7jin 0:1c8f2727e9f5 4 * Name: RT_LIST.H
y7jin 0:1c8f2727e9f5 5 * Purpose: Functions for the management of different lists
y7jin 0:1c8f2727e9f5 6 * Rev.: V4.60
y7jin 0:1c8f2727e9f5 7 *----------------------------------------------------------------------------
y7jin 0:1c8f2727e9f5 8 *
y7jin 0:1c8f2727e9f5 9 * Copyright (c) 1999-2009 KEIL, 2009-2012 ARM Germany GmbH
y7jin 0:1c8f2727e9f5 10 * All rights reserved.
y7jin 0:1c8f2727e9f5 11 * Redistribution and use in source and binary forms, with or without
y7jin 0:1c8f2727e9f5 12 * modification, are permitted provided that the following conditions are met:
y7jin 0:1c8f2727e9f5 13 * - Redistributions of source code must retain the above copyright
y7jin 0:1c8f2727e9f5 14 * notice, this list of conditions and the following disclaimer.
y7jin 0:1c8f2727e9f5 15 * - Redistributions in binary form must reproduce the above copyright
y7jin 0:1c8f2727e9f5 16 * notice, this list of conditions and the following disclaimer in the
y7jin 0:1c8f2727e9f5 17 * documentation and/or other materials provided with the distribution.
y7jin 0:1c8f2727e9f5 18 * - Neither the name of ARM nor the names of its contributors may be used
y7jin 0:1c8f2727e9f5 19 * to endorse or promote products derived from this software without
y7jin 0:1c8f2727e9f5 20 * specific prior written permission.
y7jin 0:1c8f2727e9f5 21 *
y7jin 0:1c8f2727e9f5 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
y7jin 0:1c8f2727e9f5 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
y7jin 0:1c8f2727e9f5 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
y7jin 0:1c8f2727e9f5 25 * ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE
y7jin 0:1c8f2727e9f5 26 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
y7jin 0:1c8f2727e9f5 27 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
y7jin 0:1c8f2727e9f5 28 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
y7jin 0:1c8f2727e9f5 29 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
y7jin 0:1c8f2727e9f5 30 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
y7jin 0:1c8f2727e9f5 31 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
y7jin 0:1c8f2727e9f5 32 * POSSIBILITY OF SUCH DAMAGE.
y7jin 0:1c8f2727e9f5 33 *---------------------------------------------------------------------------*/
y7jin 0:1c8f2727e9f5 34
y7jin 0:1c8f2727e9f5 35 /* Definitions */
y7jin 0:1c8f2727e9f5 36
y7jin 0:1c8f2727e9f5 37 /* Values for 'cb_type' */
y7jin 0:1c8f2727e9f5 38 #define TCB 0
y7jin 0:1c8f2727e9f5 39 #define MCB 1
y7jin 0:1c8f2727e9f5 40 #define SCB 2
y7jin 0:1c8f2727e9f5 41 #define MUCB 3
y7jin 0:1c8f2727e9f5 42 #define HCB 4
y7jin 0:1c8f2727e9f5 43
y7jin 0:1c8f2727e9f5 44 /* Variables */
y7jin 0:1c8f2727e9f5 45 extern struct OS_XCB os_rdy;
y7jin 0:1c8f2727e9f5 46 extern struct OS_XCB os_dly;
y7jin 0:1c8f2727e9f5 47
y7jin 0:1c8f2727e9f5 48 /* Functions */
y7jin 0:1c8f2727e9f5 49 extern void rt_put_prio (P_XCB p_CB, P_TCB p_task);
y7jin 0:1c8f2727e9f5 50 extern P_TCB rt_get_first (P_XCB p_CB);
y7jin 0:1c8f2727e9f5 51 extern void rt_put_rdy_first (P_TCB p_task);
y7jin 0:1c8f2727e9f5 52 extern P_TCB rt_get_same_rdy_prio (void);
y7jin 0:1c8f2727e9f5 53 extern void rt_resort_prio (P_TCB p_task);
y7jin 0:1c8f2727e9f5 54 extern void rt_put_dly (P_TCB p_task, U16 delay);
y7jin 0:1c8f2727e9f5 55 extern void rt_dec_dly (void);
y7jin 0:1c8f2727e9f5 56 extern void rt_rmv_list (P_TCB p_task);
y7jin 0:1c8f2727e9f5 57 extern void rt_rmv_dly (P_TCB p_task);
y7jin 0:1c8f2727e9f5 58 extern void rt_psq_enq (OS_ID entry, U32 arg);
y7jin 0:1c8f2727e9f5 59
y7jin 0:1c8f2727e9f5 60 /* This is a fast macro generating in-line code */
y7jin 0:1c8f2727e9f5 61 #define rt_rdy_prio(void) (os_rdy.p_lnk->prio)
y7jin 0:1c8f2727e9f5 62
y7jin 0:1c8f2727e9f5 63
y7jin 0:1c8f2727e9f5 64 /*----------------------------------------------------------------------------
y7jin 0:1c8f2727e9f5 65 * end of file
y7jin 0:1c8f2727e9f5 66 *---------------------------------------------------------------------------*/
y7jin 0:1c8f2727e9f5 67