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

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

?? sfrs.c

?? TDK 6521 SOC 芯片 DEMO程序
?? C
字號:
/***************************************************************************
 * This code and information is provided "as is" without warranty of any   *
 * kind, either expressed or implied, including but not limited to the     *
 * implied warranties of merchantability and/or fitness for a particular   *
 * purpose.                                                                *
 *                                                                         *
 * Copyright (C) 2005 Teridian Semiconductor Corp. All Rights Reserved.    *
 ***************************************************************************/
//**************************************************************************
//  DESCRIPTION: 71M652x POWER METER - Special Function Register Access.
// 
//  AUTHOR:  MTF
//
//  HISTORY: See end of file
//**************************************************************************
// File:  SFRS.C
//               
// Low level API for SFRs and MEMORY.
//
#include "options.h"
#include "sfrs.h"  // included to assure interface is right

/*** External functions used within this module ***/
// None.

/*** External variables used within this module ***/
// None.

/*** Public functions declared within this module ***/
// see sfrs.h

/*** Public variables declared within this module ***/
// None.

/*** Private functions declared within this module ***/
// None.

/*** Private variables declared within this module ***/
// None.

//  SFR API
//

#pragma save
#pragma NOAREGS
enum SFR_RC SFR_Read (uint8_t s, int8d_t *pc) small reentrant
{
    enum SFR_RC rc = SFR_OK;
    int8_t c;
    
    switch (s | 0x80)
    {                                            // 
       case 0x80:        c = P0;        break;   // 
       case 0x81:        c = SP;        break;   // 
       case 0x82:        c = DPL;       break;   // 
       case 0x83:        c = DPH;       break;   // 
       case 0x84:        c = DPL1;      break;   // 
       case 0x85:        c = DPH1;      break;   // 
       case 0x86:        c = WDTREL;    break;   // 
       case 0x87:        c = PCON;      break;   // 

       case 0x88:        c = TCON;      break;   // 
       case 0x89:        c = TMOD;      break;   // 
       case 0x8A:        c = TL0;       break;   // 
       case 0x8B:        c = TL1;       break;   // 
       case 0x8C:        c = TH0;       break;   // 
       case 0x8D:        c = TH1;       break;   // 
       case 0x8E:        c = CKCON;     break;   // 

       case 0x90:        c = P1;        break;   // 
       case 0x91:        c = DIR1;      break;   // 
       case 0x92:        c = DPS;       break;   // 
       case 0x94:        c = ERASE;     break;   // 

       case 0x98:        c = SCON;      break;   // 
       case 0x99:        c = SBUF;      break;   // 
       case 0x9A:        c = IEN2;      break;   // 
       case 0x9B:        c = S1CON;     break;   // 
       case 0x9C:        c = S1BUF;     break;   // 
       case 0x9D:        c = S1RELL;    break;   // 
       case 0x9E:        c = EEDATA;    break;   // 
       case 0x9F:        c = EECTRL;    break;   // 

       case 0xA0:        c = P2;        break;   // 
       case 0xA1:        c = DIR2;      break;   // 
       case 0xA2:        c = DIR0;      break;   // 

       case 0xA8:        c = IE;        break;   // 
       case 0xA9:        c = IP;        break;   // 
       case 0xAA:        c = S0RELL;    break;   // 

       case 0xB0:        c = P3;        break;   // 
       case 0xB2:        c = FCTRL;     break;   // 
       case 0xB7:        c = FPAGE;     break;   // 

       case 0xB8:        c = IEN1;      break;   // 
       case 0xB9:        c = IP1;       break;   // 
       case 0xBA:        c = S0RELH;    break;   // 
       case 0xBB:        c = S1RELH;    break;   // 
       case 0xBF:        c = ADRMSB;    break;   // 

       case 0xC0:        c = IRCON;     break;   //

       case 0xC8:        c = T2CON;     break;   //

       case 0xD0:        c = PSW;       break;   //
       case 0xD8:        c = WDCON;     break;   //

       case 0xE8:        c = IFLAGS;    break;   //
 
       case 0xF0:        c = B;         break;   //
       case 0xF8:        c = INTBIT;    break;   //

       default:
          rc = SFR_INVALID;
          c = 0xff;
          break;
    }

    *pc = c;
    return (rc);
}
#pragma restore

#pragma save
#pragma NOAREGS
enum SFR_RC SFR_Write (uint8_t s, uint8_t c, uint8_t op) small reentrant
{
    static enum SFR_RC rc;
    static uint8_t data d;

    switch (op)
    {
       case ASSIGN:
           rc = SFR_OK;
	   break;
       case AND:
           if (rc = SFR_Read (s, (int8d_t *) &d) != SFR_OK)       
               return (rc);
           c &= d;
	   break;
       case OR:
           if (rc = SFR_Read (s, (int8d_t *) &d) != SFR_OK)       
               return (rc);
           c |= d;
           break;
    }

    switch (s | 0x80)
    {                                            //
       case 0x80:        P0 = c;     break;      //
       case 0x81:        SP = c;     break;      //
       case 0x82:        DPL = c;    break;      //
       case 0x83:        DPH = c;    break;      //
       case 0x84:        DPL1 = c;   break;      //
       case 0x85:        DPH1 = c;   break;      //
       case 0x86:        WDTREL = c; break;      //
       case 0x87:        PCON = c;   break;      // 

       case 0x88:        TCON = c;   break;      // 
       case 0x89:        TMOD = c;   break;      // 
       case 0x8A:        TL0 = c;    break;      // 
       case 0x8B:        TL1 = c;    break;      // 
       case 0x8C:        TH0 = c;    break;      // 
       case 0x8D:        TH1 = c;    break;      // 
       case 0x8E:        CKCON = c;  break;      // 

       case 0x90:        USER1 = c;  break;      // 
       case 0x91:        DIR1 = c;   break;      // 
       case 0x92:        DPS = c;    break;      // 
       case 0x94:        ERASE = c;  break;      // 

       case 0x98:        SCON = c;   break;      // 
       case 0x99:        SBUF = c;   break;      // 
       case 0x9A:        IEN2 = c;   break;      // 
       case 0x9B:        S1CON = c;  break;      // 
       case 0x9C:        S1BUF = c;  break;      // 
       case 0x9D:        S1RELL = c; break;      // 
       case 0x9E:        EEDATA = c; break;      // 
       case 0x9F:        EECTRL = c; break;      // 

       case 0xA0:        P2 = c;     break;      // 
       case 0xA1:        DIR2 = c;   break;      // 
       case 0xA2:        DIR0 = c;   break;      // 

       case 0xA8:        IE = c;     break;      // 
       case 0xA9:        IP = c;     break;      // 
       case 0xAA:        S0RELL = c; break;      // 

       case 0xB0:        P3 = c;     break;      // 
       case 0xB2:        EA = FALSE;    FCTRL = c;     EA = TRUE;     break;
       case 0xB7:        EA = FALSE;    FPAGE = c;     EA = TRUE;     break;

       case 0xB8:        IEN1 = c;   break;      // 
       case 0xB9:        IP1 = c;    break;      // 
       case 0xBA:        S0RELH = c; break;      // 
       case 0xBB:        S1RELH = c; break;      // 
       case 0xBF:        ADRMSB = c; break;      // 

       case 0xC0:        IRCON = c;  break;      // 

       case 0xC8:        T2CON = c;  break;      // 

       case 0xD0:        PSW = c;    break;      //
       case 0xD8:        WDCON = c;  break;      //

       case 0xE8:        IFLAGS = c; break;      //
 
       case 0xF0:        B = c;      break;      //
       case 0xF8:        INTBIT = c; break;      //

       default:
          break;
    }

    return (rc);
}
#pragma restore
/***************************************************************************
 * History:
 * $Log: sfrs.c,v $
 * Revision 1.5  2006/09/09 01:15:55  gmikef
 * *** empty log message ***
 *
 * Revision 1.4  2006/06/29 00:58:44  tvander
 * Added NOAREGs to reentrant code.
 *
 * Revision 1.2  2005/09/22 23:45:29  tvander
 * Clean build all models and unit tests, updated copyright to be fore Teridian
 *
 * Revision 1.1  2005/08/22 22:30:57  tvander
 * Clean build of FLAG system
 * No pulse counting.
 * No debug/CLI.
 *
 * Revision 1.1  2005/08/18 02:56:09  gmikef
 * *** empty log message ***
 *
 * Copyright (C) 2005 Teridian Semiconductor Corp. All Rights Reserved.    *
 * this program is fully protected by the United States copyright          *
 * laws and is the property of Teridian Semiconductor Corporation.         *
 ***************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品蜜臀在线观看| 色婷婷av一区二区三区gif| 日韩一区二区影院| 肉色丝袜一区二区| 日韩欧美aaaaaa| 国产一区中文字幕| 久久精品网站免费观看| 成人国产精品视频| 亚洲人精品一区| 欧美色图天堂网| 日本韩国精品在线| 亚洲福利电影网| 精品少妇一区二区三区在线播放| 另类小说一区二区三区| 日本一区二区三区免费乱视频 | 亚洲国产aⅴ成人精品无吗| 在线观看日韩精品| 亚洲福利一区二区| 久久先锋资源网| 99久久精品情趣| 午夜久久久久久| 久久久综合视频| 暴力调教一区二区三区| 亚洲成人av中文| 亚洲精品一区二区三区蜜桃下载| 成人免费视频视频在线观看免费 | 天天操天天色综合| 精品久久久久久亚洲综合网| 国产经典欧美精品| 亚洲一区二区不卡免费| 欧美一卡二卡在线| jiyouzz国产精品久久| 香蕉成人啪国产精品视频综合网 | 亚洲国产精品久久人人爱| 91精品国产综合久久久蜜臀粉嫩| 国内成人自拍视频| 亚洲最色的网站| 久久影院视频免费| 欧亚洲嫩模精品一区三区| 狠狠色狠狠色综合| 亚洲地区一二三色| 中文字幕 久热精品 视频在线| 国产精品影视网| 亚洲女爱视频在线| 久久青草欧美一区二区三区| 波波电影院一区二区三区| 奇米一区二区三区| 亚洲综合一区二区三区| 国产偷国产偷精品高清尤物| 日本道色综合久久| 国产成人综合精品三级| 亚洲一区二区欧美激情| 国产精品伦理在线| 久久久亚洲综合| 欧美精品日日鲁夜夜添| 91麻豆国产自产在线观看| 奇米影视7777精品一区二区| 亚洲国产综合在线| 欧美国产精品久久| 精品少妇一区二区| 欧美一级久久久| 欧洲精品在线观看| 色呦呦国产精品| 国内外成人在线视频| 蜜桃av一区二区三区电影| 一区二区欧美精品| 亚洲美女在线一区| 亚洲三级电影网站| 日本一区二区三区电影| 26uuu久久综合| 精品美女一区二区三区| 精品理论电影在线| 亚洲精品在线观看视频| 欧美tk丨vk视频| 欧美大肚乱孕交hd孕妇| 日韩午夜在线观看视频| 9191久久久久久久久久久| 91.成人天堂一区| 99re这里都是精品| 99精品热视频| 91亚洲精华国产精华精华液| 91免费视频网| 欧美一区二区二区| 久久国产综合精品| 丝瓜av网站精品一区二区| 久久综合国产精品| 欧美日本在线看| 国内精品伊人久久久久影院对白| 91久久久免费一区二区| 99视频有精品| fc2成人免费人成在线观看播放 | 成人午夜电影久久影院| 久久精品亚洲一区二区三区浴池| 欧美精品一区二区三区很污很色的 | 欧美日韩国产a| 欧美一区二区三区啪啪| 国产a区久久久| 亚洲男帅同性gay1069| 成人黄色av电影| 风流少妇一区二区| 欧美私人免费视频| 欧美午夜精品免费| 91精品国产一区二区三区香蕉| 在线观看免费亚洲| 日韩精品一区二区三区在线播放| 欧美日韩日日摸| 欧美成人国产一区二区| 在线免费观看成人短视频| 亚洲一区二区三区四区在线| 日韩电影在线免费| 色视频欧美一区二区三区| 欧美电影影音先锋| 国产欧美日韩在线| 麻豆精品一区二区综合av| 日韩欧美国产三级电影视频| 在线一区二区观看| 亚洲欧洲另类国产综合| 精品一区二区在线视频| 欧美人体做爰大胆视频| 肉肉av福利一精品导航| 粉嫩高潮美女一区二区三区| 亚洲一区视频在线观看视频| 看电视剧不卡顿的网站| 93久久精品日日躁夜夜躁欧美| 91精品国产入口在线| 国产亚洲精品aa| 天堂av在线一区| 成人av免费在线| 欧美一区二区不卡视频| 中文字幕一区二区在线播放| 日韩精品免费专区| 菠萝蜜视频在线观看一区| 欧美男人的天堂一二区| 国产精品你懂的在线| 免费国产亚洲视频| 欧美久久一区二区| 99久久99久久久精品齐齐| 色94色欧美sute亚洲线路一ni| 日韩免费一区二区| 一区二区视频免费在线观看| 国产精品18久久久久久久久| 欧美在线你懂得| 中文字幕一区二区三区精华液 | 亚洲电影在线播放| 国产成人亚洲综合a∨婷婷| 欧美日本视频在线| 亚洲视频图片小说| 国产精品综合网| 欧美一区二区三区四区久久| 亚洲精品ww久久久久久p站| 国产91色综合久久免费分享| 91精品国产色综合久久| 亚洲第一成年网| 欧美性大战久久| 亚洲欧洲无码一区二区三区| 国产ts人妖一区二区| 精品国产人成亚洲区| 免费在线观看视频一区| 欧美日韩一区二区三区不卡 | 婷婷亚洲久悠悠色悠在线播放 | 欧美色图在线观看| 一区二区三区自拍| 色成人在线视频| 亚洲日本va午夜在线影院| 成人国产免费视频| 国产精品久久777777| 成人成人成人在线视频| 国产欧美一区二区精品性色| 国产一区二区三区免费| 精品久久一区二区三区| 精品一区二区三区av| 精品国产乱子伦一区| 国产在线精品一区二区夜色| 欧美草草影院在线视频| 激情久久五月天| 亚洲精品一区二区三区精华液 | 春色校园综合激情亚洲| 国产日韩精品久久久| 国产黄色精品网站| 国产女主播视频一区二区| 成人免费看片app下载| 中文字幕视频一区| 欧美系列日韩一区| 日韩国产精品久久| 欧美午夜在线一二页| 亚洲综合无码一区二区| 欧美色中文字幕| 免费在线观看一区| 国产欧美视频一区二区| 99riav一区二区三区| 亚洲成在人线免费| 日韩你懂的在线播放| 丰满岳乱妇一区二区三区| 成人免费在线视频观看| 91国内精品野花午夜精品| 图片区小说区国产精品视频| 精品免费国产二区三区| av电影在线观看一区| 亚洲一区av在线| 精品精品国产高清一毛片一天堂|