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

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

?? datapage.c

?? freescale 9s12dp256單片機spi 通信原代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
  FILE        : datapage.c
  PURPOSE     : paged data access runtime routines
  MACHINE     : Motorola 68HC12 (Target)
  LANGUAGE    : ANSI-C
  HISTORY     : 21.7.96 first version created
******************************************************************************/

/*
   According to the -Cp option of the compiler the
   __DPAGE__, __PPAGE__ and __EPAGE__ macros are defined.
   If none of them is given as argument, then no page accesses should occur and
   this runtime routine should not be used !
   To be on the save side, the runtime routines are created anyway.
   If some of the -Cp options are given an adapted versions which only covers the
   needed cases is produced.
*/

/* if no compiler option -Cp is given, it is assumed that all possible are given : */

/* Compile with option -DHCS12 to activate this code */
#if defined(HCS12) || defined(_HCS12) /* HCS12 family has PPAGE register only at 0x30 */
#define PPAGE_ADDR (0x30+REGISTER_BASE)
#ifndef __PPAGE__ /* may be set already by option -CPPPAGE */
#define __PPAGE__
#endif
/* Compile with option -DDG128 to activate this code */
#elif defined DG128 /* HC912DG128 derivative has PPAGE register only at 0xFF */
#define PPAGE_ADDR (0xFF+REGISTER_BASE)
#ifndef __PPAGE__ /* may be set already by option -CPPPAGE */
#define __PPAGE__
#endif
#elif defined(HC812A4)
/* all setting default to A4 already */
#endif


#if !defined(__EPAGE__) && !defined(__PPAGE__) && !defined(__DPAGE__)
/* as default use all page registers */
#define __DPAGE__
#define __EPAGE__
#define __PPAGE__
#endif

/* modify the following defines to your memory configuration */

#define EPAGE_LOW_BOUND   0x400u
#define EPAGE_HIGH_BOUND  0x7ffu

#define DPAGE_LOW_BOUND   0x7000u
#define DPAGE_HIGH_BOUND  0x7fffu

#define PPAGE_LOW_BOUND   (DPAGE_HIGH_BOUND+1)
#define PPAGE_HIGH_BOUND  0xBFFFu

#define REGISTER_BASE      0x0u
#ifndef DPAGE_ADDR
#define DPAGE_ADDR        (0x34u+REGISTER_BASE)
#endif
#ifndef EPAGE_ADDR
#define EPAGE_ADDR        (0x36u+REGISTER_BASE)
#endif
#ifndef PPAGE_ADDR
#define PPAGE_ADDR        (0x35u+REGISTER_BASE)
#endif

/*
  The following parts about the defines are assumed in the code of _GET_PAGE_REG :
  - the memory region controlled by DPAGE is above the area controlled by the EPAGE and
    below the area controlled by the PPAGE.
  - the lower bound of the PPAGE area is equal to be the higher bound of the DPAGE area + 1
*/
#if EPAGE_LOW_BOUND >= EPAGE_HIGH_BOUND || EPAGE_HIGH_BOUND >= DPAGE_LOW_BOUND || DPAGE_LOW_BOUND >= DPAGE_HIGH_BOUND || DPAGE_HIGH_BOUND >= PPAGE_LOW_BOUND || PPAGE_LOW_BOUND >= PPAGE_HIGH_BOUND
#error /* please adapt _GET_PAGE_REG for this non default page configuration */
#endif

#if DPAGE_HIGH_BOUND+1 != PPAGE_LOW_BOUND
#error /* please adapt _GET_PAGE_REG for this non default page configuration */
#endif

#include "hidef.h"
#include "non_bank.sgm"
#include "runtime.sgm"

/* this module does either control if any access is in the bounds of the specified page or */
/* ,if only one page is specified, just use this page. */
/* This behavior is controlled by the define USE_SEVERAL_PAGES. */
/* If !USE_SEVERAL_PAGES does increase the performance significantly */
/* NOTE : When !USE_SEVERAL_PAGES, the page is also set for accesses outside of the area controlled */
/*        by this single page. But this is usually no problem because the page is set again before any other access */

#if !defined(__DPAGE__) && !defined(__EPAGE__) && !defined(__PPAGE__)
/* no page at all is specified */
/* only specifing the right pages will speed up these functions a lot */
#define USE_SEVERAL_PAGES 1
#elif defined(__DPAGE__) && defined(__EPAGE__) || defined(__DPAGE__) && defined(__PPAGE__) || defined(__EPAGE__) && defined(__PPAGE__)
/* more than one page register is used */
#define USE_SEVERAL_PAGES 1
#else

#define USE_SEVERAL_PAGES 0

#if defined(__DPAGE__) /* check which pages are used  */
#define PAGE_ADDR PPAGE_ADDR
#elif defined(__EPAGE__)
#define PAGE_ADDR EPAGE_ADDR
#elif defined(__PPAGE__)
#define PAGE_ADDR PPAGE_ADDR
#else /* we dont know which page, decide it at runtime */
#error /* must not happen */
#endif

#endif


#if USE_SEVERAL_PAGES /* only needed for several pages support */
/*--------------------------- _GET_PAGE_REG --------------------------------
  Runtime routine to detect the right register depending on the 16 bit offset part
  of an address.
  This function is only used by the functions below.

  Depending on the compiler options -Cp different versions of _GET_PAGE_REG are produced.

  Arguments :
  - Y : offset part of an address

  Result :
  if address Y is controlled by a page register :
  - X : address of page register if Y is controlled by an page register
  - Zero flag cleared
  - all other registers remain unchanged

  if address Y is not controlled by a page register :
  - Zero flag is set
  - all registers remain unchanged

  --------------------------- _GET_PAGE_REG ----------------------------------*/

#if defined(__DPAGE__)

#ifdef __cplusplus
extern "C"
#endif
#pragma NO_ENTRY
#pragma NO_EXIT
#pragma NO_FRAME

static void NEAR _GET_PAGE_REG(void) { /*lint -esym(528, _GET_PAGE_REG) used in asm code */
  asm {
L_DPAGE:
        CPY  #DPAGE_LOW_BOUND     ; test of lower bound of DPAGE
#if defined(__EPAGE__)
        BLO  L_EPAGE              ; EPAGE accesses are possible
#else
        BLO  L_NOPAGE             ; no paged memory below accesses
#endif
        CPY  #DPAGE_HIGH_BOUND    ; test of higher bound DPAGE/lower bound PPAGE
#if defined(__PPAGE__)
        BHI  L_PPAGE              ; EPAGE accesses are possible
#else
        BHI  L_NOPAGE             ; no paged memory above accesses
#endif
FOUND_DPAGE:
        LDX  #DPAGE_ADDR          ; load page register address and clear zero flag
        RTS

#if defined(__PPAGE__)
L_PPAGE:
        CPY  #PPAGE_HIGH_BOUND    ; test of higher bound of PPAGE
        BHI  L_NOPAGE
FOUND_PPAGE:
        LDX  #PPAGE_ADDR          ; load page register address and clear zero flag
        RTS
#endif

#if defined(__EPAGE__)
L_EPAGE:
        CPY #EPAGE_LOW_BOUND      ; test of lower bound of EPAGE
        BLO L_NOPAGE
        CPY #EPAGE_HIGH_BOUND     ; test of higher bound of EPAGE
        BHI L_NOPAGE

FOUND_EPAGE:
        LDX #EPAGE_ADDR           ; load page register address and clear zero flag
        RTS
#endif

L_NOPAGE:
        ORCC #0x04                ; sets zero flag
        RTS
  }
}

#else /* !defined(__DPAGE__) */

#if defined( __PPAGE__ )

#ifdef __cplusplus
extern "C"
#endif
#pragma NO_ENTRY
#pragma NO_EXIT
#pragma NO_FRAME

static void NEAR _GET_PAGE_REG(void) {	/*lint -esym(528, _GET_PAGE_REG) used in asm code */
  asm {
L_PPAGE:
        CPY  #PPAGE_LOW_BOUND     ; test of lower bound of PPAGE
#if defined( __EPAGE__ )
        BLO  L_EPAGE
#else
        BLO  L_NOPAGE             ; no paged memory below
#endif
        CPY  #PPAGE_HIGH_BOUND    ; test of higher bound PPAGE
        BHI  L_NOPAGE
FOUND_PPAGE:
        LDX  #PPAGE_ADDR          ; load page register address and clear zero flag
        RTS
#if defined( __EPAGE__ )
L_EPAGE:
        CPY #EPAGE_LOW_BOUND      ; test of lower bound of EPAGE
        BLO L_NOPAGE
        CPY #EPAGE_HIGH_BOUND     ; test of higher bound of EPAGE
        BHI L_NOPAGE
FOUND_EPAGE:
        LDX #EPAGE_ADDR           ; load page register address and clear zero flag
        RTS
#endif

L_NOPAGE:                         ; not in any allowed page area
                                  ; its a far access to a non paged variable
        ORCC #0x04                ; sets zero flag
        RTS
  }
}

#else /* !defined(__DPAGE__ ) && !defined( __PPAGE__) */
#if defined(__EPAGE__)

#ifdef __cplusplus
extern "C"
#endif
#pragma NO_ENTRY
#pragma NO_EXIT
#pragma NO_FRAME

static void NEAR _GET_PAGE_REG(void) { /*lint -esym(528, _GET_PAGE_REG) used in asm code */
  asm {
L_EPAGE:
        CPY #EPAGE_LOW_BOUND      ; test of lower bound of EPAGE
        BLO L_NOPAGE
        CPY #EPAGE_HIGH_BOUND     ; test of higher bound of EPAGE
        BHI L_NOPAGE
FOUND_EPAGE:
        LDX #EPAGE_ADDR           ; load page register address and clear zero flag
        RTS

L_NOPAGE:                         ; not in any allowed page area
                                  ; its a far access to a non paged variable
        ORCC #0x04                ; sets zero flag
        RTS
  }
}

#endif /*  defined(__EPAGE__) */
#endif /*  defined(__PPAGE__) */
#endif /*  defined(__DPAGE__) */

#endif /* USE_SEVERAL_PAGES */

/*--------------------------- _SET_PAGE --------------------------------
  Runtime routine to set the right page register. This routine is used if the compiler
  does not know the right page register, i.e. if the option -Cp is used for more than
  one pageregister or if the runtime option is used for one of the -Cp options.

  Arguments :
  - offset part of an address in the Y register
  - page part of an address in the B register

  Result :
  - page part written into the correct page register.
  - the old page register content is destroyed
  - all processor registers remains unchanged
  --------------------------- _SET_PAGE ----------------------------------*/

#ifdef __cplusplus
extern "C"
#endif
#pragma NO_ENTRY
#pragma NO_EXIT
#pragma NO_FRAME

void NEAR _SET_PAGE(void) {
#if USE_SEVERAL_PAGES
  asm {
          PSHX                  ; save X register
          __PIC_JSR(_GET_PAGE_REG)
          BEQ    L_NOPAGE
          STAB   0,X            ; set page register
L_NOPAGE:
          PULX                  ; restore X register
          RTS
  }
#else /* USE_SEVERAL_PAGES */
  asm {
          STAB   PAGE_ADDR      ; set page register
          RTS
  }
#endif /* USE_SEVERAL_PAGES */
}

/*--------------------------- _LOAD_FAR_8 --------------------------------
  This runtime routine is used to access paged memory via a runtime function.
  It may also be used if the compiler  option -Cp is not used with the runtime argument.

  Arguments :
  - offset part of an address in the Y register
  - page part of an address in the B register

  Result :
  - value to be read in the B register
  - all other registers remains unchanged
  - all page register still contain the same value
  --------------------------- _LOAD_FAR_8 ----------------------------------*/

#ifdef __cplusplus
extern "C"
#endif
#pragma NO_ENTRY
#pragma NO_EXIT
#pragma NO_FRAME

void NEAR _LOAD_FAR_8(void) {
#if USE_SEVERAL_PAGES
  asm {
          PSHX                ; save X register
          __PIC_JSR(_GET_PAGE_REG)
          BEQ    L_NOPAGE
          PSHA                ; save A register
          LDAA   0,X          ; save page register
          STAB   0,X          ; set page register
          LDAB   0,Y          ; actual load, overwrites page
          STAA   0,X          ; restore page register
          PULA                ; restore A register
          PULX                ; restore X register
          RTS
L_NOPAGE:
          LDAB   0,Y          ; actual load, overwrites page
          PULX                ; restore X register
          RTS
  }
#else /* USE_SEVERAL_PAGES */
  asm {
          PSHA                ; save A register
          LDAA   PAGE_ADDR    ; save page register
          STAB   PAGE_ADDR    ; set page register
          LDAB   0,Y          ; actual load, overwrites page
          STAA   PAGE_ADDR    ; restore page register
          PULA                ; restore A register
          RTS
  }
#endif /* USE_SEVERAL_PAGES */
}

/*--------------------------- _LOAD_FAR_16 --------------------------------
  This runtime routine is used to access paged memory via a runtime function.
  It may also be used if the compiler  option -Cp is not used with the runtime argument.

  Arguments :
  - offset part of an address in the Y register
  - page part of an address in the B register

  Result :
  - value to be read in the Y register
  - all other registers remains unchanged
  - all page register still contain the same value
  --------------------------- _LOAD_FAR_16 ----------------------------------*/

#ifdef __cplusplus
extern "C"
#endif
#pragma NO_ENTRY
#pragma NO_EXIT
#pragma NO_FRAME

void NEAR _LOAD_FAR_16(void) {
#if USE_SEVERAL_PAGES
  asm {
          PSHX                 ; save X register
          __PIC_JSR(_GET_PAGE_REG)
          BEQ   L_NOPAGE
          PSHA                 ; save A register
          LDAA  0,X            ; save page register
          STAB  0,X            ; set page register
          LDY   0,Y            ; actual load, overwrites address
          STAA  0,X            ; restore page register
          PULA                 ; restore A register
          PULX                 ; restore X register
          RTS
L_NOPAGE:
          LDY   0,Y              ; actual load, overwrites address
          PULX                 ; restore X register
          RTS
  }
#else /* USE_SEVERAL_PAGES */
  asm {
          PSHA                ; save A register
          LDAA   PAGE_ADDR    ; save page register
          STAB   PAGE_ADDR    ; set page register
          LDY    0,Y          ; actual load, overwrites address
          STAA   PAGE_ADDR    ; restore page register
          PULA                ; restore A register
          RTS
  }
#endif /* USE_SEVERAL_PAGES */
}
/*--------------------------- _LOAD_FAR_24 --------------------------------
  This runtime routine is used to access paged memory via a runtime function.
  It may also be used if the compiler  option -Cp is not used with the runtime argument.

  Arguments :
  - offset part of an address in the Y register

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区三区在线不卡| 高清日韩电视剧大全免费| 欧美日韩一卡二卡三卡 | 欧美精品三级日韩久久| 亚洲国产精品久久不卡毛片 | 成人免费视频视频在线观看免费| 国产亚洲视频系列| 国产**成人网毛片九色 | 亚洲一卡二卡三卡四卡无卡久久 | 日韩欧美国产一区二区三区| 蜜臀a∨国产成人精品| 久久综合九色综合欧美就去吻| 狠狠色丁香婷婷综合| 国产网红主播福利一区二区| 91麻豆视频网站| 天涯成人国产亚洲精品一区av| 3d成人h动漫网站入口| 国产呦精品一区二区三区网站| 国产欧美日韩亚州综合| 色婷婷av一区二区三区软件| 香港成人在线视频| 日韩欧美一二三区| 成人黄色777网| 性做久久久久久免费观看欧美| 欧美一区二区观看视频| 国产91精品久久久久久久网曝门 | 一区二区三区日韩欧美精品| 67194成人在线观看| 国产一区二区三区高清播放| 中文字幕一区二区三区精华液 | 欧美高清视频一二三区 | 日韩avvvv在线播放| 久久久99久久| 欧美视频在线观看一区| 国产一区二区福利| 一区二区在线观看免费视频播放| 日韩欧美中文一区二区| 一本一本大道香蕉久在线精品 | 国产自产2019最新不卡| 一区二区三区精品久久久| 2020国产精品久久精品美国| 97aⅴ精品视频一二三区| 久久国产尿小便嘘嘘| 一卡二卡欧美日韩| 久久人人超碰精品| 欧美三级电影在线观看| 成人一区二区三区在线观看| 日韩成人午夜电影| 亚洲天堂成人网| 精品国产区一区| 欧美日韩精品是欧美日韩精品| 成人黄色777网| 国产在线国偷精品产拍免费yy | 亚洲丝袜美腿综合| 久久综合国产精品| 制服丝袜亚洲播放| 在线精品视频免费播放| 粗大黑人巨茎大战欧美成人| 精品无码三级在线观看视频| 午夜精品福利视频网站| 国产精品久久久久aaaa| 久久日韩粉嫩一区二区三区| 日韩女优毛片在线| 欧美高清dvd| 欧美午夜影院一区| 91小视频免费观看| 成人av在线资源网| 国产精品资源网| 久久国产综合精品| 免费人成精品欧美精品| 肉丝袜脚交视频一区二区| 一区二区三区在线播放| 亚洲色图制服诱惑 | 在线免费视频一区二区| 色哟哟亚洲精品| av在线一区二区| 成人av在线电影| 成人ar影院免费观看视频| 丁香婷婷综合色啪| 国产乱码精品一品二品| 国产老肥熟一区二区三区| 韩国成人在线视频| 国精产品一区一区三区mba桃花| 美国十次综合导航| 老鸭窝一区二区久久精品| 欧美a一区二区| 蜜臀精品一区二区三区在线观看| 麻豆国产精品视频| 国产真实乱对白精彩久久| 激情综合五月天| 国产盗摄一区二区| 成人黄色免费短视频| k8久久久一区二区三区| 99视频精品全部免费在线| 91小视频免费观看| 欧美视频自拍偷拍| 欧美一级黄色片| 久久久噜噜噜久噜久久综合| 国产亚洲午夜高清国产拍精品| 中日韩免费视频中文字幕| 亚洲人一二三区| 午夜激情久久久| 久久国产福利国产秒拍| 国产91丝袜在线播放| 99久久精品免费观看| 精品视频免费看| 日韩午夜在线观看| 国产午夜精品理论片a级大结局 | 欧美中文字幕亚洲一区二区va在线 | 偷拍与自拍一区| 九九**精品视频免费播放| 成人听书哪个软件好| 在线一区二区三区四区| 91精品国产色综合久久久蜜香臀| 欧美zozozo| 亚洲人成在线播放网站岛国 | 欧美xxxxx裸体时装秀| 国产精品狼人久久影院观看方式| 亚洲黄色在线视频| 久久精品噜噜噜成人88aⅴ | 国产精品一二三四| 色欧美片视频在线观看在线视频| 欧美福利一区二区| 欧美韩国一区二区| 午夜精品福利在线| 国产iv一区二区三区| 欧美理论在线播放| 欧美国产一区二区| 天天av天天翘天天综合网色鬼国产| 国产乱国产乱300精品| 欧美三级视频在线| 中文字幕成人在线观看| 午夜欧美2019年伦理| 成人免费看视频| 日韩免费看的电影| 夜夜操天天操亚洲| 国产成人小视频| 91精品国产欧美一区二区成人| 国产精品蜜臀在线观看| 视频一区二区三区中文字幕| 91小视频免费观看| 久久新电视剧免费观看| 视频在线观看91| 91在线视频播放| 久久精品一区二区| 裸体健美xxxx欧美裸体表演| 在线观看国产91| 国产精品初高中害羞小美女文| 九一久久久久久| 日韩无一区二区| 亚洲成人动漫在线免费观看| 色综合久久久久久久久| 国产精品情趣视频| 国产成人av一区二区三区在线| 欧美一区二区久久| 亚洲成人黄色影院| 在线免费视频一区二区| 亚洲精品久久久久久国产精华液| 高清成人在线观看| 久久久久88色偷偷免费| 另类小说色综合网站| 日韩午夜激情av| 玖玖九九国产精品| 欧美电视剧免费全集观看| 日韩专区在线视频| 精品视频色一区| 午夜精品一区在线观看| 欧美日韩在线免费视频| 亚洲已满18点击进入久久| 91免费视频网| 亚洲精品国产无套在线观| 91在线观看成人| 尤物在线观看一区| 欧美最猛性xxxxx直播| 亚洲愉拍自拍另类高清精品| 在线视频国产一区| 亚洲成人精品在线观看| 欧美伦理视频网站| 爽好久久久欧美精品| 日韩一区二区视频| 激情综合一区二区三区| 国产午夜精品福利| 亚洲chinese男男1069| 91精品国产综合久久婷婷香蕉 | 午夜精品123| 日韩欧美精品三级| 国产在线视频不卡二| 国产精品网站在线播放| www.66久久| 亚洲成人在线网站| 欧美成人r级一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 国产欧美1区2区3区| 99r国产精品| 亚洲图片一区二区| 精品日韩欧美一区二区| 懂色av噜噜一区二区三区av| 亚洲精品日韩一| 欧美一区二区私人影院日本| 国产一二精品视频|