mirror of
https://github.com/koreader/koreader.git
synced 2025-08-10 00:52:38 +00:00
* Enable before_wifi_action & after_wifi_action on hasWifiToggle platforms (which is basically all of 'em except naked SDL). * Decouple restoreWifiAsync from hasWifiManger, because we can do that on other platforms (namely, Kindle. Probably PB, too, but WiFi is already a mess there, and I can't test it). * Implement restoreWifiAsync on Kindle. * Properly flag rM as hasWifiManager & hasFastWifiStatusQuery, because it is actually both of those (it uses our wpa_supplicant backend). * Update the KOSync checks to take these changes into account, to properly disable auto_sync if necessary. * Really made the Network* event signaling consistent. For realz this time. * In an effort to make the whole beforeWifiAction framework somewhat usable there, we now assume connectivity is always available on !hasWifiToggle platforms...
255 lines
6.9 KiB
Lua
255 lines
6.9 KiB
Lua
local Generic = require("device/generic/device") -- <= look at this file!
|
|
local PluginShare = require("pluginshare")
|
|
local UIManager
|
|
local ffi = require("ffi")
|
|
local logger = require("logger")
|
|
|
|
local C = ffi.C
|
|
require("ffi/linux_input_h")
|
|
|
|
local function yes() return true end
|
|
local function no() return false end
|
|
|
|
local SonyPRSTUX = Generic:extend{
|
|
model = "Sony PRSTUX",
|
|
isSonyPRSTUX = yes,
|
|
hasKeys = yes,
|
|
hasOTAUpdates = yes,
|
|
hasWifiManager = yes,
|
|
canReboot = yes,
|
|
canPowerOff = yes,
|
|
canSuspend = yes,
|
|
usbPluggedIn = false,
|
|
home_dir = nil,
|
|
}
|
|
|
|
|
|
|
|
-- sony's driver does not inform of ID, so we overwrite the TOUCH_MAJOR
|
|
-- event to fake an ID event. a width == 0 means the finger was lifted.
|
|
-- after all events are received, we reset the counter
|
|
|
|
local next_touch_id = 0
|
|
local adjustTouchEvt = function(self, ev)
|
|
if ev.type == C.EV_ABS and ev.code == C.ABS_MT_TOUCH_MAJOR then
|
|
ev.code = C.ABS_MT_TRACKING_ID
|
|
if ev.value ~= 0 then
|
|
ev.value = next_touch_id
|
|
else
|
|
ev.value = -1
|
|
end
|
|
|
|
next_touch_id = next_touch_id + 1
|
|
|
|
logger.dbg("adjusted id: ", ev.value)
|
|
elseif ev.type == C.EV_SYN and ev.code == C.SYN_REPORT then
|
|
next_touch_id = 0
|
|
logger.dbg("reset id: ", ev.code, ev.value)
|
|
ev.code = C.SYN_MT_REPORT
|
|
elseif ev.type == C.EV_SYN and ev.code == C.SYN_MT_REPORT then
|
|
ev.code = C.SYN_REPORT
|
|
end
|
|
end
|
|
|
|
function SonyPRSTUX:init()
|
|
self.screen = require("ffi/framebuffer_mxcfb"):new{device = self, debug = logger.dbg}
|
|
self.powerd = require("device/sony-prstux/powerd"):new{device = self}
|
|
self.input = require("device/input"):new{
|
|
device = self,
|
|
event_map = require("device/sony-prstux/event_map"),
|
|
}
|
|
|
|
self.input.open("/dev/input/event0") -- Keys
|
|
self.input.open("/dev/input/event1") -- touchscreen
|
|
self.input.open("/dev/input/event2") -- power button
|
|
self.input.open("fake_events") -- usb plug-in/out and charging/not-charging
|
|
self.input:registerEventAdjustHook(adjustTouchEvt)
|
|
|
|
local rotation_mode = self.screen.DEVICE_ROTATED_COUNTER_CLOCKWISE
|
|
self.screen.native_rotation_mode = rotation_mode
|
|
self.screen.cur_rotation_mode = rotation_mode
|
|
|
|
Generic.init(self)
|
|
end
|
|
|
|
function SonyPRSTUX:supportsScreensaver() return true end
|
|
|
|
function SonyPRSTUX:setDateTime(year, month, day, hour, min, sec)
|
|
if hour == nil or min == nil then return true end
|
|
local command
|
|
if year and month and day then
|
|
command = string.format("date -s '%d-%d-%d %d:%d:%d'", year, month, day, hour, min, sec)
|
|
else
|
|
command = string.format("date -s '%d:%d'",hour, min)
|
|
end
|
|
if os.execute(command) == 0 then
|
|
os.execute("hwclock -u -w")
|
|
return true
|
|
else
|
|
return false
|
|
end
|
|
end
|
|
|
|
function SonyPRSTUX:intoScreenSaver()
|
|
local Screensaver = require("ui/screensaver")
|
|
if not self.screen_saver_mode then
|
|
Screensaver:setup()
|
|
Screensaver:show()
|
|
end
|
|
self.powerd:beforeSuspend()
|
|
end
|
|
|
|
function SonyPRSTUX:outofScreenSaver()
|
|
if self.screen_saver_mode then
|
|
local Screensaver = require("ui/screensaver")
|
|
Screensaver:close()
|
|
UIManager:nextTick(function() UIManager:setDirty("all", "full") end)
|
|
end
|
|
self.powerd:afterResume()
|
|
end
|
|
|
|
function SonyPRSTUX:suspend()
|
|
os.execute("./suspend.sh")
|
|
end
|
|
|
|
function SonyPRSTUX:resume()
|
|
os.execute("./resume.sh")
|
|
end
|
|
|
|
function SonyPRSTUX:powerOff()
|
|
os.execute("sleep 1 && poweroff &")
|
|
end
|
|
|
|
function SonyPRSTUX:reboot()
|
|
os.execute("sleep 1 && reboot &")
|
|
end
|
|
|
|
function SonyPRSTUX:usbPlugIn()
|
|
self.usb_plugged_in = true
|
|
PluginShare.pause_auto_suspend = true
|
|
end
|
|
|
|
function SonyPRSTUX:usbPlugOut()
|
|
self.usb_plugged_in = false
|
|
PluginShare.pause_auto_suspend = false
|
|
end
|
|
|
|
function SonyPRSTUX:usbPluggedIn()
|
|
return self.usb_plugged_in
|
|
end
|
|
|
|
function SonyPRSTUX:initNetworkManager(NetworkMgr)
|
|
function NetworkMgr:turnOffWifi(complete_callback)
|
|
self:releaseIP()
|
|
os.execute("./set-wifi.sh off")
|
|
if complete_callback then
|
|
complete_callback()
|
|
end
|
|
end
|
|
|
|
function NetworkMgr:turnOnWifi(complete_callback)
|
|
os.execute("./set-wifi.sh on")
|
|
self:reconnectOrShowNetworkMenu(complete_callback)
|
|
end
|
|
|
|
function NetworkMgr:getNetworkInterfaceName()
|
|
return "wlan0"
|
|
end
|
|
|
|
NetworkMgr:setWirelessBackend("wpa_supplicant", {ctrl_interface = "/var/run/wpa_supplicant/wlan0"})
|
|
|
|
function NetworkMgr:obtainIP()
|
|
self:releaseIP()
|
|
os.execute("dhclient wlan0")
|
|
end
|
|
|
|
function NetworkMgr:releaseIP()
|
|
logger.info("killing dhclient")
|
|
os.execute("dhclient -x wlan0")
|
|
end
|
|
|
|
--[[
|
|
function NetworkMgr:isWifiOn()
|
|
return 0 == os.execute("wmiconfig -i wlan0 --wlan query | grep -q enabled")
|
|
end
|
|
--]]
|
|
NetworkMgr.isWifiOn = NetworkMgr.sysfsWifiOn
|
|
NetworkMgr.isConnected = NetworkMgr.ifHasAnAddress
|
|
end
|
|
|
|
|
|
function SonyPRSTUX:getSoftwareVersion()
|
|
return ffi.string("PRSTUX")
|
|
end
|
|
|
|
function SonyPRSTUX:getDeviceModel()
|
|
return ffi.string("PRS-T2")
|
|
end
|
|
|
|
function SonyPRSTUX:UIManagerReady(uimgr)
|
|
UIManager = uimgr
|
|
end
|
|
|
|
function SonyPRSTUX:setEventHandlers(uimgr)
|
|
UIManager.event_handlers.Suspend = function()
|
|
self:intoScreenSaver()
|
|
self:suspend()
|
|
end
|
|
UIManager.event_handlers.Resume = function()
|
|
self:resume()
|
|
self:outofScreenSaver()
|
|
end
|
|
UIManager.event_handlers.PowerPress = function()
|
|
UIManager:scheduleIn(2, UIManager.poweroff_action)
|
|
end
|
|
UIManager.event_handlers.PowerRelease = function()
|
|
if not UIManager._entered_poweroff_stage then
|
|
UIManager:unschedule(UIManager.poweroff_action)
|
|
-- resume if we were suspended
|
|
if self.screen_saver_mode then
|
|
if self.screen_saver_lock then
|
|
UIManager.event_handlers.Suspend()
|
|
else
|
|
UIManager.event_handlers.Resume()
|
|
end
|
|
else
|
|
UIManager.event_handlers.Suspend()
|
|
end
|
|
end
|
|
end
|
|
UIManager.event_handlers.Charging = function()
|
|
self:_beforeCharging()
|
|
end
|
|
UIManager.event_handlers.NotCharging = function()
|
|
self:_afterNotCharging()
|
|
end
|
|
UIManager.event_handlers.UsbPlugIn = function()
|
|
if self.screen_saver_mode and not self.screen_saver_lock then
|
|
self:resume()
|
|
self:outofScreenSaver()
|
|
end
|
|
self:usbPlugIn()
|
|
end
|
|
UIManager.event_handlers.UsbPlugOut = function()
|
|
self:usbPlugOut()
|
|
end
|
|
end
|
|
|
|
-- For Sony PRS-T2
|
|
local SonyPRSTUX_T2 = SonyPRSTUX:extend{
|
|
isTouchDevice = yes,
|
|
hasKeys = yes,
|
|
hasFrontlight = no,
|
|
display_dpi = 166,
|
|
}
|
|
|
|
logger.info("SoftwareVersion: ", SonyPRSTUX:getSoftwareVersion())
|
|
|
|
local codename = SonyPRSTUX:getDeviceModel()
|
|
|
|
if codename == "PRS-T2" then
|
|
return SonyPRSTUX_T2
|
|
else
|
|
error("unrecognized Sony PRSTUX model " .. codename)
|
|
end
|