VirtualBox

Changeset 24651 in vbox for trunk/src/VBox/Additions/linux


Ignore:
Timestamp:
Nov 13, 2009 8:18:47 PM (15 years ago)
Author:
vboxsync
Message:

Additions/linux/installer: major clean-up of xorg.conf configuration file hacking

Location:
trunk/src/VBox/Additions/linux
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Additions/linux/Makefile.kmk

    r24543 r24651  
    284284        $(VBOX_REL_X11_ADD_INST)98vboxadd-xclient \
    285285        $(VBOX_REL_LNX_ADD_INST)vboxadd.sh \
    286         $(VBOX_REL_X11_ADD_INST)x11config.pl \
    287         $(VBOX_REL_X11_ADD_INST)x11config15.pl \
     286        $(VBOX_REL_X11_ADD_INST)x11config-new.pl \
    288287        $(VBOX_REL_LNX_INST_SRC)routines.sh
    289288
     
    295294        $(VBOX_REL_X11_ADD_INST)vboxclient.desktop \
    296295        $(VBOX_REL_X11_ADD_INST)vboxvideo.ids \
    297         $(VBOX_REL_X11_ADD_INST)linux_xorg_suse11.conf \
    298296        $(VBOX_REL_LNX_ADD_INST)90-vboxguest.fdi \
    299297        selinux-fedora/vbox_x11.pp
  • trunk/src/VBox/Additions/linux/installer/vboxadd-x11.sh

    r24531 r24651  
    3535PATH=$PATH:/bin:/sbin:/usr/sbin
    3636LOG="/var/log/vboxadd-install-x11.log"
     37CONFIG_DIR="/var/lib/VBoxGuestAdditions"
     38CONFIG="config"
    3739
    3840# Find the version of X installed
     
    178180# syntax: install_x11_startup_app app desktop service_name
    179181install_x11_startup_app() {
     182    self="install_x11_startup_app"
    180183    app_src=$1
    181184    desktop_src=$2
     
    183186    alt_command=$4
    184187    test -r "$app_src" ||
    185         { echo "install_x11_startup_app: no script given"; return 1; }
     188        { echo >> $LOG "$self: no script given"; return 1; }
    186189    test -r "$desktop_src" ||
    187         { echo "install_x11_startup_app: no desktop file given"; return 1; }
     190        { echo >> $LOG "$self: no desktop file given"; return 1; }
    188191    test -n "$service_name" ||
    189         { echo "install_x11_startup_app: no service given"; return 1; }
     192        { echo >> $LOG "$self: no service given"; return 1; }
    190193    test -n "$alt_command" ||
    191         { echo "install_x11_startup_app: no service given"; return 1; }
     194        { echo >> $LOG "$self: no service given"; return 1; }
    192195    app_dest=`basename $app_src sh`
    193196    app_dest_sh=`basename $app_src sh`.sh
     
    227230        return 0
    228231    fi
    229     cat << EOF
    230 Could not set up the X Window $service_name service.
    231 To start the $service_name service at log-in for a given user,
    232 add the command $alt_command to the file .xinitrc in their home
    233 directory.
     232    cat >> $LOG << EOF
     233Could not set up the $service_name desktop service.
     234To start it at log-in for a given user, add the command $alt_command
     235to the file .xinitrc in their home directory.
    234236EOF
    235237    return 1
     
    257259setup()
    258260{
    259     begin "Setting up the X Window System drivers"
     261    echo "VirtualBox Guest Additions installation, Window System and desktop setup" > $LOG
     262    begin "Installing the Window System drivers"
    260263    lib_dir="/usr/lib/VBoxGuestAdditions"
    261264    share_dir="/usr/share/VBoxGuestAdditions"
    262265    test -x "$lib_dir" -a -x "$share_dir" ||
    263266        fail "Invalid Guest Additions configuration found"
    264     # By default, we want to run our X Window System configuration script
    265     dox11config=1
    266     # But not the special version for X.Org 1.5+
    267     dox11config15=0
    268     # And we don't install our SUSE/X.Org 1.5 configuration file by default
    269     dox11config15suse=0
    270     # We want to use hal for auto-loading the mouse driver
    271     useHalForMouse=1
     267    # By default we want to configure X
     268    dox11config="true"
     269    # By default, we want to run our xorg.conf setup script
     270    setupxorgconf="true"
     271    # But without the workaround for SUSE 11.1 not doing input auto-detection
     272    newmouse=""
     273    # By default we want to use hal for auto-loading the mouse driver
     274    usehal="--useHal"
    272275    # And on newer servers, we want to test whether dynamic resizing will work
    273     testRandR=1
     276    testrandr="true"
    274277    # The video driver to install for X.Org 6.9+
    275278    vboxvideo_src=
     
    288291
    289292    test -z "$x_version" -o -z "$modules_dir" &&
    290         fail "Could not find X.org or XFree86 on the guest system.  The X Window drivers \
    291 will not be installed."
     293        fail "Could not find the X.Org or XFree86 Window System."
    292294
    293295    echo
     
    296298            echo "Warning: unsupported pre-release version of X.Org Server installed.  Not"
    297299            echo "installing the X.Org drivers."
    298             dox11config=0
     300            dox11config=""
    299301            ;;
    300302        1.6.99.* | 1.7.* )
     
    302304            vboxvideo_src=vboxvideo_drv_17.so
    303305            vboxmouse_src=vboxmouse_drv_17.so
    304             dox11config=0
     306            setupxorgconf=""
    305307            ;;
    306308        1.5.99.* | 1.6.* )
     
    308310            vboxvideo_src=vboxvideo_drv_16.so
    309311            vboxmouse_src=vboxmouse_drv_16.so
    310             dox11config15=1
    311312            ;;
    312313        1.4.99.* | 1.5.* )
     
    317318            vboxmouse_src=vboxmouse_drv_15.so
    318319            # SUSE with X.Org 1.5 is a special case, and is handled specially
    319             if [ -f /etc/SuSE-release ]
    320             then
    321                 dox11config15suse=1
    322             else
    323                 # This means do a limited configuration for systems with
    324                 # autodetection support
    325                 dox11config15=1
    326             fi
     320            test -r /etc/SuSE-release &&
     321            { usehal=""; newmouse="--newMouse"; }
    327322            ;;
    328323        1.4.* )
     
    330325            vboxvideo_src=vboxvideo_drv_14.so
    331326            vboxmouse_src=vboxmouse_drv_14.so
    332             useHalForMouse=0
     327            usehal=""
    333328            ;;
    334329        1.3.* )
     
    338333            vboxvideo_src=vboxvideo_drv_13.so
    339334            vboxmouse_src=vboxmouse_drv_71.so
    340             useHalForMouse=0
     335            usehal=""
    341336            ;;
    342337        7.1.* | 7.2.* )
     
    344339            vboxvideo_src=vboxvideo_drv_71.so
    345340            vboxmouse_src=vboxmouse_drv_71.so
    346             useHalForMouse=0
    347             testRandR=0
     341            usehal=""
     342            testrandr=""
    348343            ;;
    349344        6.9.* | 7.0.* )
     
    351346            vboxvideo_src=vboxvideo_drv_70.so
    352347            vboxmouse_src=vboxmouse_drv_70.so
    353             useHalForMouse=0
    354             testRandR=0
     348            usehal=""
     349            testrandr=""
    355350            ;;
    356351        6.7* | 6.8.* | 4.2.* | 4.3.* )
     
    359354            ln -s "$lib_dir/vboxvideo_drv.o" "$modules_dir/drivers/vboxvideo_drv.o"
    360355            ln -s "$lib_dir/vboxmouse_drv.o" "$modules_dir/input/vboxmouse_drv.o"
    361             useHalForMouse=0
    362             testRandR=0
     356            usehal=""
     357            testrandr=""
     358            succ_msg
    363359            ;;
    364360        * )
    365361            echo "Warning: unknown version of the X Window System installed.  Not installing"
    366362            echo "X Window System drivers."
    367             dox11config=0
    368             useHalForMouse=0
     363            dox11config=""
    369364            ;;
    370365    esac
     
    376371        succ_msg
    377372    fi
    378     if [ $testRandR -eq 1 ]; then
     373    if test -n "$testrandr"; then
    379374        # Run VBoxRandR in test mode as it prints out useful information if
    380375        # dynamic resizing can't be used.  Don't fail here though.
    381376        /usr/bin/VBoxRandR --test 1>&2
    382377    else
    383         echo "You appear to be have an old version of the X Window system installed on"
    384         echo "your guest system.  Seamless mode and dynamic resizing will not work in"
    385         echo "this guest."
    386     fi
     378        cat << EOF
     379
     380You appear to be have an old version of the X Window system installed on your guest system.  Seamless mode and dynamic resizing will not work in
     381this guest.
     382
     383EOF
     384    fi
     385
     386    if test -n "$dox11config"; then
     387        begin "Setting up the Window System to use the Guest Additions"
     388        # Certain Ubuntu/Debian versions use a special PCI-id file to identify
     389        # video drivers.  Some versions have the directory and don't use it.
     390        # Those versions can autoload vboxvideo though, so we don't need to
     391        # hack the configuration file for them.
     392        test -f /etc/debian_version -a -d /usr/share/xserver-xorg/pci &&
     393        {
     394            rm -f "/usr/share/xserver-xorg/pci/vboxvideo.ids"
     395            ln -s "$share_dir/vboxvideo.ids" /usr/share/xserver-xorg/pci 2>/dev/null
     396            test -n "$usehal" && setupxorgconf=""
     397        }
     398
     399        # Do the XF86Config/xorg.conf hack for those versions that require it
     400        configured=""
     401        generated=""
     402        if test -n "$setupxorgconf"; then
     403            for i in $x11conf_files; do
     404                if test -r "$i"; then
     405                    if grep -q "VirtualBox generated" "$i"; then
     406                        generated="$generated  `printf "$i\n"`"
     407                    else
     408                        "$lib_dir/x11config-new.pl" $newmouse $usehal "$i"
     409                    fi
     410                    configured="true"
     411                fi
     412                # Timestamp, so that we can see if the config file is changed
     413                # by someone else later
     414                test -r "$i.vbox" && touch "$i.vbox"
     415            done
     416            # X.Org Server 1.5 and 1.6 can detect hardware they know, but they
     417            # need a configuration file for VBoxVideo.
     418            main_cfg="/etc/X11/xorg.conf"
     419            nobak="/etc/X11/xorg.vbox.nobak"
     420            if test -z "$configured" -a ! -r "$nobak"; then
     421                touch "$main_cfg"
     422                "$lib_dir/x11config-new.pl" --useHal --noBak "$main_cfg"
     423                touch "$nobak"
     424            fi
     425        fi
     426        # X.Org Server versions starting with 1.5 can do mouse auto-detection,
     427        # to make our lives easier and spare us the nasty hacks.
     428        test -n "$usehal" &&
     429            if [ -d /etc/hal/fdi/policy ]
     430            then
     431                # Install hal information about the mouse driver so that X.Org
     432                # knows to load it.
     433                install -o 0 -g 0 -m 0644 "$share_dir/90-vboxguest.fdi" /etc/hal/fdi/policy
     434                # Delete the hal cache so that it notices our fdi file
     435                rm -r /var/cache/hald/fdi-cache 2> /dev/null
     436            fi
     437        succ_msg
     438        test -n "$generated" &&
     439            cat << EOF
     440The following X.Org/XFree86 configuration files were originally generated by
     441the VirtualBox Guest Additions and were not modified:
     442
     443$generated
     444
     445EOF
     446        echo "You may need to restart the Window System to enable the Guest Additions."
     447        echo
     448    fi
     449
     450    begin "Installing OpenGL and desktop services components"
    387451    # Install selinux policy for Fedora 7 and 8 to allow the X server to
    388452    # open device files
     
    398462    chcon -t unconfined_execmem_exec_t '/usr/bin/VBoxClient' > /dev/null 2>&1
    399463    semanage fcontext -a -t unconfined_execmem_exec_t '/usr/bin/VBoxClient' > /dev/null 2>&1
    400 
    401     # Certain Ubuntu/Debian versions use a special PCI-id file to identify
    402     # video drivers.  Some versions have the directory and don't use it.
    403     # Those versions can autoload vboxvideo though, so we don't need to
    404     # hack the configuration file for them.
    405     test -f /etc/debian_version -a -d /usr/share/xserver-xorg/pci &&
    406     {
    407         rm -f "/usr/share/xserver-xorg/pci/vboxvideo.ids"
    408         ln -s "$share_dir/vboxvideo.ids" /usr/share/xserver-xorg/pci 2>/dev/null
    409         test "$useHalForMouse" -eq 1 && doX11Config=0
    410     }
    411 
    412     # Do the XF86Config/xorg.conf hack for those versions that require it
    413     if [ $dox11config -eq 1 ]
    414     then
    415         # Backup any xorg.conf files
    416         for i in $x11conf_files; do
    417           test -r "$i" -a ! -f "`dirname $i`/xorg.vbox.nobak" &&
    418               cp "$i" "$i.vbox"
    419         done
    420         if [ $dox11config15suse -eq 1 ]
    421         then
    422             cp /etc/X11/xorg.conf /etc/X11/xorg.conf.bak 2> /dev/null
    423             cp "$share_dir/linux_xorg_suse11.conf" /etc/X11/xorg.conf 2> /dev/null
    424         elif [ $dox11config15 -eq 1 ]
    425         then
    426             "$lib_dir/x11config15.pl" >> $LOG 2>&1
    427             x11configured=0
    428             for x11configdir in /etc/X11 /etc /usr/etc/X11 /usr/lib/X11
    429             do
    430                 if [ -e $x11configdir/xorg.conf -o -e $x11configdir/xorg.conf-4 ]
    431                 then
    432                     x11configured=1
    433                 fi
    434                 if [ $x11configured -eq 0 ]
    435                 then
    436                     cat > /etc/X11/xorg.conf << EOF
    437 # Default xorg.conf for Xorg 1.5+ without PCI_TXT_IDS_PATH enabled.
    438 #
    439 # This file was created by VirtualBox Additions installer as it
    440 # was unable to find any existing configuration file for X.
    441 
    442 Section "Device"
    443         Identifier      "VirtualBox Video Card"
    444         Driver          "vboxvideo"
    445 EndSection
    446 EOF
    447                     touch /etc/X11/xorg.vbox.nobak
    448                 fi
    449             done
    450         else
    451             "$lib_dir/x11config.pl" >> $LOG 2>&1
    452         fi
    453     fi
    454 
    455     # X.Org Server versions starting with 1.5 can do mouse auto-detection,
    456     # to make our lives easier and spare us the nasty hacks.
    457     if [ $useHalForMouse -eq 1 ]
    458     then
    459         # Install hal information about the mouse driver so that X.Org
    460         # knows to load it.
    461         if [ -d /etc/hal/fdi/policy ]
    462         then
    463             install -o 0 -g 0 -m 0644 "$share_dir/90-vboxguest.fdi" /etc/hal/fdi/policy
    464             # Delete the hal cache so that it notices our fdi file
    465             rm -r /var/cache/hald/fdi-cache 2> /dev/null
    466         fi
    467     fi
    468464    # Install the guest OpenGL drivers
    469465    if [ "$ARCH" = "amd64" ]
     
    484480
    485481    # And set up VBoxClient to start when the X session does
    486     install_x11_startup_app "$lib_dir/98vboxadd-xclient" "$share_dir/vboxclient.desktop" VBoxClient VBoxClient-all
     482    install_x11_startup_app "$lib_dir/98vboxadd-xclient" "$share_dir/vboxclient.desktop" VBoxClient VBoxClient-all ||
     483        fail "See the log file $LOG for more information."
     484    succ_msg
    487485}
    488486
     
    491489{
    492490    # Restore xorg.conf files as far as possible
    493     for i in $x11conf_files; do
    494         restored=0
    495         if test -f "`dirname $i`/xorg.vbox.nobak"; then
    496             rm -f "$i" 2> /dev/null
    497             restored=1
    498         elif test -r "$i.vbox"; then
    499             if ! grep -q -E "vboxvideo|vboxmouse" "$i.vbox"; then
    500                 mv -f "$i.vbox" "$i"
    501                 restored=1
     491    ## List of generated files which have been changed since we generated them
     492    newer=""
     493    ## Are we dealing with a legacy information which didn't support
     494    # uninstallation?
     495    legacy=""
     496    ## Do any of the restored configuration files still reference our drivers?
     497    failed=""
     498    test -r "$CONFIG_DIR/$CONFIG" || legacy="true"
     499    main_cfg="/etc/X11/xorg.conf"
     500    nobak="/etc/X11/xorg.vbox.nobak"
     501    if test -r "$nobak"; then
     502        test -r "$main_cfg" &&
     503            if test "$main_cfg" -ot "$nobak" -o -n "$legacy"; then
     504                rm -f "$main_cfg"
     505            else
     506                newer="$newer`printf "  $main_cfg (no original)\n"`"
    502507            fi
    503         elif test -r "$i.bak"; then
    504             if ! grep -q -E "vboxvideo|vboxmouse" "$i.bak"; then
    505                 mv -f "$i.bak" "$i"
    506                 restored=1
     508    else
     509        for i in $x11conf_files; do
     510            if test -r "$i.vbox"; then
     511                if test "$i" -ot "$i.vbox" -o -n "$legacy"; then
     512                    mv -f "$i.vbox" "$i"
     513                    grep -q -E 'vboxvideo|vboxmouse' "$i" &&
     514                        failed="$failed`printf "  $i\n"`"
     515                else
     516                    newer="$newer`printf "  $i ($i.vbox)\n"`"
     517                fi
    507518            fi
    508         elif ! test -f "$i"; then
    509             restored=1
    510         fi
    511         test "$restored" = 1 &&
    512             rm -f "`dirname $i`/xorg.vbox.nobak" "$i.vbox" 2> /dev/null
    513         test "$restored" = 0 && cat << EOF
    514 Failed to restore the X server configuration file $i.
    515 Please make sure that you reconfigure your X server before it is started
    516 again, as otherwise it may fail to start!
     519        done
     520    fi
     521    test -n "$newer" && cat << EOF
     522
     523The following X.Org/XFree86 configuration files were not restored, as they may
     524have been changed since they were generated by the VirtualBox Guest Additions.
     525You may wish to restore these manually.  The file name in brackets is the
     526original version.
     527
     528$newer
     529
    517530EOF
    518     done
     531    test -n "$failed" && cat << EOF
     532
     533The following X.Org/XFree86 configuration files were restored, but still
     534contain references to the Guest Additions drivers.  You may wish to check and
     535possibly correct the restored configuration files to be sure that the server
     536will continue to work after it is restarted.
     537
     538$newer
     539
     540EOF
    519541
    520542    # Remove X.Org drivers
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette