Commit graph

340 commits

Author SHA1 Message Date
Nico Schottelius
94c98e6d20 Mixed up condition for output port... 2019-08-01 12:02:25 +02:00
Nico Schottelius
bcc039cb31 [doc] egress works with table on NetFPGA 2019-07-31 11:30:56 +02:00
Nico Schottelius
1d388630dd re-add the two bool for applying tables 2019-07-29 21:35:40 +02:00
Nico Schottelius
dfa19325a5 Re-add prod nat64 code to netpfga 2019-07-29 21:34:07 +02:00
Nico Schottelius
3ffc8d85a1 Select outgoing port based on ethertype 2019-07-29 16:35:05 +02:00
Nico Schottelius
597d10b33f Add correct parsers 2019-07-29 16:29:12 +02:00
Nico Schottelius
bbe78a44c1 Shift first 2019-07-29 09:40:20 +02:00
Nico Schottelius
ed4db31e2c Cast to 8 bit for port 2019-07-29 09:38:34 +02:00
Nico Schottelius
62e0279b25 try to emit on ANY other port 2019-07-29 09:37:01 +02:00
Nico Schottelius
eed0f3c56e Let's see if 16 == the first port of the other card 2019-07-29 02:00:13 +02:00
Nico Schottelius
81bf3b51b8 rename dummy 2019-07-28 20:15:01 +02:00
Nico Schottelius
53ce47a54e Make it more stupid - forget about tables 2019-07-28 20:08:28 +02:00
Nico Schottelius
c3331bcea7 Only use v4_networks() and set default port to 4 2019-07-28 16:56:30 +02:00
Nico Schottelius
58d7d91358 Re-organising 2019-07-28 16:27:53 +02:00
Nico Schottelius
db5bae89ad ++ various logs 2019-07-28 13:40:49 +02:00
Nico Schottelius
dd6e5b1628 Remove sending to port1 by default 2019-07-28 13:39:24 +02:00
Nico Schottelius
ae255956f2 disable commands.txt again 2019-07-28 12:18:51 +02:00
Nico Schottelius
2b03fffbe9 Reduced version: only use egress tables 2019-07-28 12:16:48 +02:00
Nico Schottelius
6007001838 -1 2019-07-27 21:38:13 +02:00
Nico Schottelius
1ae0294a39 Re-add table entries in commands.txt 2019-07-27 21:35:47 +02:00
Nico Schottelius
1c661f6990 Try to workaround compiler bug with markers 2019-07-25 15:06:56 +02:00
Nico Schottelius
5b306a4cb5 + another ifdef around netpfga / tables 2019-07-25 14:56:01 +02:00
Nico Schottelius
1ddd745731 + } 2019-07-25 14:53:40 +02:00
Nico Schottelius
809466cf61 re-enable other code that might not trigger compiler bug 2019-07-25 14:52:57 +02:00
Nico Schottelius
64a96a1336 disable more code for trying to find compiler bug 2019-07-25 14:42:24 +02:00
Nico Schottelius
f155bb5499 Try to find the reason for yet-another-compiler-bug 2019-07-25 14:41:42 +02:00
Nico Schottelius
7bba816f2c v4 if next to v6 if, not to nat64 2019-07-25 14:40:20 +02:00
Nico Schottelius
f80ecc1d68 [netpfga] remove icmp support
No payload checksumming...
2019-07-25 14:35:37 +02:00
Nico Schottelius
f60b61288f +} 2019-07-25 14:34:41 +02:00
Nico Schottelius
7bbee9ffa2 [netfpga] phase in ipv4 side of the code 2019-07-25 14:31:23 +02:00
Nico Schottelius
6003d240c6 [netpfga] add all broken defines 2019-07-24 23:51:19 +02:00
Nico Schottelius
5478e9fad7 Begin to write defines for netpfga instead of actions 2019-07-24 23:45:40 +02:00
Nico Schottelius
36e374737c Really, really ugly hack to get the thing compile again
REALLY ugly, but

works.
2019-07-24 23:28:05 +02:00
Nico Schottelius
28f985d9ce Commit broken in between state 2019-07-24 23:22:14 +02:00
Nico Schottelius
c3f540795b [netpfga] document broken if statement case 2019-07-24 22:59:13 +02:00
Nico Schottelius
8c94c1ac09 [netpfga] Fix default actions / cannot have arguments 2019-07-24 22:52:23 +02:00
Nico Schottelius
dc7d78252e Merge full IPv6 handling code from BMV2 side 2019-07-24 22:48:21 +02:00
Nico Schottelius
6b176fdc06 table size up, down, up...
Exact matches don't like 63

actions_nat64_generic.p4(173): error: table size too small for match_type(EM): 63 < 64
        size = 63;
               ^^
actions_nat64_generic.p4(173): error: could not not map table size size
        size = 63;
        ^^^^
2019-07-24 22:42:05 +02:00
Nico Schottelius
4afbf053af [netpfga] change table key to exact instead of LPM
Known bug of netpfga not correctly supporting LPM. Current bug
might be triggered by it:
2019-07-24 22:38:55 +02:00
Nico Schottelius
9e6bb893ac [netpfga] remove ARP support
Due to

minip4_solution.p4(35)
parser RealParser(
       ^^^^^^^^^^
error: table match_types are not the same
actions_arp.p4(35): error: could not map table key(s) KeyElement
            hdr.arp.dst_ipv4_addr: lpm;
            ^^^^^^^^^^^^^^^^^^^^^
Makefile:34: recipe for target 'all' failed
make[1]: *** [all] Error 1

caused by

    table v4_arp {
        key = {
            hdr.ethernet.dst_addr: exact;
            hdr.arp.opcode: exact;
            hdr.arp.dst_ipv4_addr: lpm;
        }
2019-07-24 22:27:36 +02:00
Nico Schottelius
5dcb25a8f2 Fix mis-replacement 2019-07-24 13:22:28 +02:00
Nico Schottelius
306d52176f Set table size to 2^n -1 for everything
Motivated by v6.1 error:

make[1]: Entering directory '/home/nico/projects/P4-NetFPGA/contrib-projects/sume-sdnet-switch/projects/minip4/src'
p4c-sdnet -o minip4.sdnet --sdnet_info .sdnet_switch_info.dat minip4_solution.p4
actions_egress.p4(52): warning: Table v6_networks is not used; removing
table v6_networks {
      ^^^^^^^^^^^
actions_egress.p4(69): warning: Table v4_networks is not used; removing
table v4_networks {
      ^^^^^^^^^^^
actions_nat64_generic.p4(174): warning: Table nat46 is not used; removing
    table nat46 {
          ^^^^^
minip4_solution.p4(38): [--Wwarn=uninitialized_out_param] warning: out parameter meta may be uninitialized when RealParser terminates
    out metadata meta,
                 ^^^^
minip4_solution.p4(35)
parser RealParser(
       ^^^^^^^^^^
error: LPM table size should be 2^n - 1
actions_nat64_generic.p4(169): error: could not not map table size size
        size = 64;
        ^^^^
error: table match_types are not the same
actions_arp.p4(35): error: could not map table key(s) KeyElement
            hdr.arp.dst_ipv4_addr: lpm;
            ^^^^^^^^^^^^^^^^^^^^^
error: LPM table size should be 2^n - 1
actions_arp.p4(55): error: could not not map table size size
        size = 64;
        ^^^^
Makefile:34: recipe for target 'all' failed
make[1]: *** [all] Error 1
make[1]: Leaving directory '/home/nico/projects/P4-NetFPGA/contrib-projects/sume-sdnet-switch/projects/minip4/src'
Makefile:31: recipe for target 'frontend' failed
make: *** [frontend] Error 2
nico@nsg-System:~/master-thesis/netpfga/log$
2019-07-24 13:20:35 +02:00
Nico Schottelius
91ec194b78 +arp in netpfga 2019-07-24 13:17:56 +02:00
Nico Schottelius
ee0d500355 [netpfga] phase in first applied tables/nat64 code 2019-07-24 13:08:02 +02:00
Nico Schottelius
49e1f511b0 Integrate existing headers 2019-07-24 12:15:26 +02:00
Nico Schottelius
1177008608 logfiles, cleanup 2019-07-24 12:15:11 +02:00
Nico Schottelius
ad8988bb41 Try to add real headers 2019-07-24 12:01:47 +02:00
Nico Schottelius
13ce721862 Include settings into egress for table sizes 2019-07-24 11:57:57 +02:00
Nico Schottelius
6f961db35f -typo 2019-07-24 11:57:16 +02:00
Nico Schottelius
62d5816d9d Merge controller/egress
As they are interdependent
2019-07-24 11:56:27 +02:00