summaryrefslogtreecommitdiffstats
path: root/VNFs/DPPD-PROX/defines.h
blob: c2309be1efe5c341adfe3a04fd3174d6354aaf57 (plain)
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*
// Copyright (c) 2010-2017 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
*/

#ifndef _DEFINES_H_
#define _DEFINES_H_

// with 3GHz CPU
#define DRAIN_TIMEOUT  __UINT64_C(6000000)             // drain TX buffer every 2ms
#define TERM_TIMEOUT   __UINT64_C(3000000000)          // check if terminated every 1s

/* DRAIN_TIMEOUT should be smaller than TERM_TIMEOUT as TERM_TIMEOUT
   is only checked after DRAIN_TIMEOUT */
#if TERM_TIMEOUT < DRAIN_TIMEOUT
#error TERM_TIMEOUT < DRAIN_TIMEOUT
#endif

#ifndef IPv4_BYTES
#define IPv4_BYTES_FMT  "%d.%d.%d.%d"
#define IPv4_BYTES(addr)                        \
        addr[0],  addr[1],  addr[2],  addr[3]
#endif

#ifndef IPv6_BYTES
#define IPv6_BYTES_FMT	"%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x"
#define IPv6_BYTES(addr)			\
	addr[0],  addr[1],  addr[2],  addr[3],	\
	addr[4],  addr[5],  addr[6],  addr[7],	\
	addr[8],  addr[9],  addr[10], addr[11],	\
	addr[12], addr[13], addr[14], addr[15]
#endif

#ifndef MAC_BYTES
#define MAC_BYTES_FMT "%02x:%02x:%02x:%02x:%02x:%02x"

#define MAC_BYTES(addr)   \
	addr[0], addr[1], \
	addr[2], addr[3], \
	addr[4], addr[5]
#endif

/* assume cpu byte order is little endian */
#define PKT_TO_LUTQINQ(svlan, cvlan) ((((uint32_t)svlan) & 0x000F) << 4 | (((uint32_t)svlan) & 0xFF00) << 8 | (((uint32_t)cvlan) & 0xFF0F))

#define ROUTE_ERR 254

#endif /* _DEFINES_H_ */
| | | | | | Bonnie++ is a disk and file system benchmarking tool for | | | measuring I/O performance. With Bonnie++ you can quickly and | | | easily produce a meaningful value to represent your current | | | file system performance. | | | | | | Bonnie++ is not always part of a Linux distribution, hence | | | it needs to be installed in the test image. | | | | +--------------+--------------------------------------------------------------+ |test | This test case uses Bonnie++ to perform the tests below: | |description | * Create files in sequential order | | | * Stat files in sequential order | | | * Delete files in sequential order | | | * Create files in random order | | | * Stat files in random order | | | * Delete files in random order | | | | +--------------+--------------------------------------------------------------+ |configuration | file: bonnie++.yaml (in the 'samples' directory) | | | | | | file_size is set to 1024; ram_size is set to 512; | | | test_dir is set to '/tmp'; concurrency is set to 1. | | | | | | SLA is not available in this test case. | | | | +--------------+--------------------------------------------------------------+ |applicability | Test can be configured with different: | | | | | | * file_size - size fo the test file in MB. File size should | | | be double RAM for good results; | | | * ram_size - specify RAM size in MB to use, this is used to | | | reduce testing time; | | | * test_dir - this directory is where bonnie++ will create | | | the benchmark operations; | | | * test_user - the user who should perform the test. This is | | | not required if you are not running as root; | | | * concurrency - number of thread to perform test; | | | | +--------------+--------------------------------------------------------------+ |usability | This test case is used for executing Bonnie++ benchmark in | | | VMs. | | | | +--------------+--------------------------------------------------------------+ |references | bonnie++_ | | | | | | ETSI-NFV-TST001 | | | | +--------------+--------------------------------------------------------------+ |pre-test | The Bonnie++ distribution includes a 'bon_csv2html' Perl | |conditions | script, which takes the comma-separated values reported by | | | Bonnie++ and generates an HTML page displaying them. | | | To use this feature, bonnie++ is required to be install with | | | yardstick (e.g. in yardstick docker). | | | | +--------------+--------------------------------------------------------------+ |test sequence | description and expected result | | | | +--------------+--------------------------------------------------------------+ |step 1 | A host VM with fio installed is booted. | | | | +--------------+--------------------------------------------------------------+ |step 2 | Yardstick is connected with the host VM by using ssh. | | | | +--------------+--------------------------------------------------------------+ |step 3 | Bonnie++ benchmark is invoked. Simulated IO operations are | | | started. Logs are produced and stored. | | | | | | Result: Logs are stored. | | | | +--------------+--------------------------------------------------------------+ |step 4 | An HTML report is generated using bonnie++ benchmark results | | | and stored under /tmp/bonnie.html. | | | | +--------------+--------------------------------------------------------------+ |step 5 | The host VM is deleted. | | | | +--------------+--------------------------------------------------------------+ |test verdict | None. Bonnie++ html report is generated. | | | | +--------------+--------------------------------------------------------------+