亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stos.c

?? stos Linux 源碼示范程序。 可以移植到其他平臺
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*******************************************************************************
Name        : STOS_SemaphoreWaitTimeOut
Description : OS-independent implementation of semaphore_wait_timeout
Parameters  : semaphore to wait for, time out value
Assumptions :
Limitations :
Returns     : STOS_SUCCESS if success, STOS_FAILURE if timeout occurred
*******************************************************************************/
int STOS_SemaphoreWaitTimeOut(semaphore_t * Semaphore_p, const STOS_Clock_t * TimeOutValue_p)
{
    assert(Semaphore_p != NULL);

#if (defined (ST_OS20)) || (defined (ST_OS21)) || (defined (ST_OSLINUX))
    return(semaphore_wait_timeout(Semaphore_p, (STOS_Clock_t *) TimeOutValue_p));
#else
    #error STOS_SemaphoreWaitTimeOut() can only be used with OS20, OS21 or LINUX!
#endif
}

/*******************************************************************************
Name        : STOS_memsetUncached
Description : Does an uncached CPU access to the given address and fills the
              given area with the given pattern
Parameters  : the address of the first byte, the pattern, the area size
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
void STOS_memsetUncached(const void* const PhysicalAddress, U8 Pattern, U32 Size)
{
#if defined ST_OSLINUX && !defined MODULE
    /* MODULE is a Linux specific define, if not defined current working space is USER space */
    STTBX_Print(("%s(): Feature not supported under Linux in User space!\n", __FUNCTION__));
    return;

#else

    U32 i;

    for (i = 0; i < Size; i++)
    {
        STSYS_WriteRegMemUncached8((U8*)((U32)PhysicalAddress + i), Pattern);
    }
#endif
} /* End of STOS_memsetUncached() function */

/*******************************************************************************
Name        : STOS_memcpyUncachedToUncached
Description : Does only uncached read/write CPU accesses for copying data from
              src to dest
Parameters  : the address of the src, the address of the dest, the copy size
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
void STOS_memcpyUncachedToUncached(const void* const uncached_dest, const void* const uncached_src, U32 Size)
{
#if defined ST_OSLINUX && !defined MODULE
    /* MODULE is a Linux specific define, if not defined current working space is USER space */
    STTBX_Print(("%s(): Feature not supported under Linux in User space!\n", __FUNCTION__));
    return;

#else
    U32 i;

#ifdef ST_OSLINUX
    if (uncached_dest == uncached_src)
    {
        return;
    }
#endif

    for (i = 0; i < Size; i++)
    {
        STSYS_WriteRegMemUncached8((U8*)((U32)uncached_dest + i), STSYS_ReadRegMemUncached8((U8*)((U32)uncached_src + i)));
    }
#endif
} /* End of STOS_memcpyUncachedToUncached() function */

/*******************************************************************************
Name        : STOS_memcpyCachedToUncached
Description : Does only uncached write CPU accesses and cached read CPU accesses
              for copying data from src to dest
Parameters  : the address of the src, the address of the dest, the copy size
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
void STOS_memcpyCachedToUncached(const void* const uncached_dest, const void* const cached_src, U32 Size)
{
#if defined ST_OSLINUX && !defined MODULE
    /* MODULE is a Linux specific define, if not defined current working space is USER space */
    STTBX_Print(("%s(): Feature not supported under Linux in User space!\n", __FUNCTION__));
    return;

#else
    U32 i;

#ifdef ST_OSLINUX
    if ( (((U32)uncached_dest & MASK_STBUS_FROM_ST40) | REGION2) == (((U32)cached_src & MASK_STBUS_FROM_ST40) | REGION2) )
    {
        return;
    }
#endif

    for (i = 0; i < Size; i++)
    {
        STSYS_WriteRegMemUncached8((U8*)((U32)uncached_dest + i), ((U8*)cached_src)[i]);
    }
#endif
} /* End of STOS_memcpyCachedToUncached() function */

/*******************************************************************************
Name        : STOS_memcpyUncachedToCached
Description : Does only cached write CPU accesses and uncached read CPU accesses
              for copying data from src to dest
Parameters  : the address of the src, the address of the dest, the copy size
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
void STOS_memcpyUncachedToCached(void* const cached_dest, const void* const uncached_src, U32 Size)
{
#if defined ST_OSLINUX && !defined MODULE
    /* MODULE is a Linux specific define, if not defined current working space is USER space */
    STTBX_Print(("%s(): Feature not supported under Linux in User space!\n", __FUNCTION__));
    return;

#else
    U32 i;

#ifdef ST_OSLINUX
    if ( (((U32)cached_dest & MASK_STBUS_FROM_ST40) | REGION2) == (((U32)uncached_src & MASK_STBUS_FROM_ST40) | REGION2) )
    {
        return;
    }
#endif

    for (i = 0; i < Size; i++)
    {
        ((U8*)cached_dest)[i] = STSYS_ReadRegMemUncached8((U8*)((U32)uncached_src + i));
    }
#endif
} /* End of STOS_memcpyUncachedToCached() function */

/*******************************************************************************
Name        : STOS_TaskDelay
Description : Asleep the task for a given amount of ticks
Parameters  : number of ticks to wait (none if ticks <= 0)
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
#if defined ST_OSLINUX && !defined MODULE
void STOS_TaskDelay(int ticks)
{
    struct timespec x;

    if (ticks <= 0)
    {
        STTBX_Print(("%s(): WARNING !!! Inadequate number of ticks (0x%.8x), this may hide problem !\n", __FUNCTION__, (U32)ticks));
        if (ticks < 0)
        {
            return;
        }
    }

    /* if < 2ms */    
    if (ticks <= (2 * STLINUX_GetClocksPerSecond() / 1000 ))
    {
        /* Waits 2ms */
        x.tv_sec  = 0;
        x.tv_nsec = 2000001;
    }
    else
    {
        x.tv_sec  = ticks / STLINUX_GetClocksPerSecond();
        x.tv_nsec = (((ticks % STLINUX_GetClocksPerSecond()) * 1000000) / STLINUX_GetClocksPerSecond()) * 1000;
    }

    nanosleep (&x, 0);
}
#endif  /* LINUX & !MODULE */

/*******************************************************************************
Name        : STOS_TaskDelayUs
Description : Asleep the task for a given time in microseconds
Parameters  : number of microseconds to wait (none if microsec <= 0)
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
#if defined ST_OSLINUX && !defined MODULE
void STOS_TaskDelayUs(int microsec)
{
    struct timespec x;

    /* microsec compared to duration of a tick in us */
    if (microsec <= 1000000/STLINUX_GetClocksPerSecond())
    {
        /* Required duration is to low compared to duration of tick */
        STTBX_Print(("%s(): WARNING !!! Inadequate number of us (0x%.8x), this may hide problem !\n", __FUNCTION__, (U32)microsec));
        if (microsec < 0)
        {
            return;
        }
    }

    /* if < 2ms */    
    if (microsec <= 2000)
    {
        /* Waits 2ms */
        x.tv_sec  = 0;
        x.tv_nsec = 2000001;
    }
    else
    {
        x.tv_sec  = microsec / 1000000;
        x.tv_nsec = microsec % 1000000;
    }

    nanosleep (&x, 0);
}
#endif  /* LINUX & !MODULE */

/*******************************************************************************
Name        : STOS_TaskDelayUntil
Description : Asleep the task until given absolute time is reached
Parameters  : wake up absolute time
Assumptions : None
Limitations :
Returns     : None
*******************************************************************************/
#if defined ST_OSLINUX && !defined MODULE
void STOS_TaskDelayUntil(STOS_Clock_t timeout)
{
    int Delay;

    if ((Delay = STOS_time_minus(timeout, STOS_time_now())) > 0)
    {
        STOS_TaskDelay(Delay);
    }
}
#endif  /* LINUX & !MODULE */


/*******************************************************************************
Name        : STOS_InterruptUninstall
Description : free interrupt
Parameters  : interrupt number, level and parameters
Assumptions : None
Limitations :
Returns     : STOS_SUCCESS/STOS_FAILURE
*******************************************************************************/
STOS_Error_t STOS_InterruptInstall( U32 InterruptNumber,
                                    U32 InterruptLevel,
                                    STOS_INTERRUPT_PROTOTYPE(Fct),
                                    char * IrqName,
                                    void * Params)
{
#if defined ST_OSLINUX
#ifdef MODULE
    return (request_irq(InterruptNumber,
                        Fct,
                        SA_INTERRUPT /* fast interrupt */,
                        IrqName,
                        Params) == 0 ? STOS_SUCCESS : STOS_FAILURE);

#else
    STTBX_Print(("%s() cannot be used in USER mode!\n", __FUNCTION__));

    return STOS_FAILURE;
#endif    

#elif defined ST_OS21
    return (interrupt_install(InterruptNumber,
                              InterruptLevel,
                              Fct,
                              Params) == OS21_SUCCESS ? STOS_SUCCESS : STOS_FAILURE);

#elif defined ST_OS20
    return (interrupt_install(InterruptNumber,
                              InterruptLevel,
                              Fct,
                              Params) == 0 ? STOS_SUCCESS : STOS_FAILURE);
#endif
}

/*******************************************************************************
Name        : STOS_InterruptUninstall
Description : free interrupt
Parameters  : interrupt number, level and parameters
Assumptions : None
Limitations :
Returns     : STOS_SUCCESS/STOS_FAILURE
*******************************************************************************/
STOS_Error_t STOS_InterruptUninstall(U32 InterruptNumber, U32 InterruptLevel, void * Params)
{
#if defined ST_OSLINUX
#ifdef MODULE
    free_irq(InterruptNumber, Params);
    return STOS_SUCCESS;
#else
    STTBX_Print(("%s() cannot be used in USER mode!\n", __FUNCTION__));
    return STOS_FAILURE;
#endif    

#elif defined ST_OS21
    Params = Params;    /* To avoid warnings */
    return (interrupt_uninstall(InterruptNumber, InterruptLevel) == OS21_SUCCESS ? STOS_SUCCESS : STOS_FAILURE);

#elif defined ST_OS20
    Params = Params;    /* To avoid warnings */
    return (interrupt_uninstall(InterruptNumber, InterruptLevel) == 0 ? STOS_SUCCESS : STOS_FAILURE);
#endif
}

/* End of stos.c */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区免费大片| 国产精品福利影院| 亚洲国产激情av| 丝袜亚洲另类丝袜在线| 国产精品77777| 69堂成人精品免费视频| 18欧美亚洲精品| 国产原创一区二区| 欧美日韩精品系列| 亚洲欧洲综合另类| 国产91丝袜在线播放九色| 91麻豆精品国产91久久久 | av网站免费线看精品| 欧美一区二区福利在线| 亚洲国产欧美一区二区三区丁香婷| 丁香五精品蜜臀久久久久99网站| 欧美一级理论片| 亚洲成人av一区二区| 色婷婷综合视频在线观看| 中文字幕在线一区免费| 九色综合狠狠综合久久| 欧美一区中文字幕| 图片区小说区区亚洲影院| 色诱亚洲精品久久久久久| 国产精品国产自产拍在线| 国产精品一区二区在线观看网站| 日韩一二三四区| 免费成人av资源网| 3d成人动漫网站| 午夜精品免费在线| 欧美日韩成人综合| 日韩高清在线电影| 9191精品国产综合久久久久久| 亚洲线精品一区二区三区八戒| 在线亚洲+欧美+日本专区| 国产精品三级在线观看| 高清不卡在线观看| 国产精品美女久久久久久久| 成a人片国产精品| 亚洲欧美成aⅴ人在线观看| av在线播放不卡| 日韩一区在线看| 91尤物视频在线观看| 一区二区欧美精品| 91精品国产综合久久久久| 污片在线观看一区二区| 日韩欧美在线综合网| 黄色资源网久久资源365| 久久精品视频一区二区| 国产一区二区三区最好精华液| 久久久久亚洲综合| 99久久久国产精品免费蜜臀| 亚洲综合免费观看高清完整版在线| 欧美午夜不卡视频| 美女网站色91| 国产欧美日韩视频一区二区| www.av亚洲| 亚洲国产综合色| 欧美大片免费久久精品三p| 成人激情图片网| 亚洲国产精品久久不卡毛片 | 国产欧美日韩麻豆91| 99久久精品一区二区| 亚洲成a人v欧美综合天堂下载| 欧美成va人片在线观看| 成人精品免费网站| 亚洲国产一区二区三区青草影视| 精品日产卡一卡二卡麻豆| 成人国产精品免费网站| 亚洲在线观看免费| 国产三级精品视频| 欧美日韩免费一区二区三区视频| 国产在线日韩欧美| 亚洲一区二区五区| 久久精品免费在线观看| 欧美日韩不卡视频| 成人精品gif动图一区| 免费成人av在线| 一区二区欧美精品| 国产色产综合色产在线视频| 欧美日韩不卡在线| 91麻豆123| 国产69精品久久777的优势| 天天影视网天天综合色在线播放| 国产精品日韩成人| 亚洲精品一区二区在线观看| 在线观看不卡一区| 成人福利视频网站| 久久国内精品自在自线400部| 一区二区高清视频在线观看| 国产女人18毛片水真多成人如厕| 欧美一区二区三区免费| 欧美在线一二三| 91影视在线播放| 成人黄色免费短视频| 亚洲欧洲美洲综合色网| 国产成人精品综合在线观看| 久久午夜老司机| 一区二区欧美视频| 这里只有精品99re| 国产精品一区二区在线播放| 91精品麻豆日日躁夜夜躁| 石原莉奈在线亚洲二区| 制服丝袜中文字幕亚洲| 国产精品伊人色| 亚洲同性gay激情无套| 欧美一区二区三区视频在线| 精品一区二区三区免费视频| 国产欧美日本一区视频| 9久草视频在线视频精品| 天堂va蜜桃一区二区三区| 久久这里都是精品| 91福利资源站| 欧美探花视频资源| 亚洲三级在线看| 欧美精品在线视频| 久久99国内精品| 日本一区二区三区四区 | 精油按摩中文字幕久久| 国产一本一道久久香蕉| xf在线a精品一区二区视频网站| 在线不卡中文字幕| 在线不卡欧美精品一区二区三区| 欧美午夜一区二区三区| 欧美日韩不卡视频| 欧美mv日韩mv亚洲| 久久亚洲综合色一区二区三区| 精品国产污网站| 国产亚洲欧美中文| 国产精品久久久久久亚洲毛片| 亚洲免费三区一区二区| 亚洲一区二区三区不卡国产欧美 | 蜜桃av噜噜一区| 精品一二三四区| 成人精品免费看| 欧美日韩专区在线| 3751色影院一区二区三区| 久久久久久久久久久电影| 亚洲国产精华液网站w| 亚洲自拍偷拍九九九| 久久精品久久综合| av在线一区二区三区| 欧美三区在线观看| 精品国产一区a| 亚洲欧美在线视频| 日本一道高清亚洲日美韩| 国产丶欧美丶日本不卡视频| 在线一区二区三区做爰视频网站| 日韩欧美成人一区二区| 国产精品国产三级国产普通话蜜臀| 樱桃视频在线观看一区| 六月丁香婷婷久久| 91视频在线观看| 日韩一区国产二区欧美三区| 国产精品久久久久一区| 蜜臀av性久久久久蜜臀aⅴ四虎 | 欧美乱熟臀69xxxxxx| 精品sm捆绑视频| 亚洲精选一二三| 精品在线一区二区三区| 在线国产亚洲欧美| 国产日韩欧美激情| 日本一区中文字幕| 在线观看国产91| 国产欧美日韩三级| 免费在线看成人av| 91久久一区二区| 中文字幕av一区 二区| 香蕉乱码成人久久天堂爱免费| 成人永久免费视频| 777精品伊人久久久久大香线蕉| 最新欧美精品一区二区三区| 狠狠色丁香久久婷婷综合_中| 欧美伊人精品成人久久综合97| 欧美高清在线精品一区| 精品一区二区三区影院在线午夜 | 午夜精品久久久久影视| jlzzjlzz亚洲日本少妇| 久久久av毛片精品| 蜜桃视频免费观看一区| 在线视频一区二区三区| **欧美大码日韩| 国产成人精品三级麻豆| 精品国产一二三区| 人人爽香蕉精品| 欧美美女bb生活片| 亚洲最大色网站| 欧美在线观看你懂的| 一区二区三区中文字幕电影| 成人动漫在线一区| 国产精品久久二区二区| 丰满放荡岳乱妇91ww| 国产午夜久久久久| 国产激情一区二区三区| 国产亚洲精品资源在线26u| 激情五月婷婷综合| 精品欧美乱码久久久久久1区2区| 久久精品国产99国产| 欧美一级专区免费大片| 麻豆成人综合网|