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

📄 init_qtime_omap2420.c

📁 Centrality Atlas II development software
💻 C
字号:
/* * $QNXLicenseC: * Copyright 2008, QNX Software Systems.  *  * Licensed under the Apache License, Version 2.0 (the "License"). You  * may not reproduce, modify or distribute this software except in  * compliance with the License. You may obtain a copy of the License  * at: http://www.apache.org/licenses/LICENSE-2.0  *  * Unless required by applicable law or agreed to in writing, software  * distributed under the License is distributed on an "AS IS" basis,  * WITHOUT WARRANTIES OF ANY KIND, either express or implied. * * This file may contain contributions from others, either as  * contributors under the License or as licensors under other terms.   * Please review this entire file for other proprietary rights or license  * notices, as well as the QNX Development Suite License Guide at  * http://licensing.qnx.com/license-guide/ for other information. * $ *//* * TI OMAP2420 specific timer support. * GPT1 is used. */#include "startup.h"#include <arm/omap2420.h>extern struct callout_rtn   timer_load_omap2420;extern struct callout_rtn   timer_value_omap2420;extern struct callout_rtn   timer_reload_omap2420;static uintptr_t	timer_base;static const struct callout_slot	timer_callouts[] = {	{ CALLOUT_SLOT(timer_load, _omap2420) },	{ CALLOUT_SLOT(timer_value, _omap2420) },	{ CALLOUT_SLOT(timer_reload, _omap2420) },};static unsignedtimer_start_omap2420(){	out32(timer_base + OMAP2420_GPT_TCLR, 		in32(timer_base + OMAP2420_GPT_TCLR) | 1);	return in32(timer_base + OMAP2420_GPT_TCRR);}static unsignedtimer_diff_omap2420(unsigned start){	unsigned now = in32(timer_base + OMAP2420_GPT_TCRR);	return (now - start);}voidinit_qtime_omap2420(){	struct qtime_entry	*qtime = alloc_qtime();	uint32_t			prcm_base = OMAP2420_PRCM_BASE;	/*	 * Enable GPT1 clock, select sys_clk as timer input clock	 */	out32(prcm_base + OMAP2420_CM_FCLKEN_WKUP,		in32(prcm_base + OMAP2420_CM_FCLKEN_WKUP) | 1);	out32(prcm_base + OMAP2420_CM_ICLKEN_WKUP,		in32(prcm_base + OMAP2420_CM_ICLKEN_WKUP) | 1);	out32(prcm_base + OMAP2420_CM_CLKSEL_WKUP,		in32(prcm_base + OMAP2420_CM_CLKSEL_WKUP) | 1);	while (!(in32(prcm_base + OMAP2420_CM_IDLEST_WKUP) & 1));	/*	 * Map GPT1 registers	 */	timer_base = startup_io_map(OMAP2420_GPT_SIZE, OMAP2420_GPT1_BASE);	/* Reset the timer */	out32(timer_base + OMAP2420_GPT_TIOCP_CFG, 0x02);	/* Wait for reset to complete */	while (!(in32(timer_base + OMAP2420_GPT_TISTAT)) & 1)		;	/* Clear timer count and reload count */	out32(timer_base + OMAP2420_GPT_TLDR, 0);	out32(timer_base + OMAP2420_GPT_TCRR, 0);	/*	 * Setup GPT1	 * Auto-reload enable	 * Prescaler disable	 * Stop timer, timer_load will enable it	 */	out32(timer_base + OMAP2420_GPT_TCLR, (1 << 1));	timer_start = timer_start_omap2420;	timer_diff  = timer_diff_omap2420;	qtime->intr = 37;	/* GPT1 irq */#define	OMAP_CLOCK_FREQ		12000000UL#define	OMAP_CLOCK_RATE		83333333UL#define	OMAP_CLOCK_SCALE	-15	qtime->timer_rate = OMAP_CLOCK_RATE;	qtime->timer_scale = OMAP_CLOCK_SCALE;	qtime->cycles_per_sec = (uint64_t)OMAP_CLOCK_FREQ;	add_callout_array(timer_callouts, sizeof(timer_callouts));}

⌨️ 快捷键说明

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