Reset Control


Reset Control

1.Reset Introduction

 

Reset机制是BIOS中一个很基本的动作,很多部分的操作往往需要做一下Reset然后才能正常工作。Reset如影随形无处不在,哪个功能不正常就Reset一下呗(玩笑而已:)),Reset在BIOS code中还真是挺多的,翻翻code就会找到像MRC初始化、ME设置、Setup的调整 、三键重启、BIOS Flash之后的Reset等等。虽说Reset是一个很简单的操作,但是我一直搞不清楚Reset有哪些种类,这些Reset分类的区别以及使用时机,所以就打算总结一下。翻翻spec发现其实Reset大致上就分为1. HW Reset 2.Soft Reset 3.Special Cycle Reset 4.Global Reset这么几类,每一个类别下又可能有几种不同的实现方法,后续就分别介绍一下各个Reset的原理以及使用方法。

2.Hard Reset

 

HW Reset通常是将整个Chipset以及连接在Chipset上的所有的bus device都会被Reset,它的信号上的表现就是Chipset将会给出PLTRST# signal(Platform Reset),BIOS可以通过向RST_CTL Register (CF9h)下06或者0E的cmd来产生一个HW Reset,06和0E的区别是0E会产生一个Power Cycle,也就是S3# S4# S5#的信号会依次下达。因为这和S5的power sequence是一样的,所以0E的HW Reset也通常被称之为S5RESET。Hard Reset常见开启或者关掉某些device,或者一些port的时候可能就需要做一次Hard Reset将bus reset,再重新分配和扫描资源。

3.Soft Reset

 

Soft Reset指的是只Reset CPU其他部分不受影响。Soft Reset有很多种方法,比较常见的是透过IO Port 92 or CF9还有就是64port 下FE CMD,虽然操作方法不一样,但是最终都是透过拉CPUINIT# 16个PCI clock实现Reset CPU的目的。Soft Reset通常对应的就是BIOS 的warm boot,比如常见的三键重启,或者windows下的reboot等动作。

4.Global Reset

Global Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.

5.Special Cycle Reset

Special Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:)
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
devm_reset_control_get_optional_exclusive 函数的实现如下: ``` struct reset_control *devm_reset_control_get_optional_exclusive(struct device *dev, const char *id) { struct reset_controller_dev *rcdev; struct reset_control *reset; int ret; rcdev = devm_reset_controller_dev_get(dev); if (IS_ERR(rcdev)) return ERR_CAST(rcdev); reset = reset_control_get_exclusive_rcdev(rcdev, id); if (!reset) return NULL; ret = devm_reset_control_array_add_exclusive(dev, &reset, 1); if (ret < 0) reset_control_put(reset); return reset; } ``` 该函数主要是用于获取设备的重置控制器,并获取指定重置控制器的控制权。如果获取成功,则将该控制器添加到设备的重置控制数组中,并返回该控制器的指针。如果获取失败,则返回 NULL。 函数的参数说明如下: - `dev`:指向设备结构体的指针。 - `id`:代表要获取的重置控制器的标识符字符串。 函数的实现细节如下: 1. 首先,调用 `devm_reset_controller_dev_get()` 函数获取设备的重置控制器。如果获取失败,则直接返回错误码。 2. 接下来,调用 `reset_control_get_exclusive_rcdev()` 函数获取指定重置控制器的控制权。如果获取失败,则返回 NULL。 3. 如果获取成功,则调用 `devm_reset_control_array_add_exclusive()` 函数将该控制器添加到设备的重置控制数组中。如果添加失败,则调用 `reset_control_put()` 函数释放该控制器,并返回 NULL。 4. 最后,返回该控制器的指针。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值