From e9d69db8341ee7452ce4e8f8dc54e972b0390bfe Mon Sep 17 00:00:00 2001 From: Leandro Pereira Date: Sun, 2 Jul 2017 22:12:10 -0700 Subject: [PATCH] Add zlib benchmark --- CMakeLists.txt | 5 +++ includes/benchmark.h | 2 ++ modules/benchmark.c | 17 ++++++++++ modules/benchmark/zlib.c | 71 +++++++++++++++++++++++++++++++++++++++ pixmaps/file-roller.png | Bin 0 -> 1444 bytes 5 files changed, 95 insertions(+) create mode 100644 modules/benchmark/zlib.c create mode 100644 pixmaps/file-roller.png diff --git a/CMakeLists.txt b/CMakeLists.txt index ae29a99e8..d0665ac9f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -59,6 +59,8 @@ if(NOT HARDINFO_NOSYNC) pkg_check_modules(LIBSOUP libsoup-2.4>=2.24) endif() +include(FindZLIB REQUIRED) + include_directories( ${CMAKE_SOURCE_DIR} ${CMAKE_SOURCE_DIR}/includes @@ -66,6 +68,7 @@ include_directories( ${CMAKE_BINARY_DIR} ${GTK_INCLUDE_DIRS} ${LIBSOUP_INCLUDE_DIRS} + ${ZLIB_INCLUDE_DIRS} ) link_directories( ${GTK_LIBRARY_DIRS} @@ -134,6 +137,7 @@ set(MODULE_benchmark_SOURCES modules/benchmark/nqueens.c modules/benchmark/raytrace.c modules/benchmark/sha1.c + modules/benchmark/zlib.c ) set_source_files_properties( @@ -173,6 +177,7 @@ target_link_libraries(hardinfo ${LIBSOUP_LIBRARIES} hardinfo-shell m + ${ZLIB_LIBRARIES} ) configure_file(config.h.cmake ${CMAKE_BINARY_DIR}/config.h @ONLY) diff --git a/includes/benchmark.h b/includes/benchmark.h index 8047d5c6d..39de042bb 100644 --- a/includes/benchmark.h +++ b/includes/benchmark.h @@ -10,6 +10,7 @@ enum { BENCHMARK_CRYPTOHASH, BENCHMARK_FIB, BENCHMARK_NQUEENS, + BENCHMARK_ZLIB, BENCHMARK_FFT, BENCHMARK_RAYTRACE, BENCHMARK_GUI, @@ -24,6 +25,7 @@ void benchmark_fish(void); void benchmark_gui(void); void benchmark_nqueens(void); void benchmark_raytrace(void); +void benchmark_zlib(void); gdouble benchmark_parallel_for(guint start, guint end, gpointer callback, gpointer callback_data); diff --git a/modules/benchmark.c b/modules/benchmark.c index 94997df83..de9e67c38 100644 --- a/modules/benchmark.c +++ b/modules/benchmark.c @@ -36,6 +36,7 @@ void scan_bfsh(gboolean reload); void scan_cryptohash(gboolean reload); void scan_fib(gboolean reload); void scan_nqueens(gboolean reload); +void scan_zlib(gboolean reload); void scan_gui(gboolean reload); gchar *callback_fft(); @@ -44,6 +45,7 @@ gchar *callback_bfsh(); gchar *callback_fib(); gchar *callback_cryptohash(); gchar *callback_nqueens(); +gchar *callback_zlib(); gchar *callback_gui(); static ModuleEntry entries[] = { @@ -51,6 +53,7 @@ static ModuleEntry entries[] = { {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}, + {N_("CPU Zlib"), "module.png", callback_zlib, scan_zlib, MODULE_FLAG_NONE}, {N_("FPU FFT"), "fft.png", callback_fft, scan_fft, MODULE_FLAG_NONE}, {N_("FPU Raytracing"), "raytrace.png", callback_raytr, scan_raytr, MODULE_FLAG_NONE}, {N_("GPU Drawing"), "module.png", callback_gui, scan_gui, MODULE_FLAG_NO_REMOTE}, @@ -306,6 +309,12 @@ gchar *callback_fib() "CPU Fibonacci"); } +gchar *callback_zlib() +{ + return benchmark_include_results(bench_results[BENCHMARK_ZLIB], + "CPU Zlib"); +} + typedef struct _BenchmarkDialog BenchmarkDialog; struct _BenchmarkDialog { GtkWidget *dialog; @@ -504,12 +513,20 @@ void scan_fib(gboolean reload) SCAN_END(); } +void scan_zlib(gboolean reload) +{ + SCAN_START(); + do_benchmark(benchmark_zlib, BENCHMARK_ZLIB); + SCAN_END(); +} + const gchar *hi_note_func(gint entry) { switch (entry) { case BENCHMARK_CRYPTOHASH: return _("Results in MiB/second. Higher is better."); + case BENCHMARK_ZLIB: case BENCHMARK_GUI: return _("Results in HIMarks. Higher is better."); diff --git a/modules/benchmark/zlib.c b/modules/benchmark/zlib.c new file mode 100644 index 000000000..eeec9d0e4 --- /dev/null +++ b/modules/benchmark/zlib.c @@ -0,0 +1,71 @@ +/* + * HardInfo - Displays System Information + * Copyright (C) 2017 Leandro A. F. Pereira + * + * 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 +#include +#include + +#include "benchmark.h" + +static gpointer zlib_for(unsigned int start, unsigned int end, void *data, gint thread_number) +{ + char *compressed; + uLong bound = compressBound(bound); + unsigned int i; + + compressed = malloc(bound); + if (!compressed) + return NULL; + + for (i = start; i <= end; i++) { + char uncompressed[65536]; + uLong compressedBound = bound; + uLong destBound = sizeof(uncompressed); + + compress(compressed, &compressedBound, data, 65536); + uncompress(uncompressed, &destBound, compressed, compressedBound); + } + + free(compressed); + + return NULL; +} + +void +benchmark_zlib(void) +{ + gdouble elapsed = 0; + gchar *tmpsrc, *bdata_path; + + bdata_path = g_build_filename(params.path_data, "benchmark.data", NULL); + if (!g_file_get_contents(bdata_path, &tmpsrc, NULL, NULL)) { + g_free(bdata_path); + return; + } + + shell_view_set_enabled(FALSE); + shell_status_update("Running Zlib benchmark..."); + + elapsed = benchmark_parallel_for(0, 50000, zlib_for, tmpsrc); + + g_free(bdata_path); + g_free(tmpsrc); + + gdouble marks = (50000. * 65536.) / (elapsed * 840205128.); + bench_results[BENCHMARK_ZLIB] = marks; +} diff --git a/pixmaps/file-roller.png b/pixmaps/file-roller.png new file mode 100644 index 0000000000000000000000000000000000000000..5c17e91b5ae3c4845b8e09b525a089a461d94db8 GIT binary patch literal 1444 zcmV;V1zY-wP)V=-L}_z$a%p09X>?^| zAa!nJWpW^NXk{RDWpZtEAa7NE7x6HBLDyZ7<5HgbVG7wVRUJ4ZXi@? zZDjy5FflPLFf%PNHiND7J^%m&en~_@R7i=vm0xUARUF5^=k~U}?MCVTlx~xDf7g6SX@%F z8=zklR+7^~GTD}UGx`1gf>RnA>i6E|`6DNfA4kCN1E2Z}Zdcho?Y(#RqS(%1Xk;W9 z@YU>dSFM1Rz-7u-YCB2JHZBK!F;BHUv)_ z)bP*DPU~v|wKhc%D<7&4HSNwC`e&Y%USn`@=oV057ipU2-v0axp1$5*o`5;{&{P2! zRDaVS2$(uAcBlmCe<&anYT9kL+pEVXZh{bUr>`$^q9DL9D(Y(MSW%K(%E&{^gF!}Jn2k&gz^kmWHtC#TFt8Mog1AwmUINbgTTAEvtN~Lh6 z`!YmHgkc!?_53+Z-kv;`uV1Xe&Rsj72(1rQsj3Q4KokW?k_cIrpeQmj83nqoV(gDm z1RI-BUS1AC6fiS04Oh7f9*-BGlvu6Yz9lnQYwGD3`f1oSOc;OwpLU-?u(1gZ&%6$X zAs~c-!{IBnGbjh|%6(KnMU3uq6TLW+#X;hpjEIfMr=!xGPapQ;YHOaS#Hqtl7F`28?hE zl9YxZqybQ@-L?xgn|44|^#uimrYTTl9+3-Qqk8p5uq+Ev6ftpg0-1~omSv%;s=Op1 ztI3&Ua-K``^8f|r=Vw53gOn~H02}8(Mo}<%dkQSeBBLsZ4Mf3lR+vmIBvG7N5@4Zo zsj1;B4iuLWP0cJA(%j+~pPfz}7F!V}qZd$9yBSlrC$Ze=fXCy-;6O~%HF>Vpb#a*J z@>f46TMjH<*FM{*n=rO5jKyY}=Xpqy09h6x%K~IMx1$6klLP?KrVgbXjFk7rJ zn>m=x94uxlEM_Z|i~@^=1z{w}QXIUH0K>?rs8~kLM5EHRQ#bdW5t{*I@=x;ekI(Y$ zZBO?pfj@h