链路唤醒机制可以让处于非D0状态的Endpoint,通过唤醒来请求Root(软件层)让其返回D0状态。PCIe PM的软件层和PCI PM是兼容的,尽管其硬件实现方式并非完全相同。PCI PM的唤醒机制是通过一个边带信号来实现的,而PCIe PM还支持一种inband的PME消息(Power Management Event Message)来实现这一功能。
需要注意的是,PME消息本质上也是Message,也就是说PME消息也是一种TLP,因此PME消息只能在链路处于L0状态下,才可以正常发送。
注:前面的文章中介绍过,当链路处于非L0状态时,任何TLP和DLLP都不能正常发送。
PME消息包的格式如下图所示:
有几点需要注意的是:
1、PME消息只能采用模糊寻址(Implicitly)方式;
2、PME消息的TC和VC只能是0,即不支持QoS;
3、PME消息是一种Message,因此其是Posted的,即不需要Completion与之对应;
4、PME消息不支持Relaxed Ordering,且总是强制当前器件与Root之间的链路上的所有PCIe设备中的所有其他的事务层包(TLP)在PME消息之前发送。
注:当然,第4点可能会造成链路处于死锁状态,因为如果链路中存在问题的话,可能会导致某些Non-Posted的TLP无法得到返回的Completion,如果一致等待的话,则会造成死锁。解决方式是,Root在等待超过一定的时长后,仍然无法接收到返回的Completion&#