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

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

?? timer.c

?? u-boot-1.1.6 源碼包
?? C
字號:
/* * (C) Copyright 2000 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */#include <common.h>#include <commproc.h>#include <mpc8xx_irq.h>#include <exports.h>DECLARE_GLOBAL_DATA_PTR;#undef	DEBUG#define	TIMER_PERIOD	1000000		/* 1 second clock */static void timer_handler (void *arg);/* Access functions for the Machine State Register */static __inline__ unsigned long get_msr(void){    unsigned long msr;    asm volatile("mfmsr %0" : "=r" (msr) :);    return msr;}static __inline__ void set_msr(unsigned long msr){    asm volatile("mtmsr %0" : : "r" (msr));}/* * Definitions to access the CPM Timer registers * See 8xx_immap.h for Internal Memory Map layout, * and commproc.h for CPM Interrupt vectors (aka "IRQ"s) */typedef struct tid_8xx_cpmtimer_s {  int		 cpm_vec;	/* CPM Interrupt Vector for this timer	*/  ushort	*tgcrp;		/* Pointer to Timer Global Config Reg.	*/  ushort	*tmrp;		/* Pointer to Timer Mode Register	*/  ushort	*trrp;		/* Pointer to Timer Reference Register	*/  ushort	*tcrp;		/* Pointer to Timer Capture Register	*/  ushort	*tcnp;		/* Pointer to Timer Counter Register	*/  ushort	*terp;		/* Pointer to Timer Event Register	*/} tid_8xx_cpmtimer_t;#ifndef CLOCKRATE#  define CLOCKRATE 64#endif#define	CPMT_CLOCK_DIV		16#define	CPMT_MAX_PRESCALER	256#define CPMT_MAX_REFERENCE	65535	/* max. unsigned short */#define	CPMT_MAX_TICKS		(CPMT_MAX_REFERENCE * CPMT_MAX_PRESCALER)#define	CPMT_MAX_TICKS_WITH_DIV	(CPMT_MAX_REFERENCE * CPMT_MAX_PRESCALER * CPMT_CLOCK_DIV)#define	CPMT_MAX_INTERVAL	(CPMT_MAX_TICKS_WITH_DIV / CLOCKRATE)/* For now: always use max. prescaler value */#define	CPMT_PRESCALER		(CPMT_MAX_PRESCALER)/* CPM Timer Event Register Bits */#define	CPMT_EVENT_CAP		0x0001	/* Capture Event		*/#define	CPMT_EVENT_REF		0x0002	/* Reference Counter Event	*//* CPM Timer Global Config Register */#define	CPMT_GCR_RST		0x0001	/* Reset  Timer			*/#define	CPMT_GCR_STP		0x0002	/* Stop   Timer			*/#define	CPMT_GCR_FRZ		0x0004	/* Freeze Timer			*/#define	CPMT_GCR_GM_CAS		0x0008	/* Gate Mode / Cascade Timers	*/#define	CPMT_GCR_MASK		(CPMT_GCR_RST|CPMT_GCR_STP|CPMT_GCR_FRZ|CPMT_GCR_GM_CAS)/* CPM Timer Mode register */#define	CPMT_MR_GE		0x0001	/* Gate Enable			*/#define	CPMT_MR_ICLK_CASC	0x0000	/* Clock internally cascaded	*/#define	CPMT_MR_ICLK_CLK	0x0002	/* Clock = system clock		*/#define	CPMT_MR_ICLK_CLKDIV	0x0004	/* Clock = system clock / 16	*/#define	CPMT_MR_ICLK_TIN	0x0006	/* Clock = TINx signal		*/#define	CPMT_MR_FRR		0x0008	/* Free Run / Restart		*/#define	CPMT_MR_ORI		0x0010	/* Out. Reference Interrupt En.	*/#define	CPMT_MR_OM		0x0020	/* Output Mode			*/#define	CPMT_MR_CE_DIS		0x0000	/* Capture/Interrupt disabled	*/#define	CPMT_MR_CE_RISE		0x0040	/* Capt./Interr. on rising  TIN	*/#define CPMT_MR_CE_FALL		0x0080	/* Capt./Interr. on falling TIN	*/#define	CPMT_MR_CE_ANY		0x00C0	/* Capt./Interr. on any TIN edge*//* * which CPM timer to use - index starts at 0 (= timer 1) */#define	TID_TIMER_ID	0	/* use CPM timer 1		*/void setPeriod (tid_8xx_cpmtimer_t *hwp, ulong interval);static char *usage = "\n[q, b, e, ?] ";int timer (int argc, char *argv[]){	cpmtimer8xx_t *cpmtimerp;	/* Pointer to the CPM Timer structure   */	tid_8xx_cpmtimer_t hw;	tid_8xx_cpmtimer_t *hwp = &hw;	int c;	int running;	app_startup(argv);	/* Pointer to CPM Timer structure */	cpmtimerp = &((immap_t *) gd->bd->bi_immr_base)->im_cpmtimer;	printf ("TIMERS=0x%x\n", (unsigned) cpmtimerp);	/* Initialize pointers depending on which timer we use */	switch (TID_TIMER_ID) {	case 0:		hwp->tmrp = &(cpmtimerp->cpmt_tmr1);		hwp->trrp = &(cpmtimerp->cpmt_trr1);		hwp->tcrp = &(cpmtimerp->cpmt_tcr1);		hwp->tcnp = &(cpmtimerp->cpmt_tcn1);		hwp->terp = &(cpmtimerp->cpmt_ter1);		hwp->cpm_vec = CPMVEC_TIMER1;		break;	case 1:		hwp->tmrp = &(cpmtimerp->cpmt_tmr2);		hwp->trrp = &(cpmtimerp->cpmt_trr2);		hwp->tcrp = &(cpmtimerp->cpmt_tcr2);		hwp->tcnp = &(cpmtimerp->cpmt_tcn2);		hwp->terp = &(cpmtimerp->cpmt_ter2);		hwp->cpm_vec = CPMVEC_TIMER2;		break;	case 2:		hwp->tmrp = &(cpmtimerp->cpmt_tmr3);		hwp->trrp = &(cpmtimerp->cpmt_trr3);		hwp->tcrp = &(cpmtimerp->cpmt_tcr3);		hwp->tcnp = &(cpmtimerp->cpmt_tcn3);		hwp->terp = &(cpmtimerp->cpmt_ter3);		hwp->cpm_vec = CPMVEC_TIMER3;		break;	case 3:		hwp->tmrp = &(cpmtimerp->cpmt_tmr4);		hwp->trrp = &(cpmtimerp->cpmt_trr4);		hwp->tcrp = &(cpmtimerp->cpmt_tcr4);		hwp->tcnp = &(cpmtimerp->cpmt_tcn4);		hwp->terp = &(cpmtimerp->cpmt_ter4);		hwp->cpm_vec = CPMVEC_TIMER4;		break;	}	hwp->tgcrp = &cpmtimerp->cpmt_tgcr;	printf ("Using timer %d\n"			"tgcr @ 0x%x, tmr @ 0x%x, trr @ 0x%x,"			" tcr @ 0x%x, tcn @ 0x%x, ter @ 0x%x\n",			TID_TIMER_ID + 1,			(unsigned) hwp->tgcrp,			(unsigned) hwp->tmrp,			(unsigned) hwp->trrp,			(unsigned) hwp->tcrp,			(unsigned) hwp->tcnp,			(unsigned) hwp->terp			);	/* reset timer    */	*hwp->tgcrp &= ~(CPMT_GCR_MASK << TID_TIMER_ID);	/* clear all events */	*hwp->terp = (CPMT_EVENT_CAP | CPMT_EVENT_REF);	printf (usage);	running = 0;	while ((c = getc()) != 'q') {	    if (c == 'b') {		setPeriod (hwp, TIMER_PERIOD);	/* Set period and start ticking */		/* Install interrupt handler (enable timer in CIMR) */		install_hdlr (hwp->cpm_vec, timer_handler, hwp);		printf ("Enabling timer\n");		/* enable timer */		*hwp->tgcrp |= (CPMT_GCR_RST << TID_TIMER_ID);		running = 1;#ifdef	DEBUG		printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x,"			" tcr=0x%x, tcn=0x%x, ter=0x%x\n",				*hwp->tgcrp, *hwp->tmrp, *hwp->trrp,				*hwp->tcrp,  *hwp->tcnp, *hwp->terp				);#endif	    } else if (c == 'e') {		printf ("Stopping timer\n");		*hwp->tgcrp &= ~(CPMT_GCR_MASK << TID_TIMER_ID);		running = 0;#ifdef	DEBUG		printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x,"			" tcr=0x%x, tcn=0x%x, ter=0x%x\n",				*hwp->tgcrp, *hwp->tmrp, *hwp->trrp,				*hwp->tcrp,  *hwp->tcnp, *hwp->terp			);#endif		/* Uninstall interrupt handler */		free_hdlr (hwp->cpm_vec);	    } else if (c == '?') {#ifdef	DEBUG		cpic8xx_t *cpm_icp = &((immap_t *) gd->bd->bi_immr_base)->im_cpic;		sysconf8xx_t *siup = &((immap_t *) gd->bd->bi_immr_base)->im_siu_conf;#endif		printf ("\ntgcr=0x%x, tmr=0x%x, trr=0x%x,"			" tcr=0x%x, tcn=0x%x, ter=0x%x\n",				*hwp->tgcrp, *hwp->tmrp, *hwp->trrp,				*hwp->tcrp,  *hwp->tcnp, *hwp->terp			);#ifdef	DEBUG		printf ("SIUMCR=0x%08lx, SYPCR=0x%08lx,"			" SIMASK=0x%08lx, SIPEND=0x%08lx\n",				siup->sc_siumcr,				siup->sc_sypcr,				siup->sc_simask,				siup->sc_sipend			);		printf ("CIMR=0x%08lx, CICR=0x%08lx, CIPR=0x%08lx\n",			cpm_icp->cpic_cimr,			cpm_icp->cpic_cicr,			cpm_icp->cpic_cipr			);#endif	    } else {	    	printf ("\nEnter: q - quit, b - start timer, e - stop timer, ? - get status\n");	    }	    printf (usage);	}	if (running) {		printf ("Stopping timer\n");		*hwp->tgcrp &= ~(CPMT_GCR_MASK << TID_TIMER_ID);		free_hdlr (hwp->cpm_vec);	}	return (0);}/* Set period in microseconds and start. * Truncate to maximum period if more than this is requested - but warn about it. */void setPeriod (tid_8xx_cpmtimer_t *hwp, ulong interval){	unsigned short prescaler;	unsigned long ticks;	printf ("Set interval %ld us\n", interval);	/* Warn if requesting longer period than possible */	if (interval > CPMT_MAX_INTERVAL) {		printf ("Truncate interval %ld to maximum (%d)\n",				interval, CPMT_MAX_INTERVAL);		interval = CPMT_MAX_INTERVAL;	}	/*	 * Check if we want to use clock divider:	 * Since the reference counter can be incremented only in integer steps,	 * we try to keep it as big as possible to allow the resulting period to be	 * as precise as possible.	 */	/* prescaler, enable interrupt, restart after ref count is reached */	prescaler = (ushort) ((CPMT_PRESCALER - 1) << 8) |			CPMT_MR_ORI |			CPMT_MR_FRR;	ticks = ((ulong) CLOCKRATE * interval);	if (ticks > CPMT_MAX_TICKS) {		ticks /= CPMT_CLOCK_DIV;		prescaler |= CPMT_MR_ICLK_CLKDIV;	/* use system clock divided by 16 */	} else {		prescaler |= CPMT_MR_ICLK_CLK;	/* use system clock without divider */	}#ifdef	DEBUG	printf ("clock/%d, prescale factor %d, reference %ld, ticks %ld\n",			(ticks > CPMT_MAX_TICKS) ? CPMT_CLOCK_DIV : 1,			CPMT_PRESCALER,			(ticks / CPMT_PRESCALER),			ticks			);#endif	/* set prescaler register */	*hwp->tmrp = prescaler;	/* clear timer counter */	*hwp->tcnp = 0;	/* set reference register */	*hwp->trrp = (unsigned short) (ticks / CPMT_PRESCALER);#ifdef	DEBUG	printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x,"		" tcr=0x%x, tcn=0x%x, ter=0x%x\n",			*hwp->tgcrp, *hwp->tmrp, *hwp->trrp,			*hwp->tcrp,  *hwp->tcnp, *hwp->terp		);#endif}/* * Handler for CPMVEC_TIMER1 interrupt */staticvoid timer_handler (void *arg){	tid_8xx_cpmtimer_t *hwp = (tid_8xx_cpmtimer_t *)arg;	/* printf ("** TER1=%04x ** ", *hwp->terp); */	/* just for demonstration */	printf (".");	/* clear all possible events: Ref. and Cap. */	*hwp->terp = (CPMT_EVENT_CAP | CPMT_EVENT_REF);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人性色生活片| 亚洲精品福利视频网站| 亚洲高清免费在线| 色综合视频在线观看| 欧美经典一区二区| 久久精品国产99国产精品| 欧美日韩中文字幕一区二区| 中文字幕一区二区三区乱码在线| 国产酒店精品激情| 精品免费国产一区二区三区四区| 午夜精品视频在线观看| 色999日韩国产欧美一区二区| 国产精品乱码人人做人人爱| 国产成人啪免费观看软件| 久久一二三国产| 国内一区二区在线| 亚洲精品一区二区三区在线观看| 久久精品99国产精品日本| 精品国产91乱码一区二区三区 | 亚洲综合一区二区| 精品国产123| 国内精品视频666| 欧美大片国产精品| 亚洲自拍偷拍欧美| 欧美亚洲综合另类| 午夜欧美电影在线观看| 在线不卡免费欧美| 久久精品国产一区二区| 日韩视频在线观看一区二区| 老司机一区二区| 久久久久久久久久久久电影| 国产酒店精品激情| 国产精品短视频| 欧美在线观看视频在线| 性做久久久久久免费观看| 91精品综合久久久久久| 久久国内精品自在自线400部| 日韩女优av电影在线观看| 日韩和欧美的一区| 欧美精品1区2区3区| 久热成人在线视频| 中文字幕国产一区| 91精彩视频在线观看| 亚洲一区在线看| 日韩欧美国产一区在线观看| 国产精品99久久久久久久女警| 国产精品久久久久久久久图文区 | 日韩在线一区二区三区| 日韩色视频在线观看| 国产精品一区二区x88av| 国产精品国产精品国产专区不片| 色94色欧美sute亚洲13| 日韩av一二三| 国产日韩精品一区二区三区| 91猫先生在线| 毛片基地黄久久久久久天堂| 国产精品婷婷午夜在线观看| 欧美日韩精品免费| 国产白丝精品91爽爽久久| 成人免费在线视频观看| 欧美精选午夜久久久乱码6080| 久久成人免费网站| 中文字幕一区二区日韩精品绯色| 欧美日韩一卡二卡三卡| 国产乱码精品一区二区三区av| 亚洲男同1069视频| 欧美刺激午夜性久久久久久久| av在线不卡免费看| 日韩一区欧美二区| 国产精品亲子乱子伦xxxx裸| 欧美日韩精品是欧美日韩精品| 国产精品亚洲成人| 日韩精品国产精品| 亚洲天堂中文字幕| 精品国产乱码久久久久久夜甘婷婷| 91日韩一区二区三区| 精品一区二区av| 亚洲成人资源在线| 国产精品的网站| 精品国产乱码久久久久久1区2区| 91国偷自产一区二区使用方法| 六月丁香婷婷久久| 亚洲精品自拍动漫在线| 精品欧美一区二区三区精品久久| 欧美在线高清视频| aaa国产一区| 国产酒店精品激情| 日本特黄久久久高潮| 亚洲综合免费观看高清在线观看| 国产精品狼人久久影院观看方式| 91精品国产综合久久福利| 日本高清免费不卡视频| 久久久噜噜噜久噜久久综合| 欧美老女人第四色| 欧美色图12p| 在线这里只有精品| 99视频精品免费视频| 国产经典欧美精品| 国产一区二区91| 精品一区二区av| 狠狠色丁香九九婷婷综合五月| 日韩电影在线观看一区| 视频一区视频二区在线观看| 亚洲综合在线视频| 亚洲精品大片www| 亚洲欧美一区二区不卡| 亚洲国产精品精华液ab| 国产欧美一区二区精品性色超碰| 久久久久久电影| 久久久不卡影院| 久久久久久久国产精品影院| 久久久久久久免费视频了| 亚洲精品在线免费播放| 26uuu色噜噜精品一区二区| 精品理论电影在线| 精品999久久久| 久久久.com| 欧美激情一区二区三区蜜桃视频| 国产欧美视频一区二区| 国产日韩三级在线| 国产精品福利影院| 亚洲人成亚洲人成在线观看图片| 一区二区三区四区中文字幕| 亚洲国产中文字幕在线视频综合| 五月开心婷婷久久| 蜜桃久久久久久| 国产乱码精品1区2区3区| 成人精品鲁一区一区二区| 99精品热视频| 欧美主播一区二区三区美女| 色天天综合色天天久久| 欧美精品一二三四| 欧美一区二区三区小说| 久久蜜臀精品av| 亚洲欧洲日产国产综合网| 一区二区三区四区中文字幕| 日韩电影网1区2区| 国产在线精品视频| 99久久精品久久久久久清纯| 欧美综合久久久| 精品少妇一区二区三区免费观看| 国产日韩欧美在线一区| 亚洲一区视频在线| 极品销魂美女一区二区三区| 99视频一区二区| 国产精品第四页| 亚洲一二三区不卡| 国产一区二区三区久久悠悠色av| 91丨porny丨国产入口| 678五月天丁香亚洲综合网| 久久夜色精品国产欧美乱极品| 亚洲天堂免费在线观看视频| 蜜桃av一区二区三区| av在线不卡免费看| 欧美一级一级性生活免费录像| 日本一区二区视频在线观看| 亚洲精品高清视频在线观看| 久久精品国产一区二区三 | 欧美午夜精品久久久久久超碰| 欧美一区二区人人喊爽| 日本一区二区三区国色天香| 午夜a成v人精品| 成人精品免费网站| 欧美成人综合网站| 亚洲一区二区欧美激情| 国产九色精品成人porny| 欧美日韩国产综合久久| 国产精品萝li| 国产在线麻豆精品观看| 欧美三级日韩在线| 中文字幕中文字幕一区| 精品一区二区免费在线观看| 91福利在线免费观看| 国产欧美精品一区二区三区四区| 午夜精品久久久久久久| www.色精品| 婷婷成人综合网| 不卡一区二区三区四区| 久久久久免费观看| 蜜臀a∨国产成人精品| 欧美日韩免费一区二区三区视频| 国产精品女人毛片| 韩国av一区二区三区在线观看| 欧美裸体一区二区三区| 亚洲女与黑人做爰| 国产v日产∨综合v精品视频| 日韩欧美一区二区三区在线| 亚洲一区二区三区激情| aaa欧美色吧激情视频| 欧美国产精品劲爆| 国产在线精品一区二区三区不卡 | 99精品视频一区| 国产欧美一区二区三区在线老狼| 美日韩一区二区| 欧美高清www午色夜在线视频| 一区二区三区四区在线播放| 一本大道av一区二区在线播放| 国产精品久久久久影院色老大 | 国产精品中文欧美| 精品免费日韩av|