{
struct dirent *ent;
int i, count = 0;
- char **mfilters;
+ const char **mfilters;
char buff[64];
DIR *dir;
}
closedir(dir);
- plat_target.filters = mfilters;
+ plat_target.hwfilters = mfilters;
}
-static void set_lcdrate(int is_pal)
+static int do_system(const char *cmd)
+{
+ int ret;
+
+ ret = system(cmd);
+ if (ret >= 0)
+ ret = 0;
+
+ return ret;
+}
+
+static int read_int_from_file(const char *fname)
+{
+ int ret = -1;
+ FILE *f;
+
+ f = fopen(fname, "r");
+ if (f) {
+ fscanf(f, "%d", &ret);
+ fclose(f);
+ }
+ return ret;
+}
+
+static int lcdrate_set(int is_pal)
{
static int old_pal = -1;
char buf[128];
if (is_pal == old_pal)
- return;
+ return 0;
+ old_pal = is_pal;
snprintf(buf, sizeof(buf), "%s/op_lcdrate.sh %d",
pnd_script_base, is_pal ? 50 : 60);
- system(buf);
- old_pal = is_pal;
+ return do_system(buf);
}
-static void set_filter(int which)
+static int hwfilter_set(int which)
{
static int old_filter = -1;
char buf[128];
int i;
- if (plat_target.filters == NULL || which == old_filter)
- return;
+ if (plat_target.hwfilters == NULL)
+ return -1;
- for (i = 0; i < which; i++)
- if (plat_target.filters[i] == NULL)
- return;
+ if (which == old_filter)
+ return 0;
- if (plat_target.filters[i] == NULL)
- return;
+ for (i = 0; i <= which; i++)
+ if (plat_target.hwfilters[i] == NULL)
+ return -1;
- snprintf(buf, sizeof(buf), "%s/op_videofir.sh %s",
- pnd_script_base, plat_target.filters[i]);
- system(buf);
old_filter = which;
+
+ snprintf(buf, sizeof(buf), "%s/op_videofir.sh %s",
+ pnd_script_base, plat_target.hwfilters[which]);
+ return do_system(buf);
}
static int cpu_clock_get(void)
{
- FILE *f;
- int ret = 0;
- f = fopen("/proc/pandora/cpu_mhz_max", "r");
- if (f) {
- fscanf(f, "%d", &ret);
- fclose(f);
- }
- return ret;
+ return read_int_from_file("/proc/pandora/cpu_mhz_max");
}
static int cpu_clock_set(int cpu_clock)
{
char buf[128];
- if (cpu_clock != 0 && cpu_clock != cpu_clock_get()) {
- snprintf(buf, sizeof(buf), "unset DISPLAY; echo y | %s/op_cpuspeed.sh %d",
- pnd_script_base, cpu_clock);
- system(buf);
- }
- return 0;
+ if (cpu_clock < 14)
+ return -1;
+
+ if (cpu_clock == cpu_clock_get())
+ return 0;
+
+ snprintf(buf, sizeof(buf),
+ "unset DISPLAY; echo y | %s/op_cpuspeed.sh %d",
+ pnd_script_base, cpu_clock);
+ return do_system(buf);
}
-static int get_bat_capacity(void)
+static int bat_capacity_get(void)
{
- FILE *f;
- int ret = 0;
- f = fopen("/sys/class/power_supply/bq27500-0/capacity", "r");
- if (f) {
- fscanf(f, "%d", &ret);
- fclose(f);
+ return read_int_from_file("/sys/class/power_supply/bq27500-0/capacity");
+}
+
+static int gamma_set(int val, int black_level)
+{
+ char buf[128];
+
+ snprintf(buf, sizeof(buf), "%s/op_gamma.sh -b %d %.2f",
+ pnd_script_base, black_level, (float)val / 100.0f);
+ return do_system(buf);
+}
+
+/* For now, this only switches tv-out to appropriate fb.
+ * Maybe this could control actual layers too? */
+static int switch_layer(int which, int enable)
+{
+ static int was_ovl_enabled = -1;
+ int tv_enabled = 0;
+ char buf[128];
+ int ret;
+
+ if (which != 1)
+ return -1;
+ if (enable == was_ovl_enabled)
+ return 0;
+
+ was_ovl_enabled = -1;
+
+ tv_enabled = read_int_from_file(
+ "/sys/devices/platform/omapdss/display1/enabled");
+ if (tv_enabled < 0)
+ return -1;
+
+ if (!tv_enabled) {
+ // tv-out not enabled
+ return 0;
}
+
+ snprintf(buf, sizeof(buf), "%s/op_tvout.sh -l %d",
+ pnd_script_base, enable);
+ ret = do_system(buf);
+ if (ret == 0)
+ was_ovl_enabled = enable;
+
return ret;
}
struct plat_target plat_target = {
cpu_clock_get,
cpu_clock_set,
- get_bat_capacity,
- set_filter,
- NULL,
- set_lcdrate,
+ bat_capacity_get,
+ hwfilter_set,
+ lcdrate_set,
+ gamma_set,
+ .switch_layer = switch_layer,
};
int plat_target_init(void)