return -EINVAL;
}
+static const char wm97xx_p[] =
+ "5507 0 -831476 0 -4218 16450692 65536"; // from 4.0 fw
+
long emu_do_read(int fd, void *buf, int count)
{
- static const char wm97xx_p[] =
- "5507 0 -831476 0 -4218 16450692 65536"; // from 4.0 fw
int ret, pressed = 0, x, y;
struct {
u16 pressure, x, y;
case FAKEDEV_WM97XX:
ret = host_read_ts(&pressed, &x, &y);
if (ret == 0 && pressed) {
- wm97xx.pressure = 1;
+ wm97xx.pressure = 0x8001; // TODO: check the real thing
wm97xx.x = x * 3750 / 1024 + 200;
wm97xx.y = 3750 - y * 3750 / 1024 + 200;
}
strncpy(buf, wm97xx_p, count);
break;
default:
- err("read(%d, %d)\n", fd, count);
+ dbg("read(%d, %d)\n", fd, count);
return -EINVAL;
}
return count;
const char *w_path;
FILE *ret;
- w_path = emu_wrap_path(path);
- ret = fopen(w_path, mode);
- emu_wrap_path_free(w_path, path);
+ if (strcmp(path, "/etc/pointercal") == 0) {
+ // use local pontercal, not host's
+ ret = fopen("pointercal", mode);
+ if (ret == NULL) {
+ ret = fopen("pointercal", "w");
+ if (ret != NULL) {
+ fwrite(wm97xx_p, 1, sizeof(wm97xx_p), ret);
+ fclose(ret);
+ }
+ ret = fopen("pointercal", mode);
+ }
+ }
+ else {
+ w_path = emu_wrap_path(path);
+ ret = fopen(w_path, mode);
+ emu_wrap_path_free(w_path, path);
+ }
return ret;
}
{ "/dev/fb1", FAKEDEV_FB1 },
{ "/dev/fb/1", FAKEDEV_FB1 },
{ "/dev/mmuhack", FAKEDEV_MMUHACK },
- { "/dev/tty", FAKEDEV_TTY0 },
+ { "/dev/tty", FAKEDEV_TTY },
{ "/dev/tty0", FAKEDEV_TTY0 },
{ "/dev/touchscreen/wm97xx", FAKEDEV_WM97XX },
{ "/etc/pointercal", FAKEDEV_WM97XX_P },
+ { "/dev/input/mice", -ENODEV },
#ifdef PND
- { "/dev/input/event*", -1 }, // hide for now, may cause dupe events
+ { "/dev/input/event*", -ENODEV }, // hide for now, may cause dupe events
#endif
};