-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpmSwitch_ack.p4
39 lines (34 loc) · 1.58 KB
/
pmSwitch_ack.p4
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#include "xilinx_custom.p4"
#include "common_ack.p4"
// Korakit ///////////
// For this implementation, we use sequence number to index the PM instead of real hashed address to avoid implementing log state checking in the slow softcore.
// Using sequence number allows PMNet to log the request without checking if that address contains non-ACKed log.
// The read caching part will use real hashedAddress to index the PM.
// This should maintain correctness without the performance impact of using a softcore in write (update log) path.
//////////////////////
control PMSwitchAckProcessing(inout headers hdr,
inout PMswitch_metadata_t ctrl) {
action AccessMemory() {
ctrl.PMSwitchOPS = hdr.pmswitchhds.type;
ctrl.hashedAddress = ((hdr.pmswitchhds.seq_no*2048)%0x80000000)+0x80000000;
ctrl.ackCount = hdr.pmswitchhds.ackCount;
}
action bypass() {
ctrl.PMSwitchOPS = PMSWITCH_OPCODE_NOOP;
ctrl.hashedAddress = INVALID_ADDR;
ctrl.ackCount = 0xFF;
}
apply {
// We still need to filter out the packet from the processor.
if (hdr.ipv4.isValid()&& hdr.udp.isValid() && hdr.pmswitchhds.isValid()){
if((hdr.pmswitchhds.type == PMSWITCH_OPCODE_ACK)||(hdr.pmswitchhds.type == PMSWITCH_OPCODE_REPONSE)||(hdr.pmswitchhds.type == PMSWITCH_OPCODE_RECOVER)){
AccessMemory();
}else{
bypass();
}
}else{
bypass();
}
}
}
XilinxSwitch(PMSwitch_ack_Parser(), PMSwitchAckProcessing(), PMSwitch_ack_Deparser()) main;