Skip to content

Commit

Permalink
Merge the perfimprov branch
Browse files Browse the repository at this point in the history
Performance improvement, mainly adding read_variables and
write_variables accessor to the database to enable cache-based matching
  • Loading branch information
tbarbette committed Jul 14, 2024
1 parent 8560f2a commit 52e67b7
Show file tree
Hide file tree
Showing 23 changed files with 382 additions and 207 deletions.
8 changes: 5 additions & 3 deletions integration/test_unittest.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
from npf.test import Test
from npf.build import Build
from npf.variable import dtype, numeric_dict
from npf.types.dataset import Run, ImmutableRun
from npf.types.dataset import Run

import numpy as np

Expand Down Expand Up @@ -95,11 +95,13 @@ def test_runequality():
rb["A"] = 1
b = Run(rb)
assert a == b
assert ImmutableRun(ra) == ImmutableRun(rb)
assert ImmutableRun(ra) == b
assert a.inside(b)
assert b.inside(a)
assert a.__hash__() == b.__hash__()
h = a.__hash__()
a.write_variables()["A"] = 3
assert a.__hash__() != h
assert a != b

def test_local_executor():
l = LocalExecutor()
Expand Down
2 changes: 2 additions & 0 deletions modules/fastclick-echo.npf
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
%script deps=fastclick sudo=true
click --dpdk -l 0-7 -a ${self:0:pci} -- -e "FromDPDKDevice(0, PROMISC true) -> EtherMirror -> ToDPDKDevice(0);"
8 changes: 5 additions & 3 deletions modules/fastclick-play-single-mt.npf
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ RCV_NIC=0
LIMIT=50000000
LIMIT_TIME=10
GEN_THREADS=4
GEN_RX_THREADS=4
GEN_PIPELINE=1
udpgen:GEN_PIPELINE=0
GEN_TX_PIPELINE=0
Expand All @@ -38,7 +39,7 @@ GEN_BURST=32
PROMISC=false
promisc:PROMISC=true
IGNORE?=0
PAUSE=none
GEN_PAUSE=none
GEN_DESC=0
END_AFTER=0
GEN_PROGRESSIVE=0
Expand Down Expand Up @@ -169,6 +170,7 @@ Idle->[1]output;
elementclass Numberise { $magic |
input-> Strip(14)
$GEN_NUMBER
$GEN_FNT
$(( "" if $GEN_IPV6 else " -> ResetIPChecksum() " ))
-> Unstrip(14) -> output
}
Expand Down Expand Up @@ -201,7 +203,7 @@ $(( " StaticThreadSched(fdIN0 0/0, unqueue0 0/0);" if $GEN_PIPELINE else "" ))

$(( " StaticThreadSched(tdIN 0/%d);" % ($GEN_THREADS + 1) if $GEN_TX_PIPELINE else "" ))

receiveIN :: FromDPDKDevice($port, VERBOSE $rxverbose, MAC $INsrcmac, PROMISC $PROMISC, PAUSE $PAUSE, NDESC $GEN_DESC, MAXTHREADS $GEN_THREADS, NUMA false, ACTIVE $GEN_RX)
receiveIN :: FromDPDKDevice($port, VERBOSE $rxverbose, MAC $INsrcmac, PROMISC $PROMISC, PAUSE $GEN_PAUSE, NDESC $GEN_DESC, MAXTHREADS $GEN_RX_THREADS, NUMA false, ACTIVE $GEN_RX)

elementclass Receiver { $mac, $dir |
input[0]
Expand All @@ -214,7 +216,7 @@ $GEN_MAGIC
c[1] //Not for this computer or broadcasts
-> Discard;

$(( "\n".join([ "magic[%d] -> tsd%d :: $GEN_TSDIFF(gen%d/rt, OFFSET %d, N $NRECORD, SAMPLE $SAMPLE, NANO $GEN_NANO ) -> Unstrip(14) -> avg%d :: AverageCounterMP(IGNORE $ignore) -> Discard; tsd%d[1] -> Print('WARNING: Untimestamped packet on thread %d', 64) -> Discard;" % (t,t,t,${NUMBEROFFSET} + 2,t,t,t) for t in range($GEN_THREADS) ]) ))
$(( "\n".join([ "magic[%d] -> tsd%d :: $GEN_TSDIFF(gen%d/rt, OFFSET %d, N $NRECORD, SAMPLE $SAMPLE, NANO $GEN_NANO ) -> Unstrip(14) -> avg%d :: AverageCounterIMP(IGNORE $ignore) -> Discard; tsd%d[1] -> Print('WARNING: Untimestamped packet on thread %d', 64) -> Discard;" % (t,t,t,${NUMBEROFFSET} + 2,t,t,t) for t in range($GEN_THREADS) ]) ))


$(( ( "avg :: HandlerAggregate( " + ",".join(["ELEMENT avg%d" % (i) for i in range($GEN_THREADS) ]) + " );" ) if 1 else "" ))
Expand Down
1 change: 1 addition & 0 deletions modules/fastclick-replay-single-mt.npf
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,7 @@ SND_NIC?=EXPAND($CLIENT_NIC)
RCV_NIC?=EXPAND($CLIENT_NIC)
DODUMP?=0
GEN_DUMP?=0
udpgen:GEN_SEQUENTIAL?=1
GEN_SEQUENTIAL?=0
gdb:GDB=gdb -ex run -ex "signal 2" -ex bt -batch -args
udpgen:GEN_TRACE_SUP+=->MarkMACHeader->EnsureDPDKBuffer->Pad
Expand Down
23 changes: 18 additions & 5 deletions npf/build.py
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ def _writeversion(self, filename, all_results, allow_overwrite):
f.seek(0)
for run, results in all_results.items():
v = []
for key, val in sorted(run.variables.items()):
for key, val in sorted(run.read_variables().items()):
if type(val) is tuple:
val = val[1]
v.append((key + ":" + str(val).replace('\\:', ':').replace(':','\\:')).replace('\\,', ',').replace(',','\\,'))
Expand Down Expand Up @@ -145,14 +145,27 @@ def load_results(self, test, kind=False, cache=True):
if os.path.basename(filename) in f:
kind = f[f.rfind("-") + 1 :]
f = filename + kind
kr[kind] = self._load_results(test, f, cache)
kr[kind] = self._load_results(f, cache)
return kr

else:
filename = self.__resultFilename(test)
return self._load_results(test, filename, cache)
return self._load_results(filename, cache)

def _load_results(self, test, filename, cache):
def _load_results(self, filename, cache):
"""
The function `_load_results` reads data from a file, parses it, and returns the results in a
dictionary format.
:param filename: The `filename` parameter is a string that represents the name of the file from
which the results will be loaded
:param cache: The `cache` parameter is a boolean value that determines whether or not to use a
cache to store and retrieve previously loaded results. If `cache` is `True`, the function will
check if the `filename` is already in the cache and return the cached results if available. If
`cache`
:return: the variable "all_results", which is a dictionary containing the parsed results from
the file.
"""
if not Path(filename).exists():
return None
if cache:
Expand All @@ -171,7 +184,7 @@ def _load_results(self, test, filename, cache):
for v_data in re.split(r'(?<!\\),', variables_data):
if v_data.strip():
k, v = re.split(r'(?<!\\):', v_data)
variables[k] = variable.get_numeric(v) if test.variables.is_numeric(k) else str(v).replace('\\:',':')
variables[k] = variable.get_numeric(v) if variable.is_numeric(k) else str(v).replace('\\:',':')
results = {}

results_data = results_data.strip()[1:-1].split('},{')
Expand Down
1 change: 0 additions & 1 deletion npf/executor/executor.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import re


from colorama import Fore, Back, Style

foreColors = [Fore.BLACK, Fore.RED, Fore.GREEN, Fore.YELLOW, Fore.BLUE, Fore.MAGENTA, Fore.CYAN, Fore.WHITE]
Expand Down
7 changes: 4 additions & 3 deletions npf/executor/sshexecutor.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,17 +66,17 @@ def exec(self, cmd, bin_paths : List[str] = None,
print("Executing on %s%s (PATH+=%s) :\n%s" % (self.addr,(' with sudo' if sudo and self.user != "root" else ''),':'.join(path_list) + (("NS:" + virt) if virt else ""), cmd.strip()))

# The pre-command goes into the test folder
pre = 'cd '+ self.path + ';'
pre = 'cd '+ self.path + ';\n'

if self.path:
env['NPF_ROOT'] = self.path
env['NPF_CWD_PATH'] = os.path.relpath(npf.cwd_path(options),self.path)
env['NPF_EXPERIMENT_PATH'] = '../' + os.path.relpath(npf.experiment_path(), self.path)
env['NPF_ROOT_PATH'] = '../' + os.path.relpath(npf.npf_root_path(), self.path)

env_str=""
for k,v in env.items():
if v is not None:
pre += 'export ' + k + '='+v+'\n'
env_str += 'export ' + k + '='+v+'\n'
if path_list:
path_cmd = 'export PATH="%s:$PATH"\n' % (':'.join(path_list))
else:
Expand All @@ -89,6 +89,7 @@ def exec(self, cmd, bin_paths : List[str] = None,
if stdin is not None:
unbuffer = unbuffer + " -p"

cmd = env_str + cmd
if sudo and self.user != "root":
cmd = "sudo -E mkdir -p "+testdir+" && sudo -E " + virt +" "+unbuffer+" bash -c '"+path_cmd + cmd.replace("'", "'\"'\"'") + "'";
else:
Expand Down
Loading

0 comments on commit 52e67b7

Please sign in to comment.