AMBA-CHI协议详解(六)

news2025/1/11 2:23:06

在这里插入图片描述
AMBA-CHI协议详解(一)
AMBA-CHI协议详解(二)
AMBA-CHI协议详解(三)
AMBA-CHI协议详解(四)
AMBA-CHI协议详解(五)
AMBA-CHI协议详解(六)
AMBA-CHI协议详解(七)

文章目录

    • 2.5 Transaction identifier field flows
      • 2.5.1 Read transactions
        • 2.5.1.1 ID value transfer with DMT
        • 2.5.1.2 ID value transfer with DMT and separate Comp and Data
        • 2.5.1.3 ID value transfer with DCT
        • 2.5.1.3 ID value transfer without Direct Data Transfer
      • 2.5.2 Dataless transactions
      • 2.5.2 .1 ID value transfer in a CleanSharedPersistSep transaction
      • 2.5.3 Write transactions
        • 2.5.3.1 CopyBack transaction
        • 2.5.3.2 WriteNoSnp transaction
        • 2.5.3.3 WriteUnique transaction
        • 2.5.3.4 StashOnce or StashOnceSep transaction
      • 2.5.4 DVMOp transaction
      • 2.5.5 Transaction requests with Retry
      • 2.5.6 Protocol Credit Return transaction


2.5 Transaction identifier field flows

  本节展示不同事务类型的事务ID字段流

● 每个包中包含的字段如下:

Request packet:
TgtID, SrcID, TxnID, StashNID, StashLPID, ReturnNID, ReturnTxnID, PGroupID, StashGroupID, and TagGroupID

Response packet:
TgtID, SrcID, TxnID, DBID, PGroupID, StashGroupID, and TagGroupID.

Data packet:
TgtID, SrcID, TxnID, HomeNID, and DBID

Snoop packet:
SrcNID, TxnID, FwdNID, FwdTxnID, and StashLPID.

● 下图中所有具有相同颜色的字段都具有相同的值。

● 弯曲的回圈箭头显示了Requester和Completer如何使用早期数据包中的字段为后续数据包的字段。

● 包含星号[*]的方框表示字段首次生成的时间,也就是说,它表示确定该字段原始值的Agent。

● 括号内的字段表示该值实际上是固定值。通常情况下,发送数据包时的SrcID字段和到达目的地时的TgtID字段就是这种情况。

● 划掉的字段表示该字段无效。

● 允许将原始事务的TgtID通过互连重新映射到一个新值。(这是一个包含字母R的方框)

——Note—数字硬鉴———————————
在每个发送的数据包中,ID字段属于以下类别之一:
● 新值。星号表示生成新值。
● 由较早的数据包生成。一个回圈箭头表示源。
● 固定值。该值用括号括起来。
● 不是有效的。域段被划掉了。
————————————————————
在下面的示例中,为了清晰起见,有时会省略与示例无关的任何事务ID。

2.5.1 Read transactions

  本节展示了带直接数据传输和不带直接数据传输的读事务中的ID字段流。

2.5.1.1 ID value transfer with DMT

  下图显示了如何派生DMT事务消息中的目标和事务ID值。例如,来自互联的ReadNoSnp请求中的SrcID值是由互联分配的。而在数据响应中用作TgtID的ReturnNID被设置为接收到的读取请求的SrcID值(ReturnNID在响应中会被设置为TgtID)。
在这里插入图片描述
流程中需要完成的步骤如下:

1、Requester节点通过发送请求包启动事务
  请求的ID字段生成如下:

  ● TgtID由请求的目的地决定(TgtID字段可以通过互连重新映射为不同的值。因为请求->互联的tgtid指向互联,互联->内存控制器的tgtid应该指向内存控制器)
  ● SrcID是Requester的固定值。(Requester本身的节点ID,响应需要根据该ID找回来)
  ● RN为一笔事务生成一个唯一的TxnID字段。

2、Home节点接收Requester节点的请求,并向Subordinate节点生成请求。

  请求的ID字段生成如下:

  ● TgtID被设置为SN节点的ID值。(因为已经路由Home节点,指向Home节点的Tgtid要转换为指向SN节点)
  ● SrcID是Home的固定值。(Home本身的节点ID,响应需要根据该ID找回来)
  ● TxnID是由Home生成的唯一值
  ● 将ReturnNID设置为与原始请求的SrcID相同的值。(因为若有需求,SN会根据该ID将响应跨过HN直接返回至RN)
  ● ReturnTxnID被设置为与原始请求的TxnID相同的值。(因为若有需求,SN会根据ReturnNID响应跨过HN直接返回至RN,根据ReturnTxnID找到到原始的请求)

3、如果对SN的请求需要ReadReceipt,则下级需要提供read receipt(该响应的作用是保序,后续会提到)

  ReadReceipt响应的ID字段如下所示:

  ● TgtID被设置为与请求的SrcID相同的值。(谁给我发的请求,我就要给谁回响应)
  ● SrcID是SN的固定值。这也与接收到的TgtID匹配。(SN的节点ID,接收请求是作为Tgtid,发送响应时作为Srcid)
  ● 将TxnID设置为与请求的TxnID相同的值。(响应返回到HN,HN要根据TxnID找到原始请求)
  ● DBID字段无效。

4、SN提供读取数据。
   读取数据响应的ID字段生成如下:

   ● TgtID被设置为与请求的ReturnNID相同的值。(该事务是DMT,读取的数据要跨过HN直接给到RN,所以TgtID直接指向RN,ReturnNID就是在原始请求节点RN发送请求时放置的RN的节点ID)
   ● SrcID是SN的固定值。这也与接收到的TgtID匹配。(SN的节点ID,接收请求是作为Tgtid,发送响应时作为Srcid)
  ● TxnID被设置为与请求的ReturnTxnID相同的值。(RN需要根据该ID去找到原始的请求)
  ● HomeNID设置为与请求的SrcID相同的值。(HomeNID指向Home节点,因为RN的CompAck响应需要返回至HN,而不是SN)
  ● DBID被设置为与请求的TxnID相同的值。(因为该DBID会作为CompAck的txnid,Home要根据txnid在Home找到原始请求)

5、Requester接收读取的数据并发送一个完成确认CompAck响应。(该响应的作用先理解为要去为Home释放一些东西)

   ● 生成的CompAck ID字段如下:
  ● TgtID设置为与读数据的HomeNID相同的值。(HomeNID的作用就是作为针对读数据返回CompAck的TgtID)
  ● SrcID是RN的固定值。这也与接收到响应的TgtID匹配。(RN的节点ID)
  ● TxnID设置为与读数据的DBID相同的值。(因为该DBID会作为CompAck的txnid,Home要根据txnid在Home找到原始请求)
  ● DBID字段无效。

并非所有请求都需要从Requester到Home的CompAck响应

2.5.1.2 ID value transfer with DMT and separate Comp and Data

下图说明如何在使用单独的Comp和Data的DMT事务消息中派生ID字段值。
在这里插入图片描述
1、Requester节点通过发送请求包启动事务

  生成请求的标识字段如下:
  ● TgtID由请求的目的地决定。(TgtID字段可以通过互连重新映射为不同的值。)
  ● SrcID是Requester的固定值。
  ● Requester为一笔事务生成一个唯一的TxnID字段。

2、Home节点接收Requester节点的请求,并向Subordinate节点生成请求。
  生成请求的标识字段如下:

  ● TgtID被设置为SN的节点ID。
  ● SrcID是Home的固定值。
  ● TxnID是由Home生成的唯一值。
  ● 将ReturnNID设置为与原始请求的SrcID相同的值。
  ● ReturnTxnID被设置为与原始请求的TxnID相同的值。

3、Home节点提供单独的Read响应
  读取响应的标识字段生成如下:
  ● TgtID被设置为与请求的SrcID相同的值
  ● SrcID是Home的固定值。
  ● TxnID被设置为与原始请求的TxnID相同的值。
  ● DBID值是由Home生成的唯一值,与向SN请求中的TxnID值相同

4、Requester接收Read响应并发送一个完成确认(CompAck)响应。
  ● TgtID被设置为与读响应的SrcID相同的值。
  ● SrcID是请求者的固定值。
  ● TxnID被设置为Home生成的唯一DBID值。
  ● DBID值无效。

5、对SN的请求需要一个ReadReceipt。下级提供ReadReceipt
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是SN的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。

6、SN提供单独的读取数据。
  ● TgtID被设置为与请求的ReturnNID相同的值。
  ● SrcID是从属的固定值。这也与接收到的TgtID匹配。
  ● TxnID被设置为与请求的ReturnTxnID相同的值。
  ● HomeNID设置为与请求的SrcID相同的值。
  ● DBID被设置为与请求的TxnID相同的值。

2.5.1.3 ID value transfer with DCT

在本例中,数据被转发到请求节点,并将带有或不带有数据的Snoop响应发送到HN-F。
在这里插入图片描述
1、Requester节点通过发送请求包启动事务
  ● TgtID由请求的目的地决定。
  ● SrcID是Requester的固定值。
  ● Requester为一笔事务生成一个唯一的TxnID字段。

2、互连中接收方Home节点向RN-F节点发出Forwarding snoop。
  ● SrcID是Home的固定值
  ● TxnID是由Home生成的唯一值。
  ● FwdNID设置为与原始请求的SrcID相同的值。(因为数据会根据此ID从一个RNF直接回到请求的RNF)
  ● 将FwdTxnID设置为与原始请求的TxnID相同的值。

3、RN-F提供读取数据。
  ● TgtID设置为与Snoop的FwdNID相同的值。
  ● SrcID是RN-F的固定值。
  ● TxnID设置为与Snoop的FwdTxnID相同的值。
  ● HomeNID设置为与Snoop的SrcID相同的值。
  ● DBID设置为与Snoop的TxnID相同的值。

4、RN-F还提供对Home的响应,无论是否读取数据(得把Snoop请求的响应回去呢)
  ● TgtID设置为与Snoop的SrcID相同的值。
  ● SrcID是RN-F的固定值。
  ● TxnID设置为与snoop的TxnID相同的值。
  ● DBID字段无效。

5、Requester接收读取的数据并发送一个完成确认CompAck响应。
  ● TgtID设置为与读数据的HomeNID相同的值。
  ● SrcID是Requester的固定值。这也与接收到的TgtID匹配。
  ● TxnID设置为与读数据的DBID相同的值。
  ● DBID字段无效。

2.5.1.3 ID value transfer without Direct Data Transfer

本节给出了一个没有DMT或DCT的Read ID字段流示例,并描述了在Read事务中使用TxnID和DBID字段。

本例中的Requester和Completer 分别是请求节点和HN-F

ID字段流包括来自Completer的可选ReadReceipt响应和来自Requester的可选CompAck响应。

对于包含CompAck响应的Read事务,Completer使用DBID将CompAck与原始事务关联起来。

不包含CompAck响应的Read事务不需要在数据响应中包含有效的DBID字段。

在这里插入图片描述
1、请求方通过发送请求包启动事务。
  ● TgtID由请求的目的地决定。
  ● SrcID是请求者的固定值。
  ● Requester为一笔事务生成一个唯一的TxnID字段。

2、如果事务包含ReadReceipt,则Completer接收请求包并提供ReadReceipt响应(如果有保序要求,会有该响应)
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Completer的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● DBID字段无效。

3、Completer接收请求包并提供读取数据。
  ● TgtID被设置为与请求的SrcID相同的值
  ● SrcID是完成器的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● HomeNID是Completer的固定值。(用于CompAck响应)
  ● 如果断言请求中的ExpCompAck,则Completer生成唯一的DBID值。

4、Requester接收读取的数据并发送完成确认CompAck和响应
  ● TgtID设置为与读数据的HomeNID相同的值。
  ● SrcID是请求者的固定值。这也与接收到的TgtID匹配。
  ● TxnID设置为与读数据的DBID相同的值。
  ● DBID字段无效。

2.5.2 Dataless transactions

  对于Dataless事务,除了CleanSharedPersistSep和StashOnceSep之外,ID字段的使用类似于Without Direct Data传输的ID值传输。唯一的区别是,从Completer到Requester的响应在CRSP通道上作为单个数据包发送,而不是在RDAT通道上作为多个数据包发送。
  对于StashOnceSep事务,StashGroupID值在请求节点发送到互连的请求中,该值在StashDone和CompStashDone响应中返回。StashDone响应中的TxnID值不适用,必须设置为零。

下面描述了一个CleanSharedPersistSep事务中的ID值传输。

2.5.2 .1 ID value transfer in a CleanSharedPersistSep transaction

下图展示了如何在使用单独的Comp和Persist响应的CleanSharedPersistSep事务消息中生成ID符字段值。PCMOSep represents CleanSharedPersistSep。
在这里插入图片描述
1、请求方通过发送请求包启动事务。Request的ID字段生成如下:
  ● TgtID由请求的目的地决定。
  ● SrcID是Requester的固定值。
  ● Requester为每笔事务生成一个唯一的TxnID值。(Requester可以在接收到Comp响应后重用TxnID值)
  ● Requester生成一个新的PGroupID值,或者重用当前正在使用的PGroupID值。

2、Home节点向SN节点生成请求。
  ● TgtID被设置为SN所需的值。
  ● SrcID是Home的固定值。
  ● TxnID是由Home生成的唯一值。(在收到Comp响应后,Home可以重用TxnID值。)
  ● 将ReturnNID设置为与原始请求的SrcID相同的值。
  ● ReturnTxnID不适用,必须设置为零。
  ● 将PGroupID设置为与原始请求的PGroupID相同的值。

3、Home节点向请求方发送一个Comp响应
  ● TgtID被设置为与原始请求的SrcID相同的值。
  ● SrcID是Home的固定值。
  ● TxnID被设置为与原始请求的TxnID相同的值。

4、Home节点可以选择性地向请求方发送Persist响应。
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Home节点的固定值。
  ● TxnID不适用,必须设置为0。
  ● 将PGroupID设置为与请求的PGroupID相同的值。

接收方Home节点可以选择向请求方发送一个组合的CompPersist响应,而不是单独的Comp和Persist响应。

CompPersist响应中的ID字段生成如下:
  ● TgtID被设置为与原始请求的SrcID相同的值
  ● SrcID是Home的固定值。
  ● TxnID被设置为与原始请求的TxnID相同的值。
  ● 将PGroupID设置为与原始请求的PGroupID相同的值。

5、SN节点生成Home节点的Comp响应
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是SN的固定值。
  ● 将TxnID设置为与请求的TxnID相同的值。

6、SN节点生成对RN或HN的Persist响应。
  ● TgtID被设置为与请求的ReturnNID相同的值。
  ● SrcID是SN的固定值。
  ● TxnID不适用,必须设置为0。
  ● 将PGroupID设置为与请求的PGroupID相同的值。

7、如果请求的ReturnNID和SrcID是相同的值,SN节点可以选择向Home节点发送一个组合的CompPersist响应,而不是单独的Comp和Persist响应
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是SN的固定值。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● 将PGroupID设置为与请求的PGroupID相同的值。

2.5.3 Write transactions

本节描述了写事务中TxnID和DBID字段的使用:

2.5.3.1 CopyBack transaction

本节描述CopyBack 事务中ID字段的使用。
在这里插入图片描述
1、Requester通过发送请求包启动事务。生成请求的ID字段如下:
  ● TgtID由请求的目的地决定。
  ● SrcID是RN的固定值。
  ● Requester为每笔事务生成一个唯一的TxnID值。

2、Completer接收请求包并生成一个CompDBIDResp响应。响应的ID字段生成如下:
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Completer的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● Completer生成一个唯一的DBID值。

3、Requester接收CompDBIDResp响应并发送写数据。写数据的ID字段生成如下:
  ● TgtID被设置为与CompDBIDResp响应的SrcID相同的值。如果该值是由互连重新映射的,则该值可能与请求的原始TgtID不同。
  ● Requester是请求者的固定值。
  ● TxnID被设置为与CompDBIDResp响应中提供的DBID值相同的值。
  ● 写数据中的DBID字段没有被使用。
  ● 所有写数据包的TgtID、SrcID和TxnID字段必须相同。

4、Completer接收写数据并使用TxnID字段,该字段现在包含了Completer生成的DBID值。这有助于确定要关联哪个事务的写数据。

在接收到所有写数据包后,Completer可以在另一个事务中重用相同的DBID值。

2.5.3.2 WriteNoSnp transaction

本节描述WriteNoSnp事务中标ID字段的使用

显示单独Comp和DBIDResp的ID值传输。Completer可以将Comp和DBIDResp组合成单个CompDBIDResp响应。Requester可以一些情况下将NCBWrData与CompAck结合起来。
在这里插入图片描述

ID字段的使用与合并响应的事务相同,附加要求如下:
  ● 用于单独的DBIDResp和Comp响应的ID字段必须相同。
  ● 只有当接收到DBIDResp和Comp响应时,请求者才能重用TxnID值。

1、Requester通过发送请求包启动事务。生成请求的标识字段如下:
  ● TgtID由请求的目的地决定。
  ● SrcID是Requester的固定值。
  ● Requester生成一个唯一的TxnID字段。

2、Completer接收请求包并生成一个DBIDResp响应。响应的ID字段生成如下:
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Completer的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● Completer生成一个唯一的DBID值。

3、Requester接收到DBIDResp响应并发送写数据。写数据的ID字段生成如下:
  ● TgtID被设置为与DBIDResp响应的SrcID相同的值。如果该值是由互连重新映射的,则该值可能与请求的原始TgtID不同。
  ● SrcID是Requester的固定值。
  ● TxnID被设置为与DBIDResp响应中提供的DBID值相同的值。
  ● 写数据中的DBID字段没有被使用。
  ● 所有写数据包的TgtID、SrcID和TxnID字段必须相同。

4、Completer接收写数据并使用TxnID字段(即Completer生成的DBID值)来确定写数据与哪个事务相关联。

5、Completer在完成事务后生成一个Comp响应。
  Comp响应的ID字段必须与DBIDResp响应相同,生成方式如下:
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Completer的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● Completer使用与在DBIDResp响应中使用的相同的DBID值。

6、如果事务需要,Requester在接收到DBIDResp或Comp后发送一个CompAck消息。
  ● TgtID被设置为与DBIDResp或Comp响应的SrcID相同的值。
  ● SrcID是请求者的固定值。这也与接收到的TgtID匹配。
  ● TxnID设置为与DBIDResp或Comp响应的DBID相同的值。
  ● DBID字段无效。

在接收到Comp和DBIDResp响应之后,Requester可以在另一个事务中重用相同的TxnID值。

在接收到所有写数据包后,Completer可以在另一个事务中重用相同的DBID值。

在单独的DBIDResp和Comp响应之间没有order要求。当两个消息来自同一来源时,需要使用相同的id值。

2.5.3.3 WriteUnique transaction

  在某些情况下,WriteUnique事务还可以包括从Requester到Completer的CompAck响应。在这种情况下,使用ID字段的附加规则是:

● Requester给Completer的CompAck响应的TgtID、SrcID和TxnID标识字段必须与写数据使用的字段相同,即:
  —TgtID被设置为与CompDBIDResp响应的SrcID相同的值。如果给出了单独的Comp和DBIDResp响应,则将TgtID设置为与Comp或DBIDResp响应的SrcID相同的值,因为两者中的SrcID值必须相同。但是,如果该值已被互连重新映射,则该值可能与请求的原始TgtID不同。

  —SrcID是Requester的固定值。

  —TxnID被设置为与CompDBIDResp响应中提供的DBID值相同的值。如果给出了单独的Comp和DBIDResp响应,则将TxnID设置为与Comp或DBIDResp响应的DBID相同的值,因为两者中的DBID值必须相同。

  —没有使用WriteData和CompAck中的DBID字段

  —如果发送WriteData和CompAck联合响应,则TgtID值与Comp、DBIDResp或CompDBIDResp中的SrcID值相同,TxnID值与Comp、DBIDResp或CompDBIDResp中的DBID值相同。

● 在为另一个事务重用相同的DBID值之前,Completer必须接收所有写数据项和CompAck响应。

在这里插入图片描述

在这里插入图片描述

2.5.3.4 StashOnce or StashOnceSep transaction

本节描述了在蕴含DataPull的StashOnce或StashOnceSep事务中ID字段的使用:
在这里插入图片描述
1、Requester通过发送一个Stash请求包来启动事务。
  ● TgtID由请求的目的地决定。
  ● SrcID是Requester的固定值。
  ● 请Requester为请求生成一个唯一的TxnID字段。
  ● Requester包含StashNID字段,以指示要向哪个RN-F发送Stash(划重点)。
  ● Requester包含StashLPID字段,以指示RN-F中的逻辑处理器。

2、Home节点接收Stash请求包并向请求节点发送Comp响应
  ● TgtID被设置为与请求的SrcID相同的值。
  ● 将TxnID设置为与请求的TxnID相同的值。

3、对于StashOnceSep请求,互连中的Home节点向请求节点发送StashDone响应。
  ● TgtID被设置为与请求的SrcID相同的值。
  ● TxnID无效
  ● 将StashGroupID设置为与请求的StashGroupID相同的值。

另外,对于StashOnceSep请求,互连中的Home节点可以发送组合的CompStashDone响应,而不是单独的Comp和StashDone响应到请求节点。
  ● TgtID被设置为与请求的SrcID相同的值。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● 将StashGroupID设置为与请求的StashGroupID相同的值。

4、Home节点使用Stash生成对适当的RN-F的Snoop。
  ● SrcID是Home的固定值。
  ● TxnID是由Home生成的唯一值
  ● 将StashLPID设置为与原始请求的StashLPID相同的值。
—Note—————
Snoop请求不包括tgtid域段
————————

5、被Snoop的RN-F产生一个Snoop响应。在本例中,它包括一个Data Pull指示。
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是RN-F的固定值。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● DBID字段是由RN-F生成的唯一值。

6、Home提供读取数据。
  ● TgtID被设置为与Snoop响应的SrcID相同的值。
  ● SrcID是Home的固定值。(在本例中,读取数据由Home提供。)
  ● TxnID被设置为与Snoop响应的DBID相同的值。
  ● DBID字段是Home生成的唯一值。
  ● HomeNID是Home的固定值。

7、RN-F接收读取的数据并发送完成确认CompAck响应。
  ● TgtID设置为与读数据的HomeNID相同的值。
  ● SrcID是RN-F的固定值。这也与接收到的TgtID匹配。
  ● TxnID设置为与读数据的DBID相同的值。
  ● DBID字段无效。

2.5.4 DVMOp transaction

对DVMOp事务的TgtID、SrcID、TxnID和DBID标识符字段的使用与writensnp事务的相同。

2.5.5 Transaction requests with Retry

对于接收到RetryAck响应的事务,有关于如何使用ID字段的特定规则。
在这里插入图片描述
1、Requester通过发送请求包启动事务。生成请求的ID字段如下:
  ● TgtID由请求的目的地决定
  ● SrcID是请求者的固定值。
  ● Requester生成唯一的TxnID字段。

2、Completer接收请求包并确定它将发送一个RetryAck响应。RetryAck响应的ID字段生成如下:
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Completer的固定值。这也与接收到的TgtID匹配。
  ● 将TxnID设置为与请求的TxnID相同的值。
  ● DBID字段无效。
  ● Completer使用一个PCrdType值,该值指示Retry事务所需的信用类型。

3、当Completer能够接受给定PCrdType的Retry事务时,它使用PCrdGrant响应向Requester发送一个信用。生成PCrdGrant响应的标识符字段如下:
  ● TgtID被设置为与请求的SrcID相同的值。
  ● SrcID是Completer的固定值。这也与请求的TgtID相匹配。
  ● TxnID字段没有被使用,必须设置为零。
  ● DBID字段没有被使用,必须设置为零。
  ● PCrdType值被设置为再次发出原始事务所需的类型。

4、Requester接收信用授予,并通过发送请求包重新发送原始事务。生成请求的标识字段如下:
  ● TgtID被设置为与RetryAck响应的SrcID相同的值(也与PCrdGrant响应的SrcID相同),或者与原始请求中使用的值相同。
  ● SrcID是请求者的固定值
  ● Requester生成一个唯一的TxnID字段。这是允许的,但不是必需的,与接收到RetryAck响应的原始请求不同。
  ● 将PCrdType值设置为对原始请求的RetryAck响应中的PCrdType值,该值与PCrdGrant响应的PCrdType值相同。

2.5.6 Protocol Credit Return transaction

  P-Credit返回事务使用PCrdReturn请求返回已授予但不再需要的信用。TgtID、SrcID和TxnID要求如下:

● Requester通过发送PCrdReturn请求包发送协议信用返回事务。生成请求的标识字段如下:
  —TgtID必须与获得的credit的SrcID匹配。
  —SrcID是请求者的固定值。
  —TxnID字段没有被使用,必须设置为零。

PCrdType必须与再次发出原始事务所需的原始PCrdGrant中的PCrdType值匹配。

没有响应或使用与协议信用返回事务相关的DBID字段。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2051603.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaSocket编程+JDBC实战技术

一、JavaSocket编程 1.1HTTP协议 后端原理 2. 特点 同步:就是两个任务执行的过程中,其中一个任务要等另一个任务完成某各阶段性工作才能继续执行,如厨师A炒番茄,将葱花放入锅中,然后需要放入番茄,但是厨…

【自动驾驶】控制算法(二)三大坐标系与车辆运动学模型

写在前面: 🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝 个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。 🔍 本文系 清流君 原创之作&…

Dubbo服务自动Web化之路

本文字数:6047字 预计阅读时间:40分钟 01 故障出现 事情起源于一次故障,2023年12月14日14点26分,大量Dubbo服务报出异常,无法链接zookeeper集群: Session 0x0 for server dubboZk.xxx.com/10.x.x.x:2181, C…

【高校科研前沿】南方科技大学冯炼教授等人在遥感顶刊RSE发文:全球人类改造的基塘系统制图

1.文章简介 论文名称:Global mapping of human-transformed dike-pond systems(全球人类改造的基塘系统制图) 第一作者及单位:Yang Xu(南方科技大学环境学院) 第一通讯作者及单位:冯炼&#x…

机器学习:线性回归算法(一元和多元回归代码)

1、线性回归 1、数据准备: 描述如何获取和准备数据。 2、图像预处理: 包括图像读取。 3、将数据划分为训练集和测试集。 4、计算数据的相关系数矩阵。 5、模型训练: 详细说明如何使用线性回归算法训练模型&…

京东2025届秋招 算法开发工程师 第2批笔试

目录 1. 第一题2. 第二题3. 第三题 ⏰ 时间:2024/08/17 🔄 输入输出:ACM格式 ⏳ 时长:2h 本试卷还有选择题部分,但这部分比较简单就不再展示。 1. 第一题 村子里有一些桩子,从左到右高度依次为 1 , 1 2…

达梦数据库的系统视图v$reserved_words

达梦数据库的系统视图v$reserved_words 达梦数据库(DM Database)提供了一系列系统视图以帮助管理员和开发人员了解数据库的状态和配置。V$RESERVED_WORDS 是其中一个系统视图,它显示了数据库系统中已保留的关键字。这些关键字在SQL语句中具有…

SpringBoot自动配置--原理探究

什么是自动配置? SpringBoot自动配置是指在SpringBoot应用启动时,可以把一些配置类自动注入到Spring的IOC容器中,项目运行时可以直接使用这些配置类的属性。简单来说就是用注解来对一些常规的配置做默认配置,简化xml配置内容&…

【三维目标检测】H3DNet(三)

【版权声明】本文为博主原创文章,未经博主允许严禁转载,我们会定期进行侵权检索。 参考书籍:《人工智能点云处理及深度学习算法》 H3DNet数据和源码配置调试过程以及主干网络介绍请参考上一篇博文:【三维目标检测】H3DNet&am…

[Java]面向对象-内部类

类的五大成员:属性、方法、构造方法、代码块、内部类 内部类 在一个类里边再定义一个类。可以在外部其他类中创建内部类对象并调用它的方法 public class Outer {//外部类public class inner{//内部类} } 内部类使用时机: 内部类表示的事物是外部类…

打造高可用集群的基石:深度解析Keepalived实践与优化

高可用集群 集群类型 集群类型主要分为负载均衡集群(LB)、高可用集群(HA)和高性能计算集群(HPC)三大类。每种集群类型都有其特定的应用场景和优势。 1. 负载均衡集群(LB) 负载均衡集…

drawio的问题

drawio的问题 先给出drawio的链接https://app.diagrams.net/ 我在用overleaf写论文的过程中,发现了一个问题,就是使用drawio画好图之后,只能保存以下几个选项: 但是不管是什么类型,在overleaf上面图片都不显示。如果…

SpringBoot如何做自动配置

目录 一、什么是springboot的自动配置? 二、Enable注解 三、springboot自动配置流程 ComponentScan SpringBootConfiguration EnableAutoConfiguration注解 condition的几个注解: 四、自定义启动类 需求: 参考: 实现步…

使用JQUERY请求数据出现500报错

我在写项目的时候遇到了一个问题,就是在存商品id的时候我将它使用了JSON.stringify的格式转换了!!!于是便爆出了500这个错误!!! 我将JSON.stringify的格式去除之后,它就正常显示了&a…

【数学建模】趣味数模问题——四人追逐问题

问题描述: 如图所示,在正方形ABCD的四个顶点各有一个人。在初始时刻 t0 时,四人同时出发,以匀速 v 沿顺时针方向朝下一个人移动。如果他们始终对准下一个人为目标行进,最终结果会如何?需要作出各自的运动轨…

路径规划 | 灰狼算法+B样条曲线优化无人机三维路径规划(Matlab)

目录 效果一览基本介绍程序设计参考文献 效果一览 基本介绍 灰狼算法B样条曲线优化无人机三维路径规划(Matlab) 群智能路径规划算法。三维灰狼算法(GWO)加B样条曲线优化的matlab代码。无人机(UAV)路径规划…

QT:安装软件

QT 介绍 QT是一个跨平台的C应用程序开发框架,具有广泛的应用领域和强大的功能。 定义:QT是一个跨平台的C图形用户界面应用程序框架,为开发者提供了建立艺术级图形界面所需的所有功能。 特点:QT具有短平快的优秀特质,即…

csrf漏洞(二)

本文仅作为学习参考使用,本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 前言: 本文依靠phpstudy以及dvwa靶场进行操作,具体搭建流程参考:xss漏洞(二,xss靶场搭建以及简单利用) 前篇…

Godot关于3d射线投射的一些问题

首先你得把刚体模式激活如图否则将是空对象 为了区分其他坐标颜色园哥把射线设置成紫色以示区别 另外运行模式中貌似射线不可见只在调试模式中可见。最后查看调试器 成功碰撞一个名为主角的物体,也许都命中了但是方法只返回第一个命中的物体,吐槽一下&a…

场外个股期权如何发出行权指令?

场外期权行权指令也就是平仓指令的意思,一般场外个股期权交易有三种方式开仓和行权平仓指令,分别是市价,限价和半小时询价,跟普通股票的买卖和交易方式类似,唯一区别是手动发出场外个股期权的行权指令,下文…