def add_prop(key, cfg_key):
value = session_cfg["session"][cfg_key]
if value != "None":
- props.append(key + "=" + session_cfg["session"][cfg_key])
+ value = value.replace("/mnt/", "/mnt_extra/")
+ props.append(key + "=" + value)
if not os.path.isfile(args.work + "/waydroid_base.prop"):
raise RuntimeError("waydroid_base.prop Not found")
def chmod(path, mode):
if os.path.exists(path):
command = ["chmod", mode, "-R", path]
- tools.helpers.run.root(args, command, check=False)
+ tools.helpers.run.user(args, command, check=False)
# Nodes list
if not perm_list:
"/dev/MTK_SMI",
"/dev/mdp_sync",
"/dev/mtk_cmdq",
- "/dev/video32",
- "/dev/video33",
# Graphics
"/dev/dri",
"/dev/graphics",
-
- # Wayland and pulse socket permissions
- session_cfg["session"]["pulse_runtime_path"],
- session_cfg["session"]["xdg_runtime_dir"]
+ "/dev/pvr_sync",
+ "/dev/ion",
]
# Framebuffers
perm_list.extend(glob.glob("/dev/fb*"))
+ # Videos
+ perm_list.extend(glob.glob("/dev/video*"))
for path in perm_list:
chmod(path, mode)
# Networking
command = [tools.config.tools_src +
"/data/scripts/waydroid-net.sh", "start"]
- tools.helpers.run.root(args, command, check=False)
+ tools.helpers.run.user(args, command, check=False)
# Sensors
- tools.helpers.run.root(
- args, ["waydroid-sensord", "/dev/" + args.HWBINDER_DRIVER], output="background")
+ if which("waydroid-sensord"):
+ tools.helpers.run.user(
+ args, ["waydroid-sensord", "/dev/" + args.HWBINDER_DRIVER], output="background")
# Mount rootfs
helpers.images.mount_rootfs(args, cfg["waydroid"]["images_path"])
# Cgroup hacks
if which("start"):
command = ["start", "cgroup-lite"]
- tools.helpers.run.root(args, command, check=False)
- helpers.mount.umount_all(args, "/sys/fs/cgroup/schedtune")
+ tools.helpers.run.user(args, command, check=False)
+ command = ["umount", "-l", "/sys/fs/cgroup/schedtune"]
+ tools.helpers.run.user(args, command, check=False)
#TODO: remove NFC hacks
if which("stop"):
command = ["stop", "nfcd"]
- tools.helpers.run.root(args, command, check=False)
+ tools.helpers.run.user(args, command, check=False)
# Set permissions
set_permissions()
helpers.lxc.start(args)
session_cfg["session"]["state"] = helpers.lxc.status(args)
+ timeout = 10
+ while session_cfg["session"]["state"] != "RUNNING" and timeout > 0:
+ session_cfg["session"]["state"] = helpers.lxc.status(args)
+ logging.info(
+ "waiting {} seconds for container to start...".format(timeout))
+ timeout = timeout - 1
+ time.sleep(1)
+ if session_cfg["session"]["state"] != "RUNNING":
+ raise OSError("container failed to start")
tools.config.save_session(session_cfg)
- if not hasattr(args, 'hardwareLoop'):
- services.hardware_manager.start(args)
+ services.hardware_manager.start(args)
signal.signal(signal.SIGINT, signal_handler)
while os.path.exists(tools.config.session_defaults["config_path"]):
logging.warning("session manager stopped, stopping container and waiting...")
stop(args)
+ services.hardware_manager.stop(args)
start(args)
else:
logging.error("WayDroid container is {}".format(status))
# Networking
command = [tools.config.tools_src +
"/data/scripts/waydroid-net.sh", "stop"]
- tools.helpers.run.root(args, command, check=False)
+ tools.helpers.run.user(args, command, check=False)
#TODO: remove NFC hacks
if which("start"):
command = ["start", "nfcd"]
- tools.helpers.run.root(args, command, check=False)
+ tools.helpers.run.user(args, command, check=False)
# Sensors
if which("waydroid-sensord"):
command = ["pidof", "waydroid-sensord"]
- pid = tools.helpers.run.root(args, command, check=False, output_return=True)
+ pid = tools.helpers.run.user(args, command, check=False, output_return=True)
if pid:
- command = ["killall", pid]
- tools.helpers.run.root(args, command, check=False)
+ command = ["kill", "-9", pid]
+ tools.helpers.run.user(args, command, check=False)
+
+ # Umount rootfs
+ helpers.images.umount_rootfs(args)
+
+ # Umount data
+ helpers.mount.umount_all(args, tools.config.defaults["data"])
else:
logging.error("WayDroid container is {}".format(status))
+def restart(args):
+ status = helpers.lxc.status(args)
+ if status == "RUNNING":
+ helpers.lxc.stop(args)
+ helpers.lxc.start(args)
+ else:
+ logging.error("WayDroid container is {}".format(status))
+
def freeze(args):
status = helpers.lxc.status(args)
if status == "RUNNING":