summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/sysinfo/benchmarkinfo.cpp96
-rw-r--r--noncore/settings/sysinfo/benchmarkinfo.h7
2 files changed, 31 insertions, 72 deletions
diff --git a/noncore/settings/sysinfo/benchmarkinfo.cpp b/noncore/settings/sysinfo/benchmarkinfo.cpp
index 3dd4121..69d8229 100644
--- a/noncore/settings/sysinfo/benchmarkinfo.cpp
+++ b/noncore/settings/sysinfo/benchmarkinfo.cpp
@@ -16,8 +16,9 @@
**
**********************************************************************/
/* OPIE */
+#include <opie2/ostorageinfo.h>
#include <qpe/qpeapplication.h>
#include <qpe/qcopenvelope_qws.h>
#include <qpe/qpedecoration_qws.h>
#include <qpe/resource.h>
@@ -52,8 +53,11 @@ extern "C"
#define DHRYSTONE_RUNS 20000000
#define TEST_DURATION 3
+#define BUFF_SIZE 8192
+#define FILE_SIZE 1024 * 1024 // 1Mb
+
//===========================================================================
class BenchmarkPaintWidget : public QWidget
{
@@ -153,41 +157,25 @@ void BenchmarkInfo::run()
test_gfx->setText( 1, QString( "%1 gops/sec" ).arg( QString::number( value / 4 / TEST_DURATION ) ) ); // 4 tests
test_gfx->setOn( false );
}
- if ( test_ram->isOn() )
+ if ( test_ram->isOn() ) // /tmp is supposed to be in RAM on a PDA
{
- t.start();
- writeFile( "/tmp/benchmarkFile.dat" ); // /tmp is supposed to be in RAM on a PDA
- readFile( "/tmp/benchmarkFile.dat" );
- QFile::remove( "/tmp/benchmarkFile.dat" );
- test_ram->setText( 1, QString( "%1 secs" ).arg( QString::number( t.elapsed() / 1000.0 ) ) );
- test_ram->setOn( false );
+ performFileTest( "/tmp/benchmarkFile.dat", test_ram );
}
-/*
+
if ( test_cf->isOn() )
{
- t.start();
- benchInteger();
- test_alu->setText( 1, QString( "%1 secs" ).arg( QString::number( t.elapsed() / 1000.0 ) ) );
- test_alu->setOn( false );
+ OStorageInfo storage;
+ performFileTest( storage.cfPath() + "/benchmarkFile.dat", test_cf );
}
if ( test_sd->isOn() )
{
- t.start();
- benchInteger();
- test_alu->setText( 1, QString( "%1 secs" ).arg( QString::number( t.elapsed() / 1000.0 ) ) );
- test_alu->setOn( false );
+ OStorageInfo storage;
+ performFileTest( storage.sdPath() + "/benchmarkFile.dat", test_sd );
}
- if ( ( which_clipb ) && ( buf.length() > 0 ) )
- {
- clb = QApplication::clipboard();
- clb->setText( dt_buf + buf );
- }
- */
-
startButton->setText( tr( "&Start Tests!" ) );
}
@@ -287,14 +275,24 @@ int BenchmarkInfo::gfxRendering( int seconds )
return loops;
}
-// **********************************************************************
-// Read & Write
-// v2.0.0
-// **********************************************************************
-#define BUFF_SIZE 8192
-#define FILE_SIZE 1024 * 1024 // 1Mb
+void BenchmarkInfo::performFileTest( const QString& fname, QCheckListItem* item )
+{
+ QTime time;
+ time.start();
+ if ( writeFile( fname ) &&
+ readFile( fname ) )
+ {
+ QFile::remove( fname );
+ item->setText( 1, QString( "%1 kb/sec" ).arg( QString::number( 1024.0 / ( time.elapsed() / 1000.0 ) ) ) );
+ item->setOn( false );
+ }
+ else
+ {
+ item->setText( 1, tr( "error" ) );
+ }
+}
char FileBuf[ BUFF_SIZE + 1 ];
bool BenchmarkInfo::writeFile( const QString& w_path )
@@ -362,49 +360,9 @@ bool BenchmarkInfo::writeFile( const QString& w_path )
}
writeFile.close();
}
return ( true );
- // ------------------------------------*/
-
- /* ----------------------------------
- srand( time( NULL ) );
- FILE *fp;
-
- for( n= 0 ; n < 40 ; n++ )
- {
- if (( fp = fopen( w_path, "wt" )) == NULL )
- return( false );
- memset( FileBuf, '\0', BUFF_SIZE+1 );
- // ------------------------------------------ sequential write
- for( i= 0 ; i < FILE_SIZE / BUFF_SIZE ; i++ )
- {
- for( k= 0 ; k < 128 ; k++ )
- {
- n = rand() % 30;
- memcpy( &FileBuf[k*8], &data[n], 32 );
- }
- fputs( FileBuf, fp );
- }
- // ------------------------------------------ random write
- for( i= 0 ; i < 300 ; i++ )
- {
- memset( FileBuf, '\0', 130 );
- len = rand() % 120 + 8;
- for( k= 0 ; k < 16 ; k++ )
- {
- n = rand() % 54;
- memcpy( &FileBuf[k*8], &data[n], 8 );
- }
- pos = rand() % ( FILE_SIZE / BUFF_SIZE - BUFF_SIZE );
-
- fseek( fp, pos, SEEK_SET );
- fputs( FileBuf, fp );
- }
- fclose( fp );
- }
- return( true );
- -------------------------------------*/
}
bool BenchmarkInfo::readFile( const QString& r_path )
diff --git a/noncore/settings/sysinfo/benchmarkinfo.h b/noncore/settings/sysinfo/benchmarkinfo.h
index 55398eb..3c5ca37 100644
--- a/noncore/settings/sysinfo/benchmarkinfo.h
+++ b/noncore/settings/sysinfo/benchmarkinfo.h
@@ -53,11 +53,12 @@ public:
QPushButton* startButton;
int textRendering( int );
int gfxRendering( int );
- bool writeFile( const QString& );
- bool readFile( const QString& );
+ void performFileTest( const QString& fname, QCheckListItem* item );
private slots:
+ bool writeFile( const QString& );
+ bool readFile( const QString& );
void run();
-
};
+