summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/sysinfo/benchmarkinfo.cpp94
-rw-r--r--noncore/settings/sysinfo/benchmarkinfo.h7
-rw-r--r--share/sysinfo/results30
3 files changed, 109 insertions, 22 deletions
diff --git a/noncore/settings/sysinfo/benchmarkinfo.cpp b/noncore/settings/sysinfo/benchmarkinfo.cpp
index 69d8229..0aeb251 100644
--- a/noncore/settings/sysinfo/benchmarkinfo.cpp
+++ b/noncore/settings/sysinfo/benchmarkinfo.cpp
@@ -12,43 +12,44 @@
** packaging of this file.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
**********************************************************************/
/* OPIE */
#include <opie2/ostorageinfo.h>
#include <qpe/qpeapplication.h>
#include <qpe/qcopenvelope_qws.h>
#include <qpe/qpedecoration_qws.h>
#include <qpe/resource.h>
#include <qpe/config.h>
/* QT */
-#include <qlayout.h>
+#include <qclipboard.h>
+#include <qcolor.h>
+#include <qcombobox.h>
+#include <qdirectpainter_qws.h>
+#include <qfile.h>
+#include <qtextstream.h>
#include <qfiledialog.h>
#include <qlabel.h>
+#include <qlayout.h>
#include <qpainter.h>
-#include <qdirectpainter_qws.h>
-#include <qapplication.h>
#include <qpushbutton.h>
-#include <qclipboard.h>
#include <qtimer.h>
-#include <qcolor.h>
-#include <qpushbutton.h>
/* STD */
#include <time.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include "benchmarkinfo.h"
extern "C"
{
void BenchFFT( void );
double dhry_main( int );
}
#define DHRYSTONE_RUNS 20000000
@@ -78,64 +79,115 @@ class BenchmarkPaintWidget : public QWidget
QPainter p;
};
//===========================================================================
BenchmarkInfo::BenchmarkInfo( QWidget *parent, const char *name, int wFlags )
: QWidget( parent, name, wFlags )
{
setMinimumSize( 200, 150 );
QVBoxLayout* vb = new QVBoxLayout( this );
vb->setSpacing( 4 );
vb->setMargin( 4 );
tests = new QListView( this );
- tests->setMargin( 1 );
- tests->addColumn( "Tests" );
- tests->addColumn( "Results" );
+ tests->setMargin( 0 );
+ tests->addColumn( tr( "Tests" ) );
+ tests->addColumn( tr( "Results" ) );
+ tests->addColumn( tr( "Comparison" ) );
tests->setShowSortIndicator( true );
- test_alu = new QCheckListItem( tests, "1: Integer Arithmetic ", QCheckListItem::CheckBox );
+ test_alu = new QCheckListItem( tests, tr( "1. Integer Arithmetic " ), QCheckListItem::CheckBox );
+ test_fpu = new QCheckListItem( tests, tr( "2. Floating Point Unit " ), QCheckListItem::CheckBox );
+ test_txt = new QCheckListItem( tests, tr( "3. Text Rendering " ), QCheckListItem::CheckBox );
+ test_gfx = new QCheckListItem( tests, tr( "4. Gfx Rendering " ), QCheckListItem::CheckBox );
+ test_ram = new QCheckListItem( tests, tr( "5. RAM Performance " ), QCheckListItem::CheckBox );
+ test_sd = new QCheckListItem( tests, tr( "6. SD Card Performance " ), QCheckListItem::CheckBox );
+ test_cf = new QCheckListItem( tests, tr( "7. CF Card Performance " ), QCheckListItem::CheckBox );
+
test_alu->setText( 1, "n/a" );
- test_fpu = new QCheckListItem( tests, "2: Floating Point Unit ", QCheckListItem::CheckBox );
- test_fpu->setText( 1, "n/a" );
- test_txt = new QCheckListItem( tests, "3: Text Rendering ", QCheckListItem::CheckBox );
+ test_fpu->setText( 1, "n/a" );
test_txt->setText( 1, "n/a" );
- test_gfx = new QCheckListItem( tests, "4: Gfx Rendering ", QCheckListItem::CheckBox );
test_gfx->setText( 1, "n/a" );
- test_ram = new QCheckListItem( tests, "5: RAM Performance ", QCheckListItem::CheckBox );
test_ram->setText( 1, "n/a" );
- test_sd = new QCheckListItem( tests, "6: SD Card Performance ", QCheckListItem::CheckBox );
test_sd->setText( 1, "n/a" );
- test_cf = new QCheckListItem( tests, "7: CF Card Performance ", QCheckListItem::CheckBox );
- test_cf->setText( 1, "n/a" );
-
+ test_cf->setText( 1, "n/a" );
+
+ test_alu->setText( 2, "n/a" );
+ test_fpu->setText( 2, "n/a" );
+ test_txt->setText( 2, "n/a" );
+ test_gfx->setText( 2, "n/a" );
+ test_ram->setText( 2, "n/a" );
+ test_sd->setText( 2, "n/a" );
+ test_cf->setText( 2, "n/a" );
+
startButton = new QPushButton( tr( "&Start Tests!" ), this );
connect( startButton, SIGNAL( clicked() ), this, SLOT( run() ) );
-
+
vb->addWidget( tests, 2 );
- vb->addWidget( startButton );
+
+ QFile f( QPEApplication::qpeDir() + "/share/sysinfo/results" );
+ if ( f.open( IO_ReadOnly ) )
+ {
+ machineCombo = new QComboBox( this );
+
+ QTextStream ts( &f );
+ while( !ts.eof() )
+ {
+ QString machline = ts.readLine();
+ qDebug( "sysinfo: parsing benchmark results for '%s'", (const char*) machline );
+ QString resline = ts.readLine();
+ machines.insert( machline, new QStringList( QStringList::split( ",", resline ) ) );
+ machineCombo->insertItem( machline );
+ }
+
+ QHBoxLayout* hb = new QHBoxLayout( vb );
+ hb->addWidget( new QLabel( tr( "Compare To:" ), this ) );
+ hb->addWidget( machineCombo, 2 );
+ connect( machineCombo, SIGNAL( activated( int ) ), this, SLOT( machineActivated( int ) ) );
+ }
+
+ vb->addWidget( startButton, 2 );
}
BenchmarkInfo::~BenchmarkInfo()
{}
+void BenchmarkInfo::machineActivated( int index )
+{
+ QStringList* results = machines[ machineCombo->text( index ) ];
+ if ( !results )
+ {
+ qDebug( "sysinfo: no results available." );
+ return;
+ }
+ QStringList::Iterator it = results->begin();
+ test_alu->setText( 2, *(it++) );
+ test_fpu->setText( 2, *(it++) );
+ test_txt->setText( 2, *(it++) );
+ test_gfx->setText( 2, *(it++) );
+ test_ram->setText( 2, *(it++) );
+ test_sd->setText( 2, *(it++) );
+ test_cf->setText( 2, *(it++) );
+}
+
+
void BenchmarkInfo::run()
{
startButton->setText( "> Don't touch! Running Tests! Don't touch! <" );
qApp->processEvents();
QTime t;
if ( test_alu->isOn() )
{
int d = round( dhry_main( DHRYSTONE_RUNS ) );
test_alu->setText( 1, QString( "%1 dhrys" ).arg( QString::number( d ) ) );
test_alu->setOn( false );
}
if ( test_fpu->isOn() )
{
t.start();
diff --git a/noncore/settings/sysinfo/benchmarkinfo.h b/noncore/settings/sysinfo/benchmarkinfo.h
index 3c5ca37..d143602 100644
--- a/noncore/settings/sysinfo/benchmarkinfo.h
+++ b/noncore/settings/sysinfo/benchmarkinfo.h
@@ -5,60 +5,65 @@
**
** Copyright (C) 2004 Michael Lauer <mickey@vanille.de>
** Inspired by ZBench (C) 2002 Satoshi <af230533@im07.alpha-net.ne.jp>
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
**********************************************************************/
#include <qwidget.h>
#include <qdialog.h>
+#include <qdict.h>
+#include <qstringlist.h>
class QClipboard;
+class QComboBox;
class QCheckListItem;
class QPushButton;
class QListView;
class BenchmarkInfo : public QWidget
{
Q_OBJECT
public:
BenchmarkInfo( QWidget *parent = 0, const char *name = 0, int wFlags = 0 );
~BenchmarkInfo();
QCheckListItem* test_alu;
QCheckListItem* test_fpu;
QCheckListItem* test_txt;
QCheckListItem* test_gfx;
QCheckListItem* test_ram;
QCheckListItem* test_sd;
QCheckListItem* test_cf;
bool main_rd;
bool main_wt;
bool sd_rd;
bool sd_wt;
bool cf_rd;
bool cf_wt;
QClipboard* clb;
-
+ QComboBox* machineCombo;
QListView* tests;
QPushButton* startButton;
+ QDict <QStringList> machines;
int textRendering( int );
int gfxRendering( int );
void performFileTest( const QString& fname, QCheckListItem* item );
private slots:
bool writeFile( const QString& );
bool readFile( const QString& );
void run();
+ void machineActivated( int );
};
diff --git a/share/sysinfo/results b/share/sysinfo/results
new file mode 100644
index 0000000..1866da3
--- a/dev/null
+++ b/share/sysinfo/results
@@ -0,0 +1,30 @@
+<Choose a model>
+n/a,n/a,n/a,n/a,n/a,n/a,n/a,n/a,n/a
+Sharp SL-5500
+240010 dhrys,41.498 sec,88 char/sec,1786 gops/sec,50.123 kb/sec,41.7329 kb/sec,105.873 kb/sec
+Sharp SL-5600
+not,yet,contributed,please,mail,to,opie@handhelds.org
+Sharp C-700
+not,yet,contributed,please,mail,to,opie@handhelds.org
+Sharp C-750
+not,yet,contributed,please,mail,to,opie@handhelds.org
+Sharp C-760
+not,yet,contributed,please,mail,to,opie@handhelds.org
+Sharp C-860
+not,yet,contributed,please,mail,to,opie@handhelds.org
+HP iPAQ 36xx
+not,yet,contributed,please,mail,to,opie@handhelds.org
+HP iPAQ 37xx
+not,yet,contributed,please,mail,to,opie@handhelds.org
+HP iPAQ 38xx
+not,yet,contributed,please,mail,to,opie@handhelds.org
+HP iPAQ 54xx
+not,yet,contributed,please,mail,to,opie@handhelds.org
+HP iPAQ 55xx
+not,yet,contributed,please,mail,to,opie@handhelds.org
+HP Jornada 5x0
+not,yet,contributed,please,mail,to,opie@handhelds.org
+M&N Ramses
+not,yet,contributed,please,mail,to,opie@handhelds.org
+SIEMENS SIMpad
+not,yet,contributed,please,mail,to,opie@handhelds.org