#include <QMaemo5InformationBox>
#endif
-
#define APPNAME "QCPUFreq"
#define APPVERSION "0.3.2"
helperProcess( this ),
//create a new, stackable help window
helpWindow( this ),
+ //set minFreq to 0
+ minFreq(0),
//create UI refresh timer
refreshTimer( this ),
//create a QGraphicsScene for the little chip icon
{
//this is a stacked window on Maemo 5
#if defined(Q_WS_MAEMO_5)
- setAttribute(Qt::WA_Maemo5StackedWindow);
+ setAttribute(Qt::WA_Maemo5StackedWindow);
#endif
ui->setupUi(this);
// initialize stackable help window
#if defined(Q_WS_MAEMO_5)
- helpWindow.setAttribute(Qt::WA_Maemo5StackedWindow);
+ helpWindow.setAttribute(Qt::WA_Maemo5StackedWindow);
#endif
helpWindow.setWindowFlags( windowFlags() | Qt::Window );
//check if we can read a more accurate temperature (only for power kernel)
if (file.exists())
- return QString( readSysFile( "class/power_supply/bq27200-0/temp" ) + " " + QString::fromUtf8("\302\260") + "C" );
+ return QString( readSysFile( "class/power_supply/bq27200-0/temp" ) + " " + QString::fromUtf8("\302\260") + "C" );
else {
- /*
- We actually only need to read the raw temperature, but it appears that by also reading temp1_input
- the raw temperature (temp1_input_raw) is being updated more frequently.
- */
- readSysFile( "devices/platform/omap34xx_temp/temp1_input" );
-
- //read the current system temperature
- QString tstring = readSysFile( "devices/platform/omap34xx_temp/temp1_input_raw" );
- if (tstring == "0")
- return tr( "Unknown" );
-
- //convert it to an integer and calculate the approx. temperature from the raw value
- int tint = tstring.toInt();
- tint = ( 0.65 * tint );
- tstring.setNum(tint);
- return QString( tstring + " " + QString::fromUtf8("\302\260") + "C" );
+ /*
+ We actually only need to read the raw temperature, but it appears that by also reading temp1_input
+ the raw temperature (temp1_input_raw) is being updated more frequently.
+ */
+ readSysFile( "devices/platform/omap34xx_temp/temp1_input" );
+
+ //read the current system temperature
+ QString tstring = readSysFile( "devices/platform/omap34xx_temp/temp1_input_raw" );
+ if (tstring == "0")
+ return tr( "Unknown" );
+
+ //convert it to an integer and calculate the approx. temperature from the raw value
+ int tint = tstring.toInt();
+ tint = ( 0.65 * tint );
+ tstring.setNum(tint);
+ return QString( tstring + " " + QString::fromUtf8("\302\260") + "C" );
}
#endif
return tr( "Unknown" );
*/
int MainWindow::getMinFreq()
{
- QString tmp = readSysFile( "devices/system/cpu/cpu0/cpufreq/scaling_min_freq" );
- return tmp.toInt();
+ if (this->minFreq == 0) {
+ QString min = readSysFile( "devices/system/cpu/cpu0/cpufreq/scaling_min_freq" );
+ //check if avoid file exists (only on power kernel)
+ QFile file( "/sys/devices/system/cpu/cpu0/cpufreq/ondemand/avoid_frequencies" );
+ if (file.exists()) {
+ QString avoid = readSysFile( "devices/system/cpu/cpu0/cpufreq/ondemand/avoid_frequencies" );
+ QStringList avoidList = avoid.split( " " );
+
+ //check if min is in avoid_frequencies
+ for (int i = getScalingStep( min.toInt() ); i>0; --i) {
+ if (!avoidList.contains(min.setNum( getScalingFreq(i) ))) {
+ this->minFreq = min.toInt();
+ return this->minFreq;
+ }
+ }
+
+ //should not happen at all
+ this->minFreq = 125000;
+ return this->minFreq;
+ } else {
+ this->minFreq = min.toInt();
+ return this->minFreq;
+ }
+ } else {
+ return this->minFreq;
+ }
}
//SmartReflex is only supported on Maemo5
#if defined(Q_WS_MAEMO_5)
if ( getSmartReflexState() == 1 )
- callHelper( "set_sr", "off");
+ callHelper( "set_sr", "off");
else {
- QMaemo5InformationBox::information(this, tr( "SmartReflex support is known to be unstable on some devices and may cause random reboots." ), QMaemo5InformationBox::DefaultTimeout);
- callHelper( "set_sr", "on");
+ QMaemo5InformationBox::information(this, tr( "SmartReflex support is known to be unstable on some devices and may cause random reboots." ), QMaemo5InformationBox::DefaultTimeout);
+ callHelper( "set_sr", "on");
}
#endif
{
QRect screenGeometry = QApplication::desktop()->screenGeometry();
if (screenGeometry.width() > screenGeometry.height())
- return false;
+ return false;
else
- return true;
+ return true;
}