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

📄 tk_crnos.h

📁 在ARM7和UC/OSII的平台上实现了GPS自动报站的功能,涉及GPS模块LEA_4S的驱动,位置速寻算法,语音芯片ISD4004的录放音驱动,LED页面管理等等.从启动代码到操作系统的移植以及到业
💻 H
字号:
/*
 * FILENAME: tk_crnos.h
 *
 * Copyright  2001-2002 By InterNiche Technologies Inc. All rights reserved
 *
 * Definitions to map NicheTask "TK_" macros to ChronOS/uCOS RTOS
 *
 * MODULE: MISCLIB
 *
 * PORTABLE: yes (within uCOS systems)
 */

#ifndef TK_CRNOS_H
#define TK_CRNOS_H

#ifndef CHRONOS
#error - must define CHRONOS in ipport.h to use this file
#endif

extern void TK_OSTaskResume(u_char * Id);

/* define the default priority for all net related tasks */
#define  NET_PRIORITY   0  /* not used on ChronOS */

/* Self-ID token for pass to ChronOS primitives */
#define OS_PRIO_SELF 0xFF

/* Define the CHRONOS object control TK_ macros...  */

/* macros for task type, entry, and name */
#define  TK_ENTRY(name)       void  name(void * parm)
#define  TK_OBJECT(name)      u_char   name
#define  TK_OBJECT_PTR(name)  u_char * name
#define  TK_OBJECT_REF        TK_OBJECT
#define  TK_ENTRY_PTR(name)   void(*name)(void*)

#define  TK_THIS              TK_OSTaskQuery()

#ifndef  TK_RETURN_ERROR
#define  TK_RETURN_ERROR()   return
#endif
#ifndef  TK_RETURN_OK
#define  TK_RETURN_OK()      return
#endif


/*
 * synchronization primitives
 * 
 * Need one or the other of LOCK_NET_RESOURCE/UNLOCK_NET_RESOURCE and
 * ENTER_CRIT_SECTION/EXIT_CRIT_SECTION.  These should be implementable
 * as either functions or macros, so we allow e.g. ipport.h_h to 
 * override these definitions by defining the names as macros.
 * CHRONOS targets generally use LOCK_NET_RESOURCE/UNLOCK_NET_RESOURCE
 * so we default to function declaractions for them.
 */
#ifndef LOCK_NET_RESOURCE
void LOCK_NET_RESOURCE(void * semaphore);
#endif
#ifndef UNLOCK_NET_RESOURCE
void UNLOCK_NET_RESOURCE(void * semaphore);
#endif
#ifndef ENTER_CRIT_SECTION
#define  ENTER_CRIT_SECTION(p)
#endif
#ifndef EXIT_CRIT_SECTION
#define  EXIT_CRIT_SECTION(p)
#endif



/* set up pointers to CHRONOS semaphores as void * so we don't
 * have to include ChronOS includes in every file in the build. In Addition
 * RXQ_RESID and FREEQ_RESID are not real semaphores, but just placeholders.
 * See the LOCK_NET_RESOURCE() code for details.
 */
#ifndef NET_RESID
extern   void *      net_task_sem_ptr;
#define  NET_RESID   (net_task_sem_ptr)
#endif
#ifndef RXQ_RESID
extern   void *      receiveq_sem_ptr;
#define  RXQ_RESID   (receiveq_sem_ptr)
#endif
#ifndef FREEQ_RESID
extern   void *      freeq_sem_ptr;
#define  FREEQ_RESID (freeq_sem_ptr)
#endif


/* declare tasks which may need to be accessed by system code */
extern   TK_OBJECT(to_pingcheck);
extern   TK_OBJECT(to_netmain);
extern   TK_OBJECT(to_emailer);
extern   TK_OBJECT(to_ftpclnt);


/* map TK_ macros to CHRONOS: */
#define  TK_BLOCK()          OSTaskSuspend(OS_PRIO_SELF)
#define  TK_NETRX_BLOCK()    OSTaskSuspend(OS_PRIO_SELF)
#define  TK_SLEEP(count)     OSTimeDly(count + 1)

/* (Id) is always of type TK_OBJECT_PTR */
#define  TK_WAKE(Id)         OSTaskResume(*(u_char*)(Id))

/* (ev) is always of type TK_OBJECT_REF */
#define  TK_WAKE_EVENT(ev)   OSTaskResume((u_char)(ev))

/* Do tk_yield() as a function to avoid pointless delays */
void tk_yield(void);


/* For ChronOS SignalPktDemux() is a routine which manually sets the net
 * task to runnable. This is so we can call it from an ISR and not have
 * ChronOS enable interrupts on us.
 */
extern   void  SignalPktDemux(void);

#define  SignalEmailTask() OSTaskResume(to_emailer)
#define  SignalFtpClient() OSTaskResume(to_ftpclnt)

#endif  /* TK_CRNOS_H */


⌨️ 快捷键说明

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