Unverified Commit 95234fd8 authored by Kroese's avatar Kroese Committed by GitHub
Browse files

feat: Improve compatibility with older CPU's (#467)

parent ebf441ce
Loading
Loading
Loading
Loading
+3 −8
Original line number Diff line number Diff line
@@ -17,15 +17,10 @@ case "${BOOT_MODE,,}" in
    ROM="OVMF_CODE_4M.secboot.fd"
    VARS="OVMF_VARS_4M.secboot.fd"
    ;;
  windows)
  windows | windows_plain | windows_secure)
    ROM="OVMF_CODE_4M.ms.fd"
    VARS="OVMF_VARS_4M.ms.fd"
    ;;
  windows_plain)
    TPM="N"
    ROM="OVMF_CODE_4M.fd"
    VARS="OVMF_VARS_4M.fd"
    ;;
  windows_legacy)
    USB="usb-ehci,id=ehci"
    ;;
@@ -53,7 +48,7 @@ if [[ "${BOOT_MODE,,}" != "legacy" ]] && [[ "${BOOT_MODE,,}" != "windows_legacy"
    cp "$OVMF/$VARS" "$DEST.vars"
  fi

  if [[ "${BOOT_MODE,,}" == "secure" ]] || [[ "${BOOT_MODE,,}" == "windows" ]]; then
  if [[ "${BOOT_MODE,,}" == "secure" ]] || [[ "${BOOT_MODE,,}" == "windows_secure" ]]; then
    SECURE=",smm=on"
    BOOT_OPTS="$BOOT_OPTS -global driver=cfi.pflash01,property=secure,value=on"
  fi
@@ -61,7 +56,7 @@ if [[ "${BOOT_MODE,,}" != "legacy" ]] && [[ "${BOOT_MODE,,}" != "windows_legacy"
  BOOT_OPTS="$BOOT_OPTS -drive file=$DEST.rom,if=pflash,unit=0,format=raw,readonly=on"
  BOOT_OPTS="$BOOT_OPTS -drive file=$DEST.vars,if=pflash,unit=1,format=raw"

  if [[ "${BOOT_MODE,,}" == "windows" ]]; then
  if [[ "${BOOT_MODE,,}" == "windows_secure" ]]; then

    BOOT_OPTS="$BOOT_OPTS -global ICH9-LPC.disable_s3=1"

+49 −12
Original line number Diff line number Diff line
@@ -21,7 +21,8 @@ if [[ "$KVM" != [Nn]* ]]; then
    if ! sh -c 'echo -n > /dev/kvm' &> /dev/null; then
      KVM_ERR="(no write access)"
    else
      if ! grep -q -e vmx -e svm /proc/cpuinfo; then
      flags=$(sed -ne '/^flags/s/^.*: //p' /proc/cpuinfo)
      if ! grep -qw "vmx\|svm" <<< "$flags"; then
        KVM_ERR="(vmx/svm disabled)"
      fi
    fi
@@ -39,7 +40,6 @@ fi
if [[ "$KVM" != [Nn]* ]]; then

  CPU_FEATURES="kvm=on,l3-cache=on"
  HV_FEATURES="+hypervisor,+invtsc,hv_passthrough"
  KVM_OPTS=",accel=kvm -enable-kvm -global kvm-pit.lost_tick_policy=discard"

  if [ -z "$CPU_MODEL" ]; then
@@ -47,14 +47,54 @@ if [[ "$KVM" != [Nn]* ]]; then
    CPU_FEATURES="$CPU_FEATURES,migratable=no"
  fi

else
  if [[ "$HV" != [Nn]* ]] && [[ "${BOOT_MODE,,}" == "windows"* ]]; then

  CPU_FEATURES="l3-cache=on"
    HV_FEATURES="+hypervisor,hv_passthrough"

  if [[ "$ARCH" != "amd64" ]]; then
    KVM_OPTS=""
    if grep -qw "svm" <<< "$flags"; then

      # AMD processor

      if grep -qw "tsc_scale" <<< "$flags"; then
        HV_FEATURES="$HV_FEATURES,+invtsc"
      fi

      if ! grep -qw "avic" <<< "$flags"; then
        HV_FEATURES="$HV_FEATURES,-hv-avic"
      fi

    else

      # Intel processor

      vmx=$(sed -ne '/^vmx flags/s/^.*: //p' /proc/cpuinfo)

      if grep -qw "tsc_scaling" <<< "$vmx"; then
        HV_FEATURES="$HV_FEATURES,+invtsc"
      fi

      if ! grep -qw "apicv" <<< "$vmx"; then
        HV_FEATURES="$HV_FEATURES,-hv-apicv,-hv-evmcs"
      else
        if ! grep -qw "shadow_vmcs" <<< "$vmx"; then
          # Prevent eVMCS version range error on Atom CPU's
          HV_FEATURES="$HV_FEATURES,-hv-evmcs"
        fi
      fi

    fi

    [ -n "$CPU_FEATURES" ] && CPU_FEATURES="$CPU_FEATURES,"
    CPU_FEATURES="$CPU_FEATURES${HV_FEATURES}"

  fi

else

  KVM_OPTS=""
  CPU_FEATURES="l3-cache=on"

  if [[ "$ARCH" == "amd64" ]]; then
    KVM_OPTS=" -accel tcg,thread=multi"
  fi

@@ -69,12 +109,9 @@ else

  CPU_FEATURES="$CPU_FEATURES,+ssse3,+sse4.1,+sse4.2"

fi

  if [[ "$HV" != [Nn]* ]] && [[ "${BOOT_MODE,,}" == "windows"* ]]; then

  [ -n "$CPU_FEATURES" ] && CPU_FEATURES="$CPU_FEATURES,"
  CPU_FEATURES="$CPU_FEATURES${HV_FEATURES}"
    CPU_FEATURES="$CPU_FEATURES,+hypervisor"
  fi

fi