Skip to content

Commit

Permalink
benchmark/blowfish: new version of blowfish benchmark
Browse files Browse the repository at this point in the history
The new version uses a fixed time and provides variants for
single-thread, multi-thread, and multi-core.

A few results are included.

Signed-off-by: Burt P <pburt0@gmail.com>
  • Loading branch information
bp0 authored and lpereira committed Nov 4, 2018
1 parent f6299d9 commit d5d0607
Show file tree
Hide file tree
Showing 7 changed files with 136 additions and 53 deletions.
1 change: 1 addition & 0 deletions CMakeLists.txt
Expand Up @@ -167,6 +167,7 @@ set(MODULE_network_SOURCES
set(MODULE_benchmark_SOURCES_GTKANY
modules/benchmark.c
modules/benchmark/blowfish.c
modules/benchmark/blowfish2.c
modules/benchmark/cryptohash.c
modules/benchmark/drawing.c
modules/benchmark/fbench.c
Expand Down
27 changes: 27 additions & 0 deletions data/benchmark.conf
Expand Up @@ -321,3 +321,30 @@ PowerPC 740/750=58.07682|280.00 MHz|Unknown
PowerPC 740/750=2150.597408|280.00 MHz|Unknown
2_0___X370_SLI_PLUS_(MS_7A33)_(Micro_Star_International_Co___Ltd_);AMD_Ryzen_5_1600_Six_Core_Processor;38400_00 = 1.904608; 2.047665; 12|12|2.0 / X370 SLI PLUS (MS-7A33) (Micro-Star International Co., Ltd.)|AMD Ryzen 5 1600 Six-Core Processor|1 physical processor; 6 cores; 12 threads|12x 3200.00 MHz|16377260|1|6|12|AMD Radeon (TM) R9 390 Series (HAWAII, DRM 3.26.0, 4.18.0, LLVM 6.0.1)|AMD/ATI Hawaii PRO + NVIDIA GeForce GTX 750
[GPU Drawing]

[CPU Blowfish (Single-thread)]
ASUS_PRIME_B350_PLUS;AMD_Ryzen_5_1600_Six_Core_Processor;38400_00 = 9.200000; 7.000093; 1|1|ASUS PRIME B350-PLUS|AMD Ryzen 5 1600 Six-Core Processor|1 physical processor; 6 cores; 12 threads|12x 3200.00 MHz|16423384|1|6|12|Radeon RX 560 Series (POLARIS11, DRM 3.26.0, 4.18.0-10-generic, LLVM 7.0.0)|AMD/ATI Baffin
Gigabyte_GA_MA770T_UD3P;AMD_Phenom(tm)_II_X2_550_Processor;6200_00 = 9.130000; 7.000164; 1|1|Gigabyte GA-MA770T-UD3P|AMD Phenom(tm) II X2 550 Processor|1 physical processor; 2 cores; 2 threads|2x 3100.00 MHz|16425960|1|2|2|llvmpipe (LLVM 6.0, 128 bits)|AMD/ATI Caicos XT
ZOTAC_ZBOXNANO_AD12;AMD_E2_1800_APU_with_Radeon(tm)_HD_Graphics;3400_00 = 3.910000; 7.000503; 1|1|ZOTAC ZBOXNANO-AD12|AMD E2-1800 APU with Radeon(tm) HD Graphics|1 physical processor; 2 cores; 2 threads|2x 1700.00 MHz|1741052|1|2|2|llvmpipe (LLVM 6.0, 128 bits)|AMD/ATI Wrestler
Raspberry_Pi_Model_B_Rev_1;Broadcom_BCM2835;900_00 = 1.430000; 7.000866; 1|1|Raspberry Pi Model B Rev 1|Broadcom BCM2835|1x ARM ARM1176 r0p7 (AArch32)|1x 900.00 MHz|233612|1|1|1||Broadcom VideoCore IV
Raspberry_Pi_2_Model_B_Rev_1_1;Broadcom_BCM2836;3600_00 = 1.770000; 7.000509; 1|1|Raspberry Pi 2 Model B Rev 1.1|Broadcom BCM2836|4x ARM Cortex-A7 MPCore r0p5 (AArch32)|4x 900.00 MHz|948952|1|4|4|Gallium 0.4 on llvmpipe (LLVM 3.9, 128 bits)|Broadcom VideoCore IV
Raspberry_Pi_3_Model_B_Plus_Rev_1_3;Broadcom_BCM2837;5600_00 = 3.130000; 7.000431; 1|1|Raspberry Pi 3 Model B Plus Rev 1.3|Broadcom BCM2837|4x ARM Cortex-A53 r0p4 (AArch32)|4x 1400.00 MHz|948952|1|4|4|Gallium 0.4 on llvmpipe (LLVM 3.9, 128 bits)|Broadcom VideoCore IV
Firefly_ROC_RK3328_CC;Rockchip_RK3328;5568_00 = 2.580000; 7.000278; 1|1|Firefly ROC-RK3328-CC|Rockchip RK3328|4x ARM Cortex-A53 r0p4 (AArch64)|4x 1392.00 MHz|946208|1|4|4||ARM Mali 450

[CPU Blowfish (Multi-thread)]
ASUS_PRIME_B350_PLUS;AMD_Ryzen_5_1600_Six_Core_Processor;38400_00 = 105.7600000 7.000394; 12|12|ASUS PRIME B350-PLUS|AMD Ryzen 5 1600 Six-Core Processor|1 physical processor; 6 cores; 12 threads|12x 3200.00 MHz|16423384|1|6|12|Radeon RX 560 Series (POLARIS11, DRM 3.26.0, 4.18.0-10-generic, LLVM 7.0.0)|AMD/ATI Baffin
Gigabyte_GA_MA770T_UD3P;AMD_Phenom(tm)_II_X2_550_Processor;6200_00 = 18.290000; 7.000137; 2|2|Gigabyte GA-MA770T-UD3P|AMD Phenom(tm) II X2 550 Processor|1 physical processor; 2 cores; 2 threads|2x 3100.00 MHz|16425960|1|2|2|llvmpipe (LLVM 6.0, 128 bits)|AMD/ATI Caicos XT
ZOTAC_ZBOXNANO_AD12;AMD_E2_1800_APU_with_Radeon(tm)_HD_Graphics;3400_00 = 7.800000; 7.000371; 2|2|ZOTAC ZBOXNANO-AD12|AMD E2-1800 APU with Radeon(tm) HD Graphics|1 physical processor; 2 cores; 2 threads|2x 1700.00 MHz|1741052|1|2|2|llvmpipe (LLVM 6.0, 128 bits)|AMD/ATI Wrestler
Raspberry_Pi_Model_B_Rev_1;Broadcom_BCM2835;900_00 = 1.430000; 7.000891; 1|1|Raspberry Pi Model B Rev 1|Broadcom BCM2835|1x ARM ARM1176 r0p7 (AArch32)|1x 900.00 MHz|233612|1|1|1||Broadcom VideoCore IV
Raspberry_Pi_2_Model_B_Rev_1_1;Broadcom_BCM2836;3600_00 = 7.010000; 7.001122; 4|4|Raspberry Pi 2 Model B Rev 1.1|Broadcom BCM2836|4x ARM Cortex-A7 MPCore r0p5 (AArch32)|4x 900.00 MHz|948952|1|4|4|Gallium 0.4 on llvmpipe (LLVM 3.9, 128 bits)|Broadcom VideoCore IV
Raspberry_Pi_3_Model_B_Plus_Rev_1_3;Broadcom_BCM2837;5600_00 = 12.430000; 7.000546; 4|4|Raspberry Pi 3 Model B Plus Rev 1.3|Broadcom BCM2837|4x ARM Cortex-A53 r0p4 (AArch32)|4x 1400.00 MHz|948952|1|4|4|Gallium 0.4 on llvmpipe (LLVM 3.9, 128 bits)|Broadcom VideoCore IV
Firefly_ROC_RK3328_CC;Rockchip_RK3328;5568_00 = 11.820000; 7.000721; 4|4|Firefly ROC-RK3328-CC|Rockchip RK3328|4x ARM Cortex-A53 r0p4 (AArch64)|4x 1392.00 MHz|946208|1|4|4||ARM Mali 450

[CPU Blowfish (Multi-core)]
ASUS_PRIME_B350_PLUS;AMD_Ryzen_5_1600_Six_Core_Processor;38400_00 = 55.190000; 7.000318; 6|6|ASUS PRIME B350-PLUS|AMD Ryzen 5 1600 Six-Core Processor|1 physical processor; 6 cores; 12 threads|12x 3200.00 MHz|16423384|1|6|12|Radeon RX 560 Series (POLARIS11, DRM 3.26.0, 4.18.0-10-generic, LLVM 7.0.0)|AMD/ATI Baffin
Gigabyte_GA_MA770T_UD3P;AMD_Phenom(tm)_II_X2_550_Processor;6200_00 = 18.310000; 7.000139; 2|2|Gigabyte GA-MA770T-UD3P|AMD Phenom(tm) II X2 550 Processor|1 physical processor; 2 cores; 2 threads|2x 3100.00 MHz|16425960|1|2|2|llvmpipe (LLVM 6.0, 128 bits)|AMD/ATI Caicos XT
ZOTAC_ZBOXNANO_AD12;AMD_E2_1800_APU_with_Radeon(tm)_HD_Graphics;3400_00 = 7.830000; 7.000439; 2|2|ZOTAC ZBOXNANO-AD12|AMD E2-1800 APU with Radeon(tm) HD Graphics|1 physical processor; 2 cores; 2 threads|2x 1700.00 MHz|1741052|1|2|2|llvmpipe (LLVM 6.0, 128 bits)|AMD/ATI Wrestler
Raspberry_Pi_Model_B_Rev_1;Broadcom_BCM2835;900_00 = 1.430000; 7.000889; 1|1|Raspberry Pi Model B Rev 1|Broadcom BCM2835|1x ARM ARM1176 r0p7 (AArch32)|1x 900.00 MHz|233612|1|1|1||Broadcom VideoCore IV
Raspberry_Pi_2_Model_B_Rev_1_1;Broadcom_BCM2836;3600_00 = 6.940000; 7.001310; 4|4|Raspberry Pi 2 Model B Rev 1.1|Broadcom BCM2836|4x ARM Cortex-A7 MPCore r0p5 (AArch32)|4x 900.00 MHz|948952|1|4|4|Gallium 0.4 on llvmpipe (LLVM 3.9, 128 bits)|Broadcom VideoCore IV
Raspberry_Pi_3_Model_B_Plus_Rev_1_3;Broadcom_BCM2837;5600_00 = 12.440000; 7.000483; 4|4|Raspberry Pi 3 Model B Plus Rev 1.3|Broadcom BCM2837|4x ARM Cortex-A53 r0p4 (AArch32)|4x 1400.00 MHz|948952|1|4|4|Gallium 0.4 on llvmpipe (LLVM 3.9, 128 bits)|Broadcom VideoCore IV
Firefly_ROC_RK3328_CC;Rockchip_RK3328;5568_00 = 11.720000; 7.000391; 4|4|Firefly ROC-RK3328-CC|Rockchip RK3328|4x ARM Cortex-A53 r0p4 (AArch64)|4x 1392.00 MHz|946208|1|4|4||ARM Mali 450
8 changes: 6 additions & 2 deletions includes/benchmark.h
Expand Up @@ -6,7 +6,9 @@
extern ProgramParameters params;

enum {
BENCHMARK_BLOWFISH,
BENCHMARK_BLOWFISH_SINGLE,
BENCHMARK_BLOWFISH_THREADS,
BENCHMARK_BLOWFISH_CORES,
BENCHMARK_CRYPTOHASH,
BENCHMARK_FIB,
BENCHMARK_NQUEENS,
Expand All @@ -17,7 +19,9 @@ enum {
BENCHMARK_N_ENTRIES
} BenchmarkEntries;

void benchmark_bfish(void);
void benchmark_bfish_single(void);
void benchmark_bfish_threads(void);
void benchmark_bfish_cores(void);
void benchmark_cryptohash(void);
void benchmark_fft(void);
void benchmark_fib(void);
Expand Down
6 changes: 4 additions & 2 deletions modules/benchmark/bench_results.c
Expand Up @@ -377,6 +377,7 @@ static char *bench_result_more_info_less(bench_result *b) {

char *ret = g_strdup_printf("[%s]\n"
/* threads */ "%s=%d\n"
/* elapsed */ "%s=%0.4f %s\n"
/* legacy */ "%s=%s\n"
"[%s]\n"
/* board */ "%s=%s\n"
Expand All @@ -389,6 +390,7 @@ static char *bench_result_more_info_less(bench_result *b) {
/* mem */ "%s=%s\n",
_("Benchmark Result"),
_("Threads"), b->bvalue.threads_used,
_("Elapsed Time"), b->bvalue.elapsed_time, _("seconds"),
b->legacy ? _("Note") : "#Note",
b->legacy ? _("This result is from an old version of HardInfo. Results might not be comparable to current version. Some details are missing.") : "",
_("Machine"),
Expand All @@ -410,7 +412,7 @@ static char *bench_result_more_info_complete(bench_result *b) {
/* bench name */"%s=%s\n"
/* threads */ "%s=%d\n"
/* result */ "%s=%0.2f\n"
/* elapsed */ "%s=%0.2f\n"
/* elapsed */ "%s=%0.4f %s\n"
/* legacy */ "%s=%s\n"
"[%s]\n"
/* board */ "%s=%s\n"
Expand All @@ -428,7 +430,7 @@ static char *bench_result_more_info_complete(bench_result *b) {
_("Benchmark"), b->name,
_("Threads"), b->bvalue.threads_used,
_("Result"), b->bvalue.result,
_("Elapsed Time"), b->bvalue.elapsed_time,
_("Elapsed Time"), b->bvalue.elapsed_time, _("seconds"),
b->legacy ? _("Note") : "#Note",
b->legacy ? _("This result is from an old version of HardInfo. Results might not be comparable to current version. Some details are missing.") : "",
_("Machine"),
Expand Down
16 changes: 12 additions & 4 deletions modules/benchmark/benches.c
Expand Up @@ -30,7 +30,9 @@ BENCH_CALLBACK(callback_gui, "GPU Drawing", BENCHMARK_GUI, 1);
BENCH_CALLBACK(callback_fft, "FPU FFT", BENCHMARK_FFT, 0);
BENCH_CALLBACK(callback_nqueens, "CPU N-Queens", BENCHMARK_NQUEENS, 0);
BENCH_CALLBACK(callback_raytr, "FPU Raytracing", BENCHMARK_RAYTRACE, 0);
BENCH_CALLBACK(callback_bfsh, "CPU Blowfish", BENCHMARK_BLOWFISH, 0);
BENCH_CALLBACK(callback_bfsh_single, "CPU Blowfish (Single-thread)", BENCHMARK_BLOWFISH_SINGLE, 0);
BENCH_CALLBACK(callback_bfsh_threads, "CPU Blowfish (Multi-thread)", BENCHMARK_BLOWFISH_THREADS, 0);
BENCH_CALLBACK(callback_bfsh_cores, "CPU Blowfish (Multi-core)", BENCHMARK_BLOWFISH_CORES, 0);
BENCH_CALLBACK(callback_cryptohash, "CPU CryptoHash", BENCHMARK_CRYPTOHASH, 1);
BENCH_CALLBACK(callback_fib, "CPU Fibonacci", BENCHMARK_FIB, 0);
BENCH_CALLBACK(callback_zlib, "CPU Zlib", BENCHMARK_ZLIB, 0);
Expand All @@ -45,7 +47,9 @@ void SN(gboolean reload) { \
BENCH_SCAN_SIMPLE(scan_fft, benchmark_fft, BENCHMARK_FFT);
BENCH_SCAN_SIMPLE(scan_nqueens, benchmark_nqueens, BENCHMARK_NQUEENS);
BENCH_SCAN_SIMPLE(scan_raytr, benchmark_raytrace, BENCHMARK_RAYTRACE);
BENCH_SCAN_SIMPLE(scan_bfsh, benchmark_fish, BENCHMARK_BLOWFISH);
BENCH_SCAN_SIMPLE(scan_bfsh_single, benchmark_bfish_single, BENCHMARK_BLOWFISH_SINGLE);
BENCH_SCAN_SIMPLE(scan_bfsh_threads, benchmark_bfish_threads, BENCHMARK_BLOWFISH_THREADS);
BENCH_SCAN_SIMPLE(scan_bfsh_cores, benchmark_bfish_cores, BENCHMARK_BLOWFISH_CORES);
BENCH_SCAN_SIMPLE(scan_cryptohash, benchmark_cryptohash, BENCHMARK_CRYPTOHASH);
BENCH_SCAN_SIMPLE(scan_fib, benchmark_fib, BENCHMARK_FIB);
BENCH_SCAN_SIMPLE(scan_zlib, benchmark_zlib, BENCHMARK_ZLIB);
Expand All @@ -71,7 +75,9 @@ void scan_gui(gboolean reload)
}

static ModuleEntry entries[] = {
{N_("CPU Blowfish"), "blowfish.png", callback_bfsh, scan_bfsh, MODULE_FLAG_NONE},
{N_("CPU Blowfish (Single-thread)"), "blowfish.png", callback_bfsh_single, scan_bfsh_single, MODULE_FLAG_NONE},
{N_("CPU Blowfish (Multi-thread)"), "blowfish.png", callback_bfsh_threads, scan_bfsh_threads, MODULE_FLAG_NONE},
{N_("CPU Blowfish (Multi-core)"), "blowfish.png", callback_bfsh_cores, scan_bfsh_cores, MODULE_FLAG_NONE},
{N_("CPU CryptoHash"), "cryptohash.png", callback_cryptohash, scan_cryptohash, MODULE_FLAG_NONE},
{N_("CPU Fibonacci"), "nautilus.png", callback_fib, scan_fib, MODULE_FLAG_NONE},
{N_("CPU N-Queens"), "nqueens.png", callback_nqueens, scan_nqueens, MODULE_FLAG_NONE},
Expand All @@ -90,13 +96,15 @@ const gchar *hi_note_func(gint entry)
case BENCHMARK_CRYPTOHASH:
return _("Results in MiB/second. Higher is better.");

case BENCHMARK_BLOWFISH_SINGLE:
case BENCHMARK_BLOWFISH_THREADS:
case BENCHMARK_BLOWFISH_CORES:
case BENCHMARK_ZLIB:
case BENCHMARK_GUI:
return _("Results in HIMarks. Higher is better.");

case BENCHMARK_FFT:
case BENCHMARK_RAYTRACE:
case BENCHMARK_BLOWFISH:
case BENCHMARK_FIB:
case BENCHMARK_NQUEENS:
return _("Results in seconds. Lower is better.");
Expand Down
45 changes: 0 additions & 45 deletions modules/benchmark/blowfish.c
Expand Up @@ -491,48 +491,3 @@ void Blowfish_Init(BLOWFISH_CTX * ctx, unsigned char *key, int keyLen)
}
}
}

static gpointer
parallel_blowfish(unsigned int start, unsigned int end, void *data, gint thread_number)
{
BLOWFISH_CTX ctx;
unsigned int i;
unsigned long L, R;

L = 0xBEBACAFE;
R = 0xDEADBEEF;

for (i = start; i <= end; i++) {
Blowfish_Init(&ctx, (unsigned char*)data, 65536);
Blowfish_Encrypt(&ctx, &L, &R);
Blowfish_Decrypt(&ctx, &L, &R);
}

return NULL;
}

void
benchmark_fish(void)
{
bench_value r = EMPTY_BENCH_VALUE;

gchar *tmpsrc;
gchar *bdata_path;

bdata_path = g_build_filename(params.path_data, "benchmark.data", NULL);
if (!g_file_get_contents(bdata_path, &tmpsrc, NULL, NULL)) {
bench_results[BENCHMARK_BLOWFISH] = r;
g_free(bdata_path);
return;
}

shell_view_set_enabled(FALSE);
shell_status_update("Performing Blowfish benchmark...");

r = benchmark_parallel_for(0, 0, 50000, parallel_blowfish, tmpsrc);
r.result = r.elapsed_time;

bench_results[BENCHMARK_BLOWFISH] = r;
g_free(bdata_path);
g_free(tmpsrc);
}
86 changes: 86 additions & 0 deletions modules/benchmark/blowfish2.c
@@ -0,0 +1,86 @@
/*
* HardInfo - Displays System Information
* Copyright (C) 2003-2017 Leandro A. F. Pereira <leandro@hardinfo.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 2.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/

#include "hardinfo.h"
#include "benchmark.h"
#include "blowfish.h"

#define CRUNCH_TIME 7

/* must be less than or equal to
* file size of ( params.path_data + "benchmark.data" ) */
#define BENCH_DATA_SIZE 65536

static gpointer bfish_exec(void *in_data, gint thread_number)
{
unsigned char key[] = "Has my shampoo arrived?";
unsigned char *data = NULL;
unsigned long data_len = BENCH_DATA_SIZE, i = 0;
BLOWFISH_CTX ctx;

data = malloc(BENCH_DATA_SIZE);
memcpy(data, in_data, BENCH_DATA_SIZE);

Blowfish_Init(&ctx, key, strlen(key));
for(i = 0; i < data_len; i += 8) {
Blowfish_Encrypt(&ctx, (unsigned long*)&data[i], (unsigned long*)&data[i+4]);
}
for(i = 0; i < data_len; i += 8) {
Blowfish_Decrypt(&ctx, (unsigned long*)&data[i], (unsigned long*)&data[i+4]);
}

free(data);
return NULL;
}

static gchar *get_data()
{
gchar *tmpsrc, *bdata_path;
gsize length;

bdata_path = g_build_filename(params.path_data, "benchmark.data", NULL);
if (!g_file_get_contents(bdata_path, &tmpsrc, &length, NULL)) {
g_free(bdata_path);
return NULL;
}
if (length < BENCH_DATA_SIZE) {
g_free(tmpsrc);
return NULL;
}

return tmpsrc;
}

void benchmark_bfish_do(int threads, int entry, const char *status)
{
bench_value r = EMPTY_BENCH_VALUE;
gchar *test_data = get_data();

shell_view_set_enabled(FALSE);
shell_status_update(status);

r = benchmark_crunch_for(CRUNCH_TIME, threads, bfish_exec, test_data);
r.result /= 100;
bench_results[entry] = r;

g_free(test_data);
}

void benchmark_bfish_threads(void) { benchmark_bfish_do(0, BENCHMARK_BLOWFISH_THREADS, "Performing Blowfish benchmark (multi-thread)..."); }
void benchmark_bfish_single(void) { benchmark_bfish_do(1, BENCHMARK_BLOWFISH_SINGLE, "Performing Blowfish benchmark (single-thread)..."); }
void benchmark_bfish_cores(void) { benchmark_bfish_do(-1, BENCHMARK_BLOWFISH_CORES, "Performing Blowfish benchmark (multi-core)..."); }

0 comments on commit d5d0607

Please sign in to comment.