dom0+vm: introduce 'qubes-service' xenstore dir - enable/disable VM services from dom0

This allows control which services are started in VM by dom0. For some
situation vm_type was used, but it isn't enough - i.e. ntpd should be started
in one, selected NetVM.
This commit is contained in:
Marek Marczykowski 2011-10-01 02:49:25 +02:00
parent 796f45a864
commit e1a6c1ffd5
4 changed files with 24 additions and 13 deletions

View File

@ -32,7 +32,15 @@ start()
fi fi
# Start AppVM specific services # Start AppVM specific services
/sbin/service cups start start_cups=$(/usr/bin/xenstore-read qubes-service/cups 2> /dev/null)
if [ "$start_cups" != "0" ]; then
/sbin/service cups start
# Allow also notification icon
sed -i -e '/^NotShowIn=.*QUBES/s/;QUBES//' /etc/xdg/autostart/print-applet.desktop
else
# Disable notification icon
sed -i -e '/QUBES/!s/^NotShowIn=.*/\1QUBES;/' /etc/xdg/autostart/print-applet.desktop
fi
echo -n $"Executing Qubes Core scripts for AppVM:" echo -n $"Executing Qubes Core scripts for AppVM:"
@ -52,9 +60,12 @@ start()
echo Back to life. echo Back to life.
fi fi
MEM_CHANGE_THRESHOLD_KB=30000 start_meminfo_writer=$(/usr/bin/xenstore-read qubes-service/meminfo-writer)
MEMINFO_DELAY_USEC=100000 if [ "$start_meminfo_writer" != "0" ]; then
/usr/lib/qubes/meminfo-writer $MEM_CHANGE_THRESHOLD_KB $MEMINFO_DELAY_USEC & MEM_CHANGE_THRESHOLD_KB=30000
MEMINFO_DELAY_USEC=100000
/usr/lib/qubes/meminfo-writer $MEM_CHANGE_THRESHOLD_KB $MEMINFO_DELAY_USEC &
fi
success success
echo "" echo ""

View File

@ -77,8 +77,8 @@ start()
success success
echo "" echo ""
type=$(/usr/bin/xenstore-read qubes_vm_type) start_ntpd=$(/usr/bin/xenstore-read qubes-service/ntpd 2> /dev/null)
if [ "$type" == "ProxyVM" ]; then if [ "$start_ntpd" == "1" ]; then
/sbin/service ntpd start /sbin/service ntpd start
fi fi
return 0 return 0

View File

@ -11,7 +11,8 @@ PIDFILE=/var/run/qubes/qubes_firewall.pid
start() start()
{ {
type=$(/usr/bin/xenstore-read qubes_vm_type) type=$(/usr/bin/xenstore-read qubes_vm_type)
if [ "$type" == "ProxyVM" ]; then start_firewall=$(/usr/bin/xenstore-read qubes-service/qubes-firewall)
if [ -z "$start_firewall" ] && [ "$type" == "ProxyVM" ] || [ "$start_firewall" == "1" ]; then
echo -n $"Starting Qubes Firewall monitor:" echo -n $"Starting Qubes Firewall monitor:"
/sbin/ethtool -K eth0 sg off /sbin/ethtool -K eth0 sg off
/usr/sbin/qubes_firewall & /usr/sbin/qubes_firewall &
@ -23,8 +24,7 @@ start()
stop() stop()
{ {
type=$(/usr/bin/xenstore-read qubes_vm_type) if [ -r $PIDFILE ]; then
if [ "$type" == "ProxyVM" ]; then
echo -n "Stopping Qubes Firewall monitor:" echo -n "Stopping Qubes Firewall monitor:"
kill -9 $(cat $PIDFILE) 2>/dev/null && success || failure kill -9 $(cat $PIDFILE) 2>/dev/null && success || failure
echo "" echo ""

View File

@ -11,7 +11,8 @@ PIDFILE=/var/run/qubes/qubes_netwatcher.pid
start() start()
{ {
type=$(/usr/bin/xenstore-read qubes_vm_type) type=$(/usr/bin/xenstore-read qubes_vm_type)
if [ "$type" == "ProxyVM" ]; then start_netwatcher=$(/usr/bin/xenstore-read qubes-service/qubes-netwatcher)
if [ -z "$start_netwatcher" ] && [ "$type" == "ProxyVM" ] || [ "$start_netwatcher" == "1" ]; then
echo -n $"Starting Qubes Network monitor:" echo -n $"Starting Qubes Network monitor:"
/sbin/ethtool -K eth0 sg off /sbin/ethtool -K eth0 sg off
/usr/sbin/qubes_netwatcher & /usr/sbin/qubes_netwatcher &
@ -23,8 +24,7 @@ start()
stop() stop()
{ {
type=$(/usr/bin/xenstore-read qubes_vm_type) if [ -r "$PIDFILE" ]; then
if [ "$type" == "ProxyVM" ]; then
echo -n "Stopping Qubes Network monitor:" echo -n "Stopping Qubes Network monitor:"
kill -9 $(cat $PIDFILE) 2>/dev/null && success || failure kill -9 $(cat $PIDFILE) 2>/dev/null && success || failure
echo "" echo ""