1.前言

2.generate timer

2.1 概述

  1. 提供了一个系统计数器,用来实时测量流逝的时间;
  2. 提供了一个虚拟计数器,用来测量某个虚拟机上流逝的虚拟时间;
  3. 定时器,每隔一段时间会触发事件,支持正向计时和倒计时;
  4. 通用timer实现必须包含一个内存映射的系统组件:提供system counter;

2.2 完整的generic timer组件

  • System counter
  • Generic timer的PE实现

(1)一个物理的counter,它访问system counter的计数值;

(2)一个虚拟的counter,它访问虚拟时间;

(3)一组timers,所有的异常级别都实现了一个timer:

EL1物理timer;

EL2物理timer;

EL3物理timer;

虚拟timer

  • Generic timer系统级的内存映射实现

(1)内存映射的counter模块(必须),控制了system counter;

(2)内存映射的timer模块(必须),控制system timer;

(3)内存映射的timers(可选)

2.3 System Counter

概述

  1. 规格

(1)       Width:至少56bit;

(2)       频率:支持固定频率,典型是1-50MHZ;

(3)       ROLL-OVER:翻转时间不少于40 years;

(4)       Accuracy:未指定,24小时不多于10S;

(5)       Start-up:从0开始。

  1. System counter一旦配置并运行,必须提供统一的 system time view;
  2. System counter电源域必须常开;
  3. 为了支持低功耗,低频率可以一个时钟累加一个比1大的数;

初始化并读取system counter频率

系统启动阶段,初始化system counter的时钟;

System counter的内存映射控制

需要通过内存映射(ioremap??)的方式对system counter进行控制:

  1. 使能和禁用计数器;
  2. 设置计数器的值;
  3. 改变操作模式,更新频率或步长值;
  4. 使能halt-on-debug,可以用来suspend counting.

3. AArch64 generic timer

3.1 Physical counter(包含system connter的count值)

访问physical counter

通过访问CNTPCT_EL0来获取64bit物理count值

虚拟counter

指示虚拟时间

事件流

通过system counter周期性的产生事件

3.2 多个定时器

实现的timers

如果EL3使用AArch64则实现的定时器有:

  1. EL1物理定时器;
  2. Non-secure EL2物理定时器;
  3. Secure EL3物理定时器;

timer的输出

  1. 提供一个输出信号给sysem;
  2. 如果PE连到GIC,会想PE发送PPI信号

Timer regs

  1. 一个64bit compare值寄存器,提供了64bit无符加计数器;
  2. 一个32bit timer寄存器,提供了32bit有符号减计数器;
  3. 一个32bit control寄存器

4. 参考文档

[1] DDI0487A_k_armv8_arm_iss10775.pdf

ARMV8 datasheet学习笔记4:AArch64系统级体系结构之Generic timer的更多相关文章

  1. ARMV8 datasheet学习笔记3:AArch64应用级体系结构

    1.前言 本文主要从应用的角度介绍ARMV8的编程模型和存储模型 2. AArch64应用级编程模型 从应用的角度看到的ARM处理器元素: 可见的元素(寄存器/指令) 说明 可见的寄存器 R0-R30 ...

  2. ARMV8 datasheet学习笔记5:异常模型

    1.前言 2.异常类型描述 见 ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST 一文 3. 异常处理路由对比 AArch32.AArch64架 ...

  3. ARMV8 datasheet学习笔记1:预备知识

    1. 前言 ARMv8的架构继承以往ARMv7与之前处理器技术的基础; 除了支持现有的16/32bit的Thumb2指令外,也向前兼容现有的A32(ARM 32bit)指令集. 基于64bit的AAr ...

  4. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(4)- 其它

    1. 前言 2.可配置的指令使能/禁用控制和trap控制 指令使能/禁用 当指令被禁用,则这条指令就会变成未定义 指令Trap控制 控制某条或某些指令在运行时进入陷阱,进入陷阱的指令会产生trap异常 ...

  5. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST

    1.前言 ARMV8系统级编程模型主要包括异常级别.运行状态.安全状态.同步异常.异步异常.DEBUG 本文主要对系统级编程模型做一个概要介绍 2. 异常级别 2.1 Exception level概 ...

  6. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之存储模型

    1.前言 关于存储系统体系架构,可以概述如下: 存储系统体系结构的形式 VMSA 存储属性   2. 存储系统体系结构 2.1.    地址空间 指令地址空间溢出 指令地址计算((address_of ...

  7. ARMV8 datasheet学习笔记2:概述

    1. 前言 本文主要概括的介绍ARMV8体系结构定义了哪些内容,概括的说: ARM体系结构定义了PE的行为,不会定义具体的实现 ARM体系结构也定义了debug体系结构和trace体系结构 ARM体系 ...

  8. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之VMSA

    1. 前言 2. VMSA概述 2.1 ARMv8 VMSA naming VMSAv8 整个转换机中,地址转换有一个或两个stage VMSAv8-32 由运行AArch32的异常级别来管理 VMS ...

  9. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(3)- 异常

    1.前言 本文介绍异常相关内容,包括异常类型,异常进入,异常返回,异常层次结构,异常的路由等 2.  RESET ARMV8体系结构支持两种类型的RESET Cold reset:Reset PE所有 ...

随机推荐

  1. 自学Linux Shell12.6-嵌套循环for命令

    点击返回 自学Linux命令行与Shell脚本之路 12.6-嵌套循环for命令 嵌套循环就是在一个循环中还有一个循环. 内部循环在外部循环体中,在外部循环的每次执行过程中都会触发内部循环,直到内部循 ...

  2. BZOJ 4754 [JSOI2016]独特的树叶 | 树哈希判同构

    题目链接 这道题是一道判断无根树同构的模板题,判断同构主要的思路就是哈希. 一遇到哈希题,一百个人能有一百零一种哈希方式,这篇题解随便选用了一种--类似杨弋<Hash在信息学竞赛中的一类应用&g ...

  3. 洛谷 P2341 [HAOI2006]受欢迎的牛 解题报告

    P2341 [HAOI2006]受欢迎的牛 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢&q ...

  4. tjoi2018D2T2(luogu4590) 游园会 (状压dp)

    题解劝退系列 设长的那个串是A,短的那个串是B. 那我们在如果已经知道某个A的时候,A[1..i]和B[1..j]的最长公共子序列$f[i][j]=max\{f[i-1][j],f[i][j-1],f ...

  5. centos7 安装mysql的正确姿势

    1. 添加MySQL Yum源 MySQL官网>DOWNLOADS>MySQL Yum Repository找到合适版本的yum源 $wget https://dev.mysql.com/ ...

  6. 最长上升子序列LIS(51nod1134)

    1134 最长递增子序列 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 给出长度为N的数组,找出这个数组的最长递增子序列.(递增子序列是指,子序列的元素是递 ...

  7. C++类间相互引用

    两个类相互包含引用的问题 不管是下文中提到的例子,还是任何情况,使得class A的头文件需要include class B的头文件,class B的也要引用A的头文件,这种状况下,貌似会出现有一个类 ...

  8. 【模板】倍增+Floyd

    题目大意:给定一个 N 个顶点的邻接矩阵.起点顶点.终点顶点,求至少经过 K 条边(边可以重复)从起点到终点的最短路长度,若不能到达,输出 -1. 题解:至少经过 K 条边和恰好经过 K 条边的初始条 ...

  9. MATLAB:图像裁切(imcrop函数)

    对图像进行裁切可用imcrop函数,实现过程如下: close all; %关闭当前所有图形窗口,清空工作空间变量,清除工作空间所有变量 clear all; clc; [A,map]=imread( ...

  10. mac subLime3 JSON 格式化插件安装

    1.首先找到路径:/Users/hou***in/Library/Application' 'Support/Sublime' 'Text' '3/Packages/ 2.git clone http ...