summaryrefslogtreecommitdiffstats
path: root/test
AgeCommit message (Collapse)AuthorFilesLines
2017-09-07make test: disable L2BD Multi-instance test 5Florin Coras1-1/+2
Change-Id: Iba44aec60a74ada5add41ecf00b25dc44f3ad3a3 Signed-off-by: Florin Coras <fcoras@cisco.com>
2017-09-06NAT: Destination NAT44 with load-balancing (VPP-954)Matus Fabian2-0/+131
added load-balancing static mappings with unequal load support Change-Id: Ie505e41f24d46f812b94dd28bdafe3dc170a6060 Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-08-31Improvements to socket_test.sh scriptKeith Burns (alagalah)1-8/+8
Change-Id: I10c59dc32edb7336a56722b1de8cca1d0ae31c60 Signed-off-by: Keith Burns (alagalah) <alagalah@gmail.com>
2017-08-25make test: separate test discovery codeKlement Sekera2-34/+68
Separating test discovery code to it's own script file has the advantage of easily doing e.g. listing of all existing tests. Change-Id: I80dc280263cc7e33e7e13cb0d48b39bf08ece24d Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-25jvpp: introducing callback api and future api tests for all plugins (VPP-591)Matej Perina2-0/+136
test can be run with: make test TEST=test_jvpp memory_shared.c: declaring and assigning variable in if statement makes it usage outside statement impossible. Looks like memory space assigned to variable declared in statement is freed when statement ends svm.c: - fixed case when root path can have a "/" at beggining - added option for test to operate over shared memory space with /vpe-api name and not create new one with name consisting of root path and region name which would require root permisions Change-Id: Iff1170dc6a5c1be134c152f2757c7ab9b919a8ed Signed-off-by: Matej Perina <mperina@cisco.com>
2017-08-23NAT: Rename snat plugin to nat (VPP-955)Matus Fabian2-536/+525
Change-Id: I30a7e3da7a4efc6038a91e27b48045d4b07e2764 Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-08-22SRv6 testsKris Michielsen4-0/+2538
Change-Id: Ib1d2fc5a83d9d007a0468591a73881675f1bec9b Signed-off-by: Kris Michielsen <kmichiel@cisco.com>
2017-08-21PPPoE usses a midchain adjacency stack on an interface-tx DPONeale Ranns1-1/+2
1) introduce an interface-tx DPO. This is a simple wrapper around a sw_if_index. enhance DPO stacking functions to allow per-instance next-nodes and hence allow children to stack onto the interface per-instance tx node and not on 'interface-output'. 2) update PPPoE code to use ta midchain stack on a interface-tx DPO of the encap-interface. This remove the need for pppoe_encap node (which is replaced by the adj-midchain-tx) and interface-output node is no longer used (see above). Since PPPoE encap node is no longer needed, the PPPoE seesion does not need to be retrieved in the data-path, hence the cahce misses are removed. Change-Id: Id8b40f53daa14889a9c51d802e14fed7fba4399a Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-08-18make test: fix broken passing of return valueKlement Sekera2-5/+6
Change-Id: I2cb83caaf55ca9a29c06d71c6d20f8273ec062b3 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-17Fix socket_test.sh to run iperf3 in docker.Dave Wallace1-16/+31
Change-Id: I47018fee4283b7b257f16e21b82bf7e497a7d985 Signed-off-by: Dave Wallace <dwallacelf@gmail.com>
2017-08-17make test: collect symlinks to failed testsKlement Sekera3-2/+48
Compress files in temporary directories of failed tests and symlink the directories under /tmp/vpp-failed-unittests location - preparation for jenkins archivation. Automatically cleanup the directory at start of test run. The compression is performed only when environment variable COMPRESS_FAILED_TEST_LOGS is set to one of "yes", "y", "1". This is set in verify target, but left unset by default, so when invoking make test by hand, files won't be compressed. Change-Id: I84c8f1c6aa79aa9c0b753357022b1f195f17a283 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-16SNAT: Make proto optional in nat64_bib_dump (VPP-942)Matus Fabian2-20/+8
make proto optional in nat64_bib_dump and nat64_st_dump Change-Id: Idd102ce2b1555d38783fd22c84e46b4c48570edc Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-08-16NAT64: Fallback to 3-tuple key for non TCP/UDP sessions (VPP-884)Matus Fabian1-18/+37
Change-Id: I4cafc8291725feb499355092bd429433e649b5b2 Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-08-15Support proxy ARP on mirrored TAP interfacesNeale Ranns2-0/+70
When VPP has an interface whose address is also applied to a TAP interface on the host, then VPP's TAP interface will be unnumbered to the 'real' interface and do proxy ARP from the host. the curious aspect of this setup is that ARP requests from the host will come from the VPP's own address. Change-Id: Ia238790e1034ba3cd3facdab29387b65a31525f2 Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-08-14SNAT: fix overlapping address space testMatus Fabian1-2/+2
change address/network of the second interface within VRF 10 Change-Id: Iab9772a419fb3e8f1a193756bdaa68cd8cdbb121 Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-08-14Fix VCL LD_PRELOAD lib location in socket_test.shDave Wallace1-9/+16
- Use VCL_LDPRELOAD_LIB_DIR env. var if set. - Default to /usr/local/lib where it will be installed. - Change library name to libvcl_ldpreload.so.0.0.0 Change-Id: I4fc30b581c8406c5895f875d859aa44bb9ef19b5 Signed-off-by: Dave Wallace <dwallacelf@gmail.com>
2017-08-14make test: properly handle ctrl-cKlement Sekera3-3/+36
Change-Id: Iab88886ebc1582626813777ea45ce97fc8e36443 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-12make test: fix broken DEBUG=gdb* optionsKlement Sekera2-44/+56
Change-Id: I5d80982eeab78a629760f567eda3b1539d96e3a8 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-11Dedicated SW Interface EventNeale Ranns1-7/+2
Change-Id: I06a10a4291e61aec3f1396d2514ed6fe3901897a Signed-off-by: Neale Ranns <neale.ranns@cisco.com> Signed-off-by: Marek Gradzki <mgradzki@cisco.com>
2017-08-11Add VPP Communications Library (VCL)Dave Wallace1-0/+637
- VCL library - client/server test application - test script (make test integration tbd) - gdb command file templates - vppcom test config file Change-Id: I21eab7aa09b4e5dc3412acf5c2eab07415c2fc0f Signed-off-by: Dave Wallace <dwallacelf@gmail.com>
2017-08-10make test: bump default test timeout to 10 minutesKlement Sekera1-1/+1
Change-Id: I25d88966376d712ff61f29227a45880a59e8ecf2 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-10make test: detect hung testsKlement Sekera6-29/+148
Run tests in a forked process with a set of pipes to communicate keep-alives and overall result. This allows us to detect when e.g. vpp dies mid-API call causing the test to hang waiting for response (which will never come since vpp died). Support setting a (per test case) TIMEOUT make test option to set timeout, with a default timeout of 120 seconds. Example - fail the test suite if any test-case fails to finish within 300s: make TIMEOUT=300 test Change-Id: I0d04f26a7232968f4bf043adf5d5b508f5018717 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-10acl-plugin: all TCP sessions treated as transient (VPP-932)Andrew Yourtchenko1-10/+140
The packet that was creating the session was not tracked, consequently the TCP flags seen within the session record never got the value for the session to get treated as being in the established state. Test-escape, so add the TCP tests which test the three phases of the TCP session life and make them all pass. Change-Id: Ib048bc30c809a7f03be2de7e8361c2c281270348 Signed-off-by: Andrew Yourtchenko <ayourtch@gmail.com> (cherry picked from commit 754370f1b55d4102d21dd94676f2bda3170c7df0)
2017-08-09Add PPPoE PluginHongjun Ni3-0/+710
Supports 64K PPPoE sessions This plugin adds three graph nodes: 1) pppoe-input for PPPoE decapsulation 2) pppoe-encap for PPPoE encapsulation 3) pppoe-tap-dispatch for control plane process Below is the configuration to make PPPoE CP and DP work: vim /etc/vpp/startup.conf tuntap { enable ethernet name newtap } create pppoe tap tap-if-index 1 //Configure it after a subscriber's PPPoE discovery and PPP link establishment succeeds: create pppoe session client-ip 100.1.2.1 session-id 1 client-mac 00:11:01:00:00:01 show pppoe fib show pppoe session Change-Id: I73e724b6bf7c3e4181a9914c5752da1fa72d7e60 Signed-off-by: Hongjun Ni <hongjun.ni@intel.com>
2017-08-08L2 over MPLSNeale Ranns9-112/+331
[support for VPWS/VPLS] - switch to using dpo_proto_t rather than fib_protocol_t in fib_paths so that we can describe L2 paths - VLIB nodes to handle pop/push of MPLS labels to L2 Change-Id: Id050d06a11fd2c9c1c81ce5a0654e6c5ae6afa6e Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-08-07make test: kill all remaining subprocesses on exitKlement Sekera2-1/+26
This change introduces a wrapper script which kills all processes in the same process group as itself (with the exception of the script). Using this script to run the unit tests should prevent stale processes left behind in some cases (e.g. when test framework crashes). Change-Id: If3b9201c06b87fa6be095721436893207d09b5e4 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-08-03DHCP Client: receive unicast ACKsNeale Ranns1-21/+71
despite VPP DHCP client setting neither ciaddr nor giaddr and setting the broadcast bit (see RFC 2131 section 4.1) some DHCP servers will still send a unicast DCHPACK. So as not to drop this VPP must have both 1) a receive FIB entry for the OFFERED IP adress and 2) a 'don't drop me because of uRPF' FIB entry for the DHCP server's address. Change-Id: I167d858deb45629318cbdccf5bf67d971730a42f Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-08-01Tests for recursive load-balancing with no choices.Neale Ranns2-5/+68
Change-Id: I90bb3369576741d03628a818ffa63cc99d6e4c98 Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-08-01P2P EthernetPavel Kotucek3-0/+586
Change-Id: Idb97e573961b3bc2acdeef77582314590795f8c3 Signed-off-by: Pavel Kotucek <pkotucek@cisco.com>
2017-07-24SPAN:add l2 mirrorEyal Bari2-33/+322
added span feature nodes for l2-input / l2-output Change-Id: Ib6e0ce60d0811901b6edd70209e6a4c4a35cd8ff Signed-off-by: Eyal Bari <ebari@cisco.com>
2017-07-21SNAT: in2out translation as an output feature hairpinning (VPP-913)Matus Fabian1-1/+1
Change-Id: I3790739683c6090ffb2aefb4758bd4275856c09a Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-07-20SNAT: in2out translation as an output feature (VPP-903)Matus Fabian2-0/+169
in2out translation as an output feature on the outside interface (postrouting) Change-Id: I32c0311be09bdf102b9a0885b8b89c7588cb558f Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-07-18make test: improve console output messagesKlement Sekera1-3/+3
Remove the word derp and replace it with a proper, more gramatically correct message. Change-Id: I04fd44cc67dace1a31ca48fc8ce67b246162ba79 Signed-off-by: Klement Sekera <ksekera@cisco.com>
2017-07-18DHCP client option 61 "client_id"Neale Ranns2-2/+34
the existing seeting of client_id to a VPP version number was unused and so overridden Change-Id: If9ebea936336f1fcca8d07e67186c95f8f8f0ccd Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-07-18DHCP client - remove interface address when DHCP de-configuredNeale Ranns2-21/+152
Change-Id: I63c59e3c13859b51999d283774f7783ef0a6a5ed Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-07-18TEST:add l2bd nd term testsEyal Bari1-6/+119
Change-Id: I67633175d50a70a0b8ae4f85c659b93070f8e1fb Signed-off-by: Eyal Bari <ebari@cisco.com>
2017-07-07SNAT: Fallback to 3-tuple key for non TCP/UDP sessions (VPP-884)Matus Fabian1-1/+246
Change-Id: I4868ff6e81c579b29d3ea066976ae145f8b83e9e Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-07-04TEST:add L2BD arp term testsEyal Bari3-0/+273
Change-Id: I42414da9663ecfc8dfe5baf3e6615cf3b9b02e22 Signed-off-by: Eyal Bari <ebari@cisco.com>
2017-07-03SNAT: fix failing test_session_limit_per_user (VPP-896)Matus Fabian1-0/+2
Change-Id: Idf46a03803125babd9bb880363686359fbcca27d Signed-off-by: Matus Fabian <matfabia@cisco.com> (cherry picked from commit 860af5ad2b023f9c57d622a7a9d3bd0099e480b1)
2017-06-27L2-LEARN:fix l2fib entry seq num not updated on hit (VPP-888)Eyal Bari1-29/+29
fixed instability in l2bd_multi_instnce test - sometimes failing with extra packets captured it appears l2-learn was not updating hit entries but rather a copy of them. if the ager did not have a chance to run before the test was running the learning cycle - entries were not updated with the packet's seq num - causing packets to flood when hitting the stale seq_num in l2-fwd - hence the extra packets fixed handling of filter entries revert workaround for instability in test Change-Id: I16d918e6310a5bf40bad5b7335b2140c2867cb71 Signed-off-by: Eyal Bari <ebari@cisco.com> (cherry picked from commit 25ff2ea3a31e422094f6d91eab46222a29a77c4b)
2017-06-27FLOWPROBE: Add flowstartns, flowendns and tcpcontrolbitsOle Troan1-10/+96
- fixed problem with tcp_flag - changed flowtimestamp into NTP format Change-Id: I4ef05d6c69c5c078a0c80d59c5ccb0c85b924ba6 Signed-off-by: Ole Troan <ot@cisco.com>
2017-06-21acl-plugin: CLI to clear all sessionsAndrew Yourtchenko1-0/+37
It is useful to have the CLI to clear the existing sessions. There was a work-in-progress CLI but it did not work properly. Fix it and split into a separate "clear acl-plugin sessions", and add a unit test into the extended connection-oriented tests. Change-Id: I55889165ebcee139841fdac88747390903a05394 Signed-off-by: Andrew Yourtchenko <ayourtch@gmail.com>
2017-06-21NAT64: custom prefixMatus Fabian2-7/+164
Change-Id: If397b49861468eed29b964fa64b186f80eb0eceb Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-06-21ARP: ignore non-connected routes and non-interface sources when determing if ↵Neale Ranns1-2/+70
source is connected Change-Id: I39fb0ec44cc322eaa12c0ff0700fc405d3982bfc Signed-off-by: Neale Ranns <nranns@cisco.com>
2017-06-21L2-VTR: add vtr testsEyal Bari4-65/+455
re-enable l2 fib flush tests reorder l2bd multi instance tests - move flags test as last enabling of uu-flood will now flood when entry is stale Change-Id: I052663ec3eb4acee5f296fb7525dd535924e0003 Signed-off-by: Eyal Bari <ebari@cisco.com>
2017-06-20SNAT: unknow protocol hairpinning fixMatus Fabian1-2/+57
Change-Id: I15813167e7c8529f229143de4a8f64f0fb530951 Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-06-19L2FWD:fix seq_num overwritten + validate l2fib entries when forwardingEyal Bari1-3/+0
l2_classify memeber table_index was overlaid over l2.l2fib_seq_num which over written when table_index gets initialized in l2_input_classify solved by overlaying both table_index and opaque_index as only one is used seperated l2fib seq num from l2_input configs for better handling of theoretical ABA issue where an entry for a deleted interface is considered valid by the ager because a different interface with same sw_if_index and seq_num was created before the ager got a chance to delete Change-Id: I7b0eeded971627406f1c80834d7e02c0ebe62136 Signed-off-by: Eyal Bari <ebari@cisco.com>
2017-06-19SNAT: NAT packet with unknown L4 protocol if match 1:1 NATMatus Fabian1-1/+49
Change-Id: Ic81c6098d615fdb6a874e532921efd833fed872c Signed-off-by: Matus Fabian <matfabia@cisco.com>
2017-06-19acl-plugin: bihash-based ACL lookupAndrew Yourtchenko3-0/+18
Add a bihash-based ACL lookup mechanism and make it a new default. This changes the time required to lookup a 5-tuple match from O(total_N_entries) to O(total_N_mask_types), where "mask type" is an overall mask on the 5-tuple required to represent an ACE. For testing/comparison there is a temporary debug CLI "set acl-plugin use-hash-acl-matching {0|1}", which, when set to 0, makes the plugin use the "old" linear lookup, and when set to 1, makes it use the hash-based lookup. Based on the discussions on vpp-dev mailing list, prevent assigning the ACL index to an interface, when the ACL with that index is not defined, also prevent deleting an ACL if that ACL is applied. Also, for the easier debugging of the state, there are new debug CLI commands to see the ACL plugin state at several layers: "show acl-plugin acl [index N]" - show a high-level ACL representation, used for the linear lookup and as a base for building the hashtable-based lookup. Also shows if a given ACL is applied somewhere. "show acl-plugin interface [sw_if_index N]" - show which interfaces have which ACL(s) applied. "show acl-plugin tables" - a lower-level debug command used to see the state of all of the related data structures at once. There are specifiers possible, which make for a more focused and maybe augmented output: "show acl-plugin tables acl [index N]" show the "bitmask-ready" representations of the ACLs, we well as the mask types and their associated indices. "show acl-plutin tables mask" show the derived mask types and their indices only. "show acl-plugin tables applied [sw_if_index N]" show the table of all of the ACEs applied for a given sw_if_index or all interfaces. "show acl-plugin tables hash [verbose N]" show the 48x8 bihash used for the ACL lookup. Change-Id: I89fff051424cb44bcb189e3cee04c1b8f76efc28 Signed-off-by: Andrew Yourtchenko <ayourtch@gmail.com>
2017-06-19NAT64: Hairpinning (VPP-699)Matus Fabian1-14/+271
Change-Id: I83a6c277fa211ac2c2ca2d603650c992886af0a7 Signed-off-by: Matus Fabian <matfabia@cisco.com>
ss="k">for (j = 0; j < 4; j++) p[j] = 4 * i + j; } i = vec_pop (ob->free_indices); i_set = i & 3; b = ((vhash_overflow_search_bucket_t *) vec_elt_at_index (ob->search_buckets, i / 4)); /* Insert result. */ set_overflow_result (b, i_set, new_result, key_hash); /* Insert key. */ for (i = 0; i < n_key_u32s; i++) b->key[i].as_u32[i_set] = vhash_get_key_word (h, i, vi); ob->n_overflow++; h->n_elts++; return /* old result was invalid */ 0; } u32 vhash_unset_overflow (vhash_t * h, u32 key_hash, u32 vi, u32 n_key_u32s) { vhash_overflow_buckets_t *ob = vhash_get_overflow_buckets (h, key_hash); vhash_overflow_search_bucket_t *b; u32 i_set, i, old_result; foreach_vhash_overflow_bucket (b, ob, n_key_u32s) { u32x4 r; r = b->result.as_u32x4; for (i = 0; i < n_key_u32s; i++) r &= vhash_bucket_compare (h, &b->key[0], i, vi); old_result = vhash_merge_results (r); if (old_result) { i_set = vhash_non_empty_result_index (r); /* Invalidate result and invert key hash so that this will never match since all keys in this overflow bucket have matching key hashs. */ set_overflow_result (b, i_set, 0, ~key_hash); free_overflow_bucket (ob, b, i_set); ASSERT (ob->n_overflow > 0); ob->n_overflow--; h->n_elts--; return old_result; } } /* Could not find key. */ return 0; } void vhash_unset_refill_from_overflow (vhash_t * h, vhash_search_bucket_t * sb, u32 key_hash, u32 n_key_u32s) { vhash_overflow_buckets_t *obs = vhash_get_overflow_buckets (h, key_hash); vhash_overflow_search_bucket_t *ob; u32 i, j, i_refill, bucket_mask = h->bucket_mask.as_u32[0]; /* Find overflow element with matching key hash. */ foreach_vhash_overflow_bucket (ob, obs, n_key_u32s) { for (i = 0; i < 4; i++) { if (!ob->result.as_u32[i]) continue; if ((ob->key_hash.as_u32[i] & bucket_mask) != (key_hash & bucket_mask)) continue; i_refill = vhash_empty_result_index (sb->result.as_u32x4); sb->result.as_u32[i_refill] = ob->result.as_u32[i]; for (j = 0; j < n_key_u32s; j++) sb->key[j].as_u32[i_refill] = ob->key[j].as_u32[i]; set_overflow_result (ob, i, 0, ~key_hash); free_overflow_bucket (obs, ob, i); return; } } } void vhash_init (vhash_t * h, u32 log2_n_keys, u32 n_key_u32, u32 * hash_seeds) { uword i, j, m; vhash_search_bucket_t *b; clib_memset (h, 0, sizeof (h[0])); /* Must have at least 4 keys (e.g. one search bucket). */ log2_n_keys = clib_max (log2_n_keys, 2); h->log2_n_keys = log2_n_keys; h->n_key_u32 = n_key_u32; m = pow2_mask (h->log2_n_keys) & ~3; for (i = 0; i < VECTOR_WORD_TYPE_LEN (u32); i++) h->bucket_mask.as_u32[i] = m; /* Allocate and zero search buckets. */ i = (sizeof (b[0]) / sizeof (u32x4) + n_key_u32) << (log2_n_keys - 2); vec_validate_aligned (h->search_buckets, i - 1, CLIB_CACHE_LINE_BYTES); for (i = 0; i < ARRAY_LEN (h->find_first_zero_table); i++) h->find_first_zero_table[i] = min_log2 (first_set (~i)); for (i = 0; i < ARRAY_LEN (h->hash_seeds); i++) for (j = 0; j < VECTOR_WORD_TYPE_LEN (u32); j++) h->hash_seeds[i].as_u32[j] = hash_seeds[i]; } static_always_inline u32 vhash_main_key_gather (void *_vm, u32 vi, u32 wi, u32 n_key_u32) { vhash_main_t *vm = _vm; return vec_elt (vm->keys, vi * n_key_u32 + wi); } static_always_inline u32x4 vhash_main_4key_gather (void *_vm, u32 vi, u32 wi, u32 n_key_u32s) { vhash_main_t *vm = _vm; u32x4_union_t x; ASSERT (n_key_u32s == vm->n_key_u32); ASSERT (wi < n_key_u32s); x.as_u32[0] = vec_elt (vm->keys, (vi + 0) * n_key_u32s + wi); x.as_u32[1] = vec_elt (vm->keys, (vi + 1) * n_key_u32s + wi); x.as_u32[2] = vec_elt (vm->keys, (vi + 2) * n_key_u32s + wi); x.as_u32[3] = vec_elt (vm->keys, (vi + 3) * n_key_u32s + wi); return x.as_u32x4; } static_always_inline u32 vhash_main_set_result (void *_vm, u32 vi, u32 old_result, u32 n_key_u32) { vhash_main_t *vm = _vm; u32 *p = vec_elt_at_index (vm->results, vi); u32 new_result = p[0]; p[0] = old_result; return new_result; } static_always_inline u32 vhash_main_get_result (void *_vm, u32 vi, u32 old_result, u32 n_key_u32) { vhash_main_t *vm = _vm; vec_elt (vm->results, vi) = old_result; return old_result; } static_always_inline u32x4 vhash_main_get_4result (void *_vm, u32 vi, u32x4 old_result, u32 n_key_u32) { vhash_main_t *vm = _vm; u32x4 *p = (u32x4 *) vec_elt_at_index (vm->results, vi); p[0] = old_result; return old_result; } #define _(N_KEY_U32) \ static_always_inline u32 \ vhash_main_key_gather_##N_KEY_U32 (void * _vm, u32 vi, u32 i) \ { return vhash_main_key_gather (_vm, vi, i, N_KEY_U32); } \ \ static_always_inline u32x4 \ vhash_main_4key_gather_##N_KEY_U32 (void * _vm, u32 vi, u32 i) \ { return vhash_main_4key_gather (_vm, vi, i, N_KEY_U32); } \ \ clib_pipeline_stage_static \ (vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_gather_4key_stage \ (vm->vhash, \ /* vector_index */ i, \ vhash_main_4key_gather_##N_KEY_U32, \ vm, \ N_KEY_U32); \ }) \ \ clib_pipeline_stage_no_inline \ (vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_gather_key_stage \ (vm->vhash, \ /* vector_index */ vm->n_vectors_div_4, \ /* n_vectors */ vm->n_vectors_mod_4, \ vhash_main_key_gather_##N_KEY_U32, \ vm, \ N_KEY_U32); \ }) \ \ clib_pipeline_stage \ (vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_finalize_stage (vm->vhash, i, N_KEY_U32); \ }) \ \ clib_pipeline_stage_no_inline \ (vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_finalize_stage (vm->vhash, vm->n_vectors_div_4, N_KEY_U32); \ }) \ \ clib_pipeline_stage_static \ (vhash_main_get_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_get_4_stage (vm->vhash, \ /* vector_index */ i, \ vhash_main_get_4result, \ vm, N_KEY_U32); \ }) \ \ clib_pipeline_stage_no_inline \ (vhash_main_get_mod_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_get_stage (vm->vhash, \ /* vector_index */ vm->n_vectors_div_4, \ /* n_vectors */ vm->n_vectors_mod_4, \ vhash_main_get_result, \ vm, N_KEY_U32); \ }) \ \ clib_pipeline_stage_static \ (vhash_main_set_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_set_stage (vm->vhash, \ /* vector_index */ i, \ /* n_vectors */ VECTOR_WORD_TYPE_LEN (u32), \ vhash_main_set_result, \ vm, N_KEY_U32); \ }) \ \ clib_pipeline_stage_no_inline \ (vhash_main_set_mod_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_set_stage (vm->vhash, \ /* vector_index */ vm->n_vectors_div_4, \ /* n_vectors */ vm->n_vectors_mod_4, \ vhash_main_set_result, \ vm, N_KEY_U32); \ }) \ \ clib_pipeline_stage_static \ (vhash_main_unset_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_unset_stage (vm->vhash, \ /* vector_index */ i, \ /* n_vectors */ VECTOR_WORD_TYPE_LEN (u32), \ vhash_main_get_result, \ vm, N_KEY_U32); \ }) \ \ clib_pipeline_stage_no_inline \ (vhash_main_unset_mod_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_unset_stage (vm->vhash, \ /* vector_index */ vm->n_vectors_div_4, \ /* n_vectors */ vm->n_vectors_mod_4, \ vhash_main_get_result, \ vm, N_KEY_U32); \ }) _(1); _(2); _(3); _(4); _(5); _(6); #undef _ #define _(N_KEY_U32) \ clib_pipeline_stage \ (vhash_main_hash_mix_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_mix_stage (vm->vhash, i, N_KEY_U32); \ }) \ \ clib_pipeline_stage_no_inline \ (vhash_main_hash_mix_mod_stage_##N_KEY_U32, \ vhash_main_t *, vm, i, \ { \ vhash_mix_stage (vm->vhash, vm->n_vectors_div_4, N_KEY_U32); \ }) _(4); _(5); _(6); #undef _ typedef enum { GET, SET, UNSET, } vhash_main_op_t; static void vhash_main_op (vhash_main_t * vm, vhash_main_op_t op) { u32 n_keys = vec_len (vm->results); vm->n_key_u32 = vm->vhash->n_key_u32; vhash_validate_sizes (vm->vhash, vm->n_key_u32, n_keys); vm->n_vectors_div_4 = n_keys / 4; vm->n_vectors_mod_4 = n_keys % 4; if (vm->n_vectors_div_4 > 0) { switch (vm->n_key_u32) { default: ASSERT (0); break; #define _(N_KEY_U32) \ case N_KEY_U32: \ if (op == GET) \ clib_pipeline_run_3_stage \ (vm->n_vectors_div_4, \ vm, \ vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_get_stage_##N_KEY_U32); \ else if (op == SET) \ clib_pipeline_run_3_stage \ (vm->n_vectors_div_4, \ vm, \ vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_set_stage_##N_KEY_U32); \ else \ clib_pipeline_run_3_stage \ (vm->n_vectors_div_4, \ vm, \ vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_unset_stage_##N_KEY_U32); \ break; _(1); _(2); _(3); #undef _ #define _(N_KEY_U32) \ case N_KEY_U32: \ if (op == GET) \ clib_pipeline_run_4_stage \ (vm->n_vectors_div_4, \ vm, \ vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_hash_mix_stage_##N_KEY_U32, \ vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_get_stage_##N_KEY_U32); \ else if (op == SET) \ clib_pipeline_run_4_stage \ (vm->n_vectors_div_4, \ vm, \ vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_hash_mix_stage_##N_KEY_U32, \ vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_set_stage_##N_KEY_U32); \ else \ clib_pipeline_run_4_stage \ (vm->n_vectors_div_4, \ vm, \ vhash_main_gather_keys_stage_##N_KEY_U32, \ vhash_main_hash_mix_stage_##N_KEY_U32, \ vhash_main_hash_finalize_stage_##N_KEY_U32, \ vhash_main_unset_stage_##N_KEY_U32); \ break; _(4); _(5); _(6); #undef _ } } if (vm->n_vectors_mod_4 > 0) { switch (vm->n_key_u32) { default: ASSERT (0); break; #define _(N_KEY_U32) \ case N_KEY_U32: \ if (op == GET) \ clib_pipeline_run_3_stage \ (1, \ vm, \ vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_get_mod_stage_##N_KEY_U32); \ else if (op == SET) \ clib_pipeline_run_3_stage \ (1, \ vm, \ vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_set_mod_stage_##N_KEY_U32); \ else \ clib_pipeline_run_3_stage \ (1, \ vm, \ vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_unset_mod_stage_##N_KEY_U32); \ break; _(1); _(2); _(3); #undef _ #define _(N_KEY_U32) \ case N_KEY_U32: \ if (op == GET) \ clib_pipeline_run_4_stage \ (1, \ vm, \ vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_hash_mix_mod_stage_##N_KEY_U32, \ vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_get_mod_stage_##N_KEY_U32); \ else if (op == SET) \ clib_pipeline_run_4_stage \ (1, \ vm, \ vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_hash_mix_mod_stage_##N_KEY_U32, \ vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_set_mod_stage_##N_KEY_U32); \ else \ clib_pipeline_run_4_stage \ (1, \ vm, \ vhash_main_gather_keys_mod_stage_##N_KEY_U32, \ vhash_main_hash_mix_mod_stage_##N_KEY_U32, \ vhash_main_hash_finalize_mod_stage_##N_KEY_U32, \ vhash_main_unset_mod_stage_##N_KEY_U32); \ break; _(4); _(5); _(6); #undef _ } } } void vhash_main_get (vhash_main_t * vm) { vhash_main_op (vm, GET); } void vhash_main_set (vhash_main_t * vm) { vhash_main_op (vm, SET); } void vhash_main_unset (vhash_main_t * vm) { vhash_main_op (vm, UNSET); } u32 vhash_resize_incremental (vhash_resize_t * vr, u32 vector_index, u32 n_keys_this_call) { vhash_t *old = vr->old; vhash_main_t *vm = &vr->new; vhash_t *new = vm->vhash; uword i, j, n_key_u32; n_key_u32 = old->n_key_u32; if (vector_index == 0) { u32 hash_seeds[3]; hash_seeds[0] = old->hash_seeds[0].as_u32[0]; hash_seeds[1] = old->hash_seeds[1].as_u32[0]; hash_seeds[2] = old->hash_seeds[2].as_u32[0]; vhash_init (new, old->log2_n_keys + 1, n_key_u32, hash_seeds); } vec_reset_length (vm->keys); vec_reset_length (vm->results); if (0 == (vector_index >> old->log2_n_keys)) { for (i = vector_index; 0 == (i >> (old->log2_n_keys - 2)); i++) { vhash_search_bucket_t *b = vhash_get_search_bucket_with_index (old, 4 * i, n_key_u32); u32 r, *k; #define _(I) \ if ((r = b->result.as_u32[I]) != 0) \ { \ vec_add1 (vm->results, r - 1); \ vec_add2 (vm->keys, k, n_key_u32); \ for (j = 0; j < n_key_u32; j++) \ k[j] = b->key[j].as_u32[I]; \ } _(0); _(1); _(2); _(3); #undef _ if (vec_len (vm->results) >= n_keys_this_call) { vhash_main_op (vm, SET); return i; } } } /* Add overflow buckets. */ { vhash_overflow_buckets_t *ob; vhash_overflow_search_bucket_t *b; for (ob = old->overflow_buckets; ob < old->overflow_buckets + ARRAY_LEN (old->overflow_buckets); ob++) { foreach_vhash_overflow_bucket (b, ob, old->n_key_u32) { u32 r, *k; #define _(I) \ if ((r = b->result.as_u32[I]) != 0) \ { \ vec_add1 (vm->results, r - 1); \ vec_add2 (vm->keys, k, n_key_u32); \ for (j = 0; j < n_key_u32; j++) \ k[j] = b->key[j].as_u32[I]; \ } _(0); _(1); _(2); _(3); #undef _ } } } vhash_main_op (vm, SET); /* Let caller know we are done. */ return ~0; } void vhash_resize (vhash_t * old, u32 log2_n_keys) { static vhash_resize_t vr; vhash_t new; u32 i = 0; vr.old = old; vr.new.vhash = &new; while (1) { i = vhash_resize_incremental (&vr, i, 1024); if (i == ~0) break; } vhash_free (old); *old = new; } #endif /* CLIB_HAVE_VEC128 */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */