--[[ /* * Copyright (c) 2016 Cisco and/or its affiliates. * 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. */ ]] local vpp = require "vpp-lapi" local ffi = require "ffi" ffi.cdef([[ struct timespec { long tv_sec; /* seconds */ long tv_nsec; /* nanoseconds */ }; int clock_gettime(int clk_id, struct timespec *tp); ]]) local time_cache = ffi.new("struct timespec[1]") local time_cache_1 = time_cache[0] function get_ns() ffi.C.clock_gettime(0, time_cache) return time_cache_1.tv_nsec + 1000000000 * time_cache_1.tv_sec end function do_bench() local cycle_start = get_ns() local n_iterations = 10000 local count = 1 for i = 1,n_iterations do -- print(i) vpp:api_call("show_version") count = count + 1 -- print(i, "done") end cycle_end = get_ns() local tps = n_iterations*1000000000LL/(cycle_end - cycle_start) print (tostring(count) .. " iterations, average speed " .. tostring(tps) .. " per second") return tps end root_dir = "/home/ubuntu/vpp" pneum_path = root_dir .. "/build-root/install-vpp_lite_debug-native/vpp-api/lib64/libpneum.so" vpp:init({ pneum_path = pneum_path }) vpp:json_api(root_dir .. "/build-root/install-vpp_lite_debug-native/vpp/vpp-api/vpe.api.json") vpp:connect("lua-bench") local n_tests = 10 local tps_acc = 0LL for i=1,n_tests do tps_acc = tps_acc + do_bench() end print("Average tps across the tests: " .. tostring(tps_acc/n_tests)) vpp:disconnect()