Jump to content
Sign in to follow this  
Followers 0
DeltaUnit38

Possible problem with current OS installation

4 posts in this topic

Recommended Posts

Hello

 

So basically I am planning to install MacOS Sierra sooner or later, but I have a feeling that my current installation (Windows 10 Pro & Ubuntu 16.04) are going to cause trouble, because of Ubuntu's GRUB loader. Both operating systems are installed in UEFI mode, and that's why I am also going to use the Clover loader for my installation. What I just simply wonder is that if GRUB is going to interfere or not.

 

Can I actually make a triple-boot with the current installation or do I have to get rid of Ubuntu and then reinstall it after I've got Clover?

 

Share this post


Link to post
Share on other sites
Advertisement

Are they all on the same drive or separate?

I have windows 10, macOS Sierra and Ubuntu 16.04.1 installed on separate ssd's (well 2 ssd's and an intel m.2) and all boot perfectly with clover from my osx drive.

 

Sent from my SM-G900I using Tapatalk

I boot to clover uefi, select os and it boots. When I select Ubuntu from clover it boots to grub then the os.

 

Sent from my SM-G900I using Tapatalk

Share this post


Link to post
Share on other sites

Are they all on the same drive or separate?

I have windows 10, macOS Sierra and Ubuntu 16.04.1 installed on separate ssd's (well 2 ssd's and an intel m.2) and all boot perfectly with clover from my osx drive.

 

Sent from my SM-G900I using Tapatalk

I boot to clover uefi, select os and it boots. When I select Ubuntu from clover it boots to grub then the os.

 

Sent from my SM-G900I using Tapatalk

 

Nah, the current dual-boot installation is on one single SSD. But if you say is true that when you have Clover and you select Ubuntu at boot-up, then it should not be a problem at all I think. I take it that you had Windows 10 and Ubuntu installed already as well?

Share this post


Link to post
Share on other sites

Yeah I did but as I said they are all on separate drives. Just make sure you have a clover usb driver handy to boot osx after and reinstall clover if needed.

 

Sent from my SM-G900I using Tapatalk

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  
Followers 0

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • By Hicks1gb
      Mi intención al crear esta guía es mostrar las formas de instalación de múltiples sistemas operativos en la Surface Pro 4, y que a poder ser, convivan entre ellas. También busco unificar información para resolver los problemas que surjan y solucionar los ya existentes.
      Voy a intentar en la medida de lo posible ir actualizando el post con la nueva información y consejos que reciba tanto de vosotros, como la que encuentre por el mundo.

      Dicho esto, mi Surface Pro 4 es la versión Core i5, de 128 GB, ampliada a 512GB de almacenamiento interno y 4 GB de Ram.

      Voy a instalar en mi disco duro interno Windows, Linux y Android y Mojave, dejando la tarjeta MicroSD libre.
      Haciéndolo de este modo, siempre nos va a quedar libre nuestro puerto USB.

      Herramientas necesarias (hardware):
      Un segundo ordenador.
      1 pendrive de unos 10GB para la recuperación de Windows en caso de ser necesario.
      1 pendrive de 8 GB para de instalación de Hackintosh.
      1 pendrive de 2GB para la instalación de Linux.
      1 pendrive de unos 512MB para la instalación de Macrium
      1 teclado USB
      1 ratón USB
      1 hub de 4 puertos USB



      Herramientas necesarias (software):

      1.- Rufus (herramienta para crear discos de arranque bajo Windows).
      http://rufus.akeo.ie/?locale
       
      2.- Aplicación EasyUefi (de pago)
      https://www.easyuefi.com/index-us.html

      3.- StopUpdates10 (Herramienta maravillosa que va a deshabilitar las actualizaciones de Windows 10. Se pueden activar de nuevo con un click. El motivo de hacerlo, es que dichas actualizaciones pueden romper el arranque múltiple, aparte de que yo soy de los que prefiere reinstalar el sistema operativo cada X tiempo, que estar cada 2x3 liado con actualizaciones parciales, que suelen fallar más que una escopeta de feria.
      https://greatis.com/blog/thanks-stopupdates10



      Comenzamos por Windows...:
       
      Vamos a partir desde cero, reinstalando Windows en la Surface. Antes de nada, guardar fuera de la Surface todo lo que no queráis perder.

      1.- Crea un pendrive de recuperación de Windows desde el enlace oficial de Microsoft.
      En caso de necesidad, podrás restablecer tu Surface al estado de fábrica con ese pendrive.
      https://www.microsoft.com/surface/es-es/support/warranty-service-and-recovery/downloadablerecoveryimage


      2.- Una vez tengamos a buen recaudo nuestro USB de recuperación de Windows, procedemos a encender la Surface con el botón de volumen+ presionado para acceder a la bios.

      3.- Vamos a "Security" - "Secure Boot" - "Change configuration" y ponemos "None"
      Deshabilitamos también Trusted Platform Module (TPM).

      Una vez hagamos esto, el Surface nos va a permitir iniciar cualquier otro sistema operativo. Nos va a aparecer cuando lo iniciemos una franja roja con un candado (buena señal).

      Utilizamos nuestro pendrive de recuperación de Windows para restaurar por completo la Surface. Iniciamos la máquina con el botón de Volumen + pulsado para acceder a la Bios, y marcamos como inicio "Unidades extraíbles USB" y seguimos los pasos para restaurar la Surface.
      Con nuestro Windows recién restaurado, NO NOS CONECTAREMOS A INTERNET PARA NADA. Deshabilitamos el Wifi !!!

      Lo siguiente que haremos es deshabitar la hibernación, ejecutando lo siguiente como administrador.
      powercfg.exe /hibernate off
       
      También deshabilitaremos en opciones de energía el inicio rápido. Si no lo hacemos, no vamos a poder acceder a las particiones NTFS desde Linux u otro sistema operativo, ya que Windows las bloquea.
      Instalamos la aplicación que ya teníamos descargada "stopupdates10" y simplemente le damos a deshabilitar actualizaciones. No es necesario tocar nada más. De vez en cuando la herramienta debe actualizarse... Una vez deshabilitadas las actualizaciones, reiniciamos Windows y ya podemos conectarnos a internet.

       
      Seguimos con la instalación de GNU/Linux (Kubuntu 18.10 LTS):
      Nos vamos a la página de Kubuntu y descargamos la versión 18.10 64 bits Desktop. Puede usarse cualquier otra distribución.
      http://cdimage.ubuntu.com/kubuntu/releases/18.10/release/kubuntu-18.10-desktop-amd64.iso

      Una vez descargada la imagen ISO del sistema, desde Windows, insertamos una nueva unidad USB de 2 GB y abrimos el programa Rufus, seleccionamos la imagen descargada, nuestra unidad de USB y seleccionamos GPT para UEFI. Si solicita descargar archivos, aceptar y dejar el resto por defecto.
      Una vez termine la creación del disco de arranque de Linux, extraemos la unidad y reiniciamos la Surface.
       
      Iniciamos de nuevo desde USB. Cuando pregunte, le ponemos español y seleccionamos probar el sistema.
      Una vez veamos el escritorio, lo primero que vamos a hacer es conectarnos a internet. Una vez conectados, abrimos una terminal "konsole" y tecleamos los siguientes comandos, uno por uno pulsando intro, y respetando mayúsculas y minúsculas (usar copia y pega):
       
      sudo apt update
      sudo apt install gparted -y
      sudo gparted
       
      Al ejecutar el último comando, se nos va a abrir el gestor de particiones llamado gparted (no cerréis la terminal, o se cerrará gparted).
      En la siguiente captura podéis ver mi esquema de particiones (falta otra para Android)

       
      *La primera de ellas, llamada nvme0n1p1 corresponde con la EFI (no se toca).
      *La segunda de ellas, llamada nvme0n1p2 corresponde con una partición reservada para Windows. (no se toca).
      *nvme0n1p3 es otra partición de Windows. (no se toca).
      *nvme0n1p4 es la partición del sistema operativo Windows 10. Esa partición debemos redimensionarla para dejar espacio al resto de sistemas. Para ello, pulsamos con el ratón encima de ella, botón derecho y pulsamos sobre redimensionar/mover. Reducimos el tamaño de Windows a lo que necesitemos. En mi caso, con un disco duro de 512 GB, he dejado para Windows 100GB (espacio más que suficiente). En la mayoría de casos, con 25 GB llegaría.
       

       
      *nvme0n1p5 sería la partición de Mac una vez instalado el sistema. Desde Linux se vería así.
      *nvme0n1p6 partición de instalación del sistema operativo Linux.
      *nvme0n1p7 Partición de intercambio de datos entre todos los sistemas y donde instalo los juegos de Windows. Le he llamado Steam, vosotros podéis llamarla como queráis.
      *nvme0n1p8 Partición de memoria extendida de Linux.
      Una vez redimensionada la partición de Windows, aplicamos cambios con la "V" que se encuentra debajo de "Editar Ver Dispositivo"
       
      Una vez aplicados los cambios, aparecerá un espacio libre a continuación llamado (sin asignar). Pulsando sobre ese espacio libre vamos a crear el resto de particiones para los otros sistemas.
      Pulsamos el botón derecho del ratón encima, y le damos a Nueva:
       
      Linux >> Necesitamos 2 particiones:
      1.- Para el sistema operativo >> Tamaño: 100GB (o lo que necesitéis) >> Sistema de archivos ext4 >> Etiqueta Kubuntu  >> Nombre de la partición (Kubuntu)
      Aplicamos cambios. Pulsamos de nuevo sobre el espacio libre disponible.
      2.- Para la memoria de intercambio Swap >> Tamaño 1-2 GB >> Nombre partición Swap >> Etiqueta Swap >> Sistema de archivos: linux-swap
      Aplicamos cambios. Pulsamos de nuevo sobre el espacio libre disponible.
       
      Mac OS >> Necesitamos 1 partición:
      1.- Para el sistema operativo >> Tamaño: 100GB (o lo que necesitéis) >> Sistema de archivos fat32 >>Nombre partición: MAC >> Etiqueta: MAC
      Aplicamos cambios. Pulsamos de nuevo sobre el espacio libre disponible.
       
      Android >> Necesitamos 1 partición:
      1.- Para el sistema operativo >> Tamaño 10 GB (o lo que necesitéis) >> Sistema de archivos ext4 >> Nombre partición: Android >> Etiqueta: Android
      Aplicamos cambios.
       
      Intercambio entre sistemas >> Necesitamos 1 partición
      1.- Para almacén de datos que sea visible y usable por todos los sistemas operativos instalados >> Tamaño: Todo lo que os sobre >> Sistema de archivos NTFS >> Nombre partición: Steam >> Etiqueta: Steam
       
      Ahora que ya tenemos la Surface particionada, instalamos Linux, aunque no vamos a realizar la instalación normal, ya que debido a un fallo en el instalador, cuando el sistema intenta instalar el cargador de arranque (Grub) no lo consigue, y la instalación falla. Por ese motivo, vamos a hacerlo desde la terminal:
       
      Hay que iniciar el instalador de Linux desde la terminal konsole, usando el comando:
      sudo ubiquity -b   Con ese comando, se realiza la instalación normal, pero se omite la instalación del grub. Cuando termine la instalación, instalaremos el grub manualmente.   Le damos a Probar Kubuntu                           Llegados a este punto, escogemos manual. Nos van a aparecer todas las particiones del disco duro.   Buscamos nuestra partición de Windows (donde está instalado el sistema Windows 10). 
      Pulsamos sobre la partición, cambiar, tipo de partición NTFS, punto de montaje /media/Windows
      No formateamos nada.   Ahora buscamos nuestra partición de datos, a la que yo llamo Steam. 
      Pulsamos sobre la partición, cambiar, tipo de partición NTFS, punto de montaje /media/Steam
      No formateamos nada.   Ahora buscamos nuestra partición de Linux, a la que yo llamo Kubuntu. 
      Pulsamos sobre la partición, cambiar, tipo de partición ext4, punto de montaje /
      No formateamos nada.   Ahora buscamos nuestra partición de memoria de intercambio a la que yo llamo Swap. 
      Pulsamos sobre la partición, cambiar, tipo de partición Swap   Ahora buscamos nuestra partición de Android, a la que yo llamo Android. 
      Pulsamos sobre la partición, cambiar, tipo de partición ext4, punto de montaje /media/Android
      No formateamos nada.   Veremos abajo del todo que nos pregunta donde queremos instalar el cargador de arranque. Lo dejamos por defecto.           Cuando termine la instalación, NO REINICIAMOS, seguimos probando el sistema. Iniciamos una terminal y ejecutamos: (cambiando si es necesario nvme0n1p1 y nvme0n1p6 por la partición que corresponda con vuestra instalación). Tenéis que localizar vuestra partición EFI y vuestra partición del sistema operativo Kubuntu. Lo podéis ver en la aplicación gparted. En mi caso las particiones EFI y del sistema corresponden con estas: nvme0n1p1 >> EFI nvme0n1p6 >> Partición de instalación del sistema operativo Linux.   Estos son los comandos que hay que ejecutar. Recordar lo que acabo de decir arriba y hacer cambios si proceden. Usar copia y pega. Un comando (una línea) de cada vez, pulsando intro.   sudo mount /dev/nvme0n1p6 /mnt sudo mount /dev/nvme0n1p1 /mnt/boot/efi for i in /dev /dev/pts /proc /sys; do sudo mount -B $i /mnt$i; done modprobe efivars sudo apt-get install --reinstall grub-efi-amd64 sudo grub-install --no-nvram --root-directory=/mnt sudo chroot /mnt sudo update-grub cd /boot/efi/EFI/ sudo cp -R ubuntu/* Boot/ cd Boot sudo cp grubx64.efi bootx64.efi   Ahora podemos reiniciar el sistema y ya deberíamos poder iniciar Windows y Linux desde el grub. Encendemos de nuevo la Surface con el botón de volumen+ apretado para acceder a la Bios. En Boot configuration dejamos solamente activado “ubuntu” y salimos.

      Al iniciarse la Surface, vamos a Linux.
      Nos conectamos de nuevo a internet.
      Ahora vamos a instalar la última versión del escritorio Plasma (Tiene mejoras para pantallas con mucha resolución HiDPI)
      Abrimos una terminal (konsole) y escribimos:

      sudo apt-add-repository -y ppa:kubuntu-ppa/backports       y pulsamos intro. Nos va a pedir nuestra clave de usuario. No aparece nada cuando la tecleamos, es normal. Cuando la escribamos, pulsamos intro.
      sudo apt update
      sudo apt dist-upgrade -y

      Cuando termine, reiniciamos de nuevo el Surface e iniciamos de nuevo con Linux.
      Estas cosillas que pongo ahora son totalmente opcionales. La Surface tiene mucha resolución de pantalla, y muchas cosas se ven demasiado pequeñas. Podemos ponerlas un poco más grandes con estos tips:
      inicio-Equipo-Preferencias del sistema.

      1.- En la sección de Tipos de letra-forzar ppp a 130 aproximadamente
      2.- En la sección de Pantalla y monitor-configuración de la pantalla-escalar pantalla-scale a 2.5x aproximadamente.
      Guardamos cambios y reincidamos. (con eso veremos todo un poco más grande).

      Si utilizamos Firefox o Thunderbird, podemos hacer que se vea más grande. En Firefox tenemos que poner en la barra de búsqueda:
      about:config y buscar la entrada: layout.css.devPixelsPerPx     Ponemos el valor a 2 y cerramos el Firefox.

      En Thunderbird es igual, pero accediendo a esa ruta desde preferencias avanzadas de la aplicación. La cadena a editar el la misma, y el valor también.
       

      Instalando el nuevo kernel que hará funcionar la pantalla táctil y el lápiz:
      La forma más sencilla de hacerlo es crear un "alias". Una vez creado, solo hay que ejecutar esa orden para que el kernel especial se instale o actualice por completo.
      He añadido a este alias la instalación de una aplicación estupenda que elimina publicidad de internet a punta pala. Se llama "hosty". Su función es descargar de internet la última versión de ficheros de publicidad, bloqueándolos desde el archivo hosts del sistema.
      Abrimos una konsole, copiamos y pegamos todo lo siguiente de golpe:
       
      sudo apt-get install -y curl wget && sudo rm /usr/local/bin/hosty ; sudo wget -c https://github.com/juankfree/hosty/raw/master/hosty -O /usr/local/bin/hosty ; sudo chmod +x /usr/local/bin/hosty && hosty
       
      Cuando termine, de nuevo en la terminal ejecutamos (copia & Pega):
      nano ~/.bashrc
       
      Se nos va a abrir un archivo de texto en la terminal donde debemos pegar una línea. Bajamos con la rueda del ratón hasta que encontremos lo siguiente:
      # some more ls aliases
      alias ll='ls -alF'
      alias la='ls -A'
      alias l='ls -CF'

      Y a continuación de este texto, hacemos click y pegamos todo el texto que pongo a continuación en una nueva línea justo debajo:
       
      alias actualizar-surface='hosty && sudo apt-get update && sudo apt-get upgrade && sudo apt-get dist-upgrade && sudo apt-get autoremove && sudo apt-get clean && sudo apt-get autoclean && rm -r linux-surface || sudo apt-get install -y git curl wget sed && git clone https://github.com/jakeday/linux-surface.git ~/linux-surface && cd linux-surface && sudo sh setup.sh'
       
      Una vez añadida esa línea, a continuación copiamos y pegamos también la siguiente, creando otra línea nueva:
      alias fix-surface-touch='xset dpms force off && xset dpms force on'
       
      Esa última línea nos activará un comando para si alguna vez nos falla la pantalla táctil, podamos restaurarla. Para hacerlo, solamente hay que abrir una terminal y escribir:
      fix-surface-touch
       
      Una vez pegadas esas líneas, pulsamos las teclas control + X para que nos pregunte si deseamos guardar el archivo, y le decimos que si.
      Una vez cerrado el editor de texto, ejecutamos lo siguiente (copia & pega):
      source ~/.bashrc
       
      Con eso ya hemos creado un "alias" llamado "actualizar-surface" que al ejecutarlo desde una terminal primero va a recargar nuestras listas de bloqueo de publicidad (hosty), después va a actualizar las fuentes de software del sistema, va a buscar actualizaciones y si las hay las va a instalar. Después de eso, va a instalar el último kernel para que funcione la pantalla táctil, el lápiz, etc en la Surface.
      También se ha añadido el comando "fix-surface-touch" que repara la pantalla táctil si alguna vez se cae y deja de funcionar.
      Procedemos a hacerlo... Abrimos una terminal y ejecutamos:
      actualizar-surface
       
      Cuando lleguemos al final del trabajo que hace ese script, nos va a preguntar varias cosas. La primera de ellas es que si estamos usando una Surface Pro 4. Debemos pulsar intro para confirmar.
      Después de eso, nos va a preguntar otras cosas, a las que debemos responder "yes" y presionar intro cada vez que pare y pregunte hasta que termine Cuando nos pida reiniciar la Surface ya debería estar todo instalado y configurado para funcionar.
      Reiniciamos
       
       
       
      Instalación de Android (BlissOS)
      Descargamos de internet la última versión del sistema operativo BlissOS para nuestra Surface. Tenemos que descargar entre todas las ISOS de todas las versiones que aparecen en el listado "bleeding edge" la más actual que lleve IPTS en su nombre. IPTS significa Intel Precision Touch and Stylus, resumiendo, la pantalla táctil.
      https://sourceforge.net/projects/blissos-x86/files/Official/bleeding_edge/
       
      Una vez descargada la imagen iso, la abrimos con el gestor de archivos comprimidos ark, y la extraemos. (botón derecho, extraer, detectar carpeta).
      Ahora tenemos que darle permisos a nuestra partición de Android, para que podamos escribir en ella. Si la habéis llamado como os dije, y la habéis montado también donde os dije, los comandos, teniendo en cuenta que vuestro usuario se llame fulanito... son estos: (son dos comandos diferentes, y debéis cambiar fulanito por vuestro usuario):
      sudo chown fulanito /media/Android
       
      sudo chmod -Rf 777 /media/Android
       
      Una vez hecho eso, ya podemos copiar todo el contenido de la ISO que hemos descargado a nuestra partición de Android. Estos son los archivos extraídos de la ISO que deben copiarse en la raíz de la partición de Android:
      boot, efi, isolinux, Androidx86-Installv26.0003.exe, kernel, boot.img, initrd.img, install.img, ramdisk-recovery.img, ramdisk.img, recovery.img, system.sfs
       
      De nuevo en Linux, vamos a añadir la entrada de Android Bliss a nuestro gestor de arranque grub. Nos conectamos a internet, abrimos una terminal y copiamos y pegamos esto:
      sudo add-apt-repository -y ppa:danielrichter2007/grub-customizer && sudo apt-get update && sudo apt-get install -y grub-customizer && grub-customizer
       
      Una vez puesta la clave de usuario y abierta la aplicación, pulsamos en un icono que hay con un documento en blanco con un signo + en verde.


       
       
      En la ventanita que aparece, ponemos esto:
      Nombre: Bliss
      Tipo: Otro
      Secuencia: (copiamos todo lo siguiente junto)
      search --no-floppy --fs-uuid --set=root 55336145-4d27-4fd5-b9b1-d973adf5f30e
      linux /kernel initrd=/initrd.img boot=LABEL=Android disk=LABEL=Android quiet root=/dev/ram0 androidboot.hardware=android_x86_64 androidboot.selinux=permissive quiet SERIAL=random SRC= DATA= CREATE_DATA_IMG=1
      initrd /initrd.img
       
       
      Ahora sin cerrar la ventana ni aceptar cambios, nos fijamos en la parte del texto que está en negrita (55336145-4d27-4fd5-b9b1-d973adf5f30e). Esa cadena de números y letras, son el identificador único de MI partición Android, que NO va a ser igual que la TUYA, con lo que NO te va a funcionar.
      Tienes que averiguar cual es la UUID de TU partición y cambiarlo por el mío.
      Hacerlo es muy sencillo, abres una konsole nueva sin cerrar la que ya tienes abierta, la pones a pantalla completa para ver bien, y ejecutas lo siguiente:
      sudo blkid
       
      Al hacer esto, te va a aparecer información de todas tus particiones, incluyendo sus UUID's. Únicamente hay que buscar entre todas las particiones disponibles, tu partición de Android, copiar el UUID, y reemplazarlo por el mío en la entrada del grub-customizer y guardar los cambios.
       
      Una vez hecho eso, nos vamos "Configurador de la apariencia". Ahí únicamente tocamos el tipo de letra (importante). Yo lo tengo en DejaVu Sans Book 21 y funciona y se ve bien.
      Esto es para que se vea el texto del cargador de arranque más grande. Si tocáis otros parámetros, igual os cargáis el arranque y la liamos 
      Ahora vamos a (Configurador de la lista), y buscamos la entrada de Bliss. Pulsamos sobre ella, y usando las flechitas de arriba, la subimos hasta la segunda posición.
      Guardamos cambios y salimos.
       
      Creación del archivo de datos persistentes para Android
      Hay que ejecutar estos dos comandos y esperar un poco, ya que el primero de ellos tarda un rato... De nuevo, suponiendo que habéis montado la partición de Android en /media/Android
      Donde 8000  (8GB) es el tamaño del archivo persistente (donde se guardan los datos de Android. Si elimináis este archivo, es como si formatearais Android). Si vuestra partición Android es de menor tamaño, debéis ajustar esa cifra, cambiándola por 7000, 6000, etc.
       
      sudo dd if=/dev/zero of=/media/Android/data.img bs=1M count=8000   sudo mkfs.ext4 /media/Android/data.img  
      Con esto ya tenemos Android instalado.
      Hay que resaltar que cada vez que queramos actualizar Android, tenemos que abrir Linux, ir al directorio Android, y eliminarlo todo EXCEPTO el archivo data.img
      Luego descargamos la iso de la nueva versión de BlissOS, extraemos el contenido igual que antes y lo copiamos de nuevo en nuestra partición Android. No hay que hacer nada más.
      En caso de que tengamos problemas con los datos de la instalación anterior, como fallos de aplicaciones, servicios, etc, simplemente formateamos el archivo data.img con el siguiente comando:
      sudo mkfs.ext4 /media/Android/data.img   Al hacer eso, cuando inicie Android, será como si iniciara por primera vez, con lo que tendremos que configurarlo todo de nuevo.
      Para iniciar Android, Iniciamos Linux desde el cargador de arranque Clover, y después seleccionaremos la entrada Bliss.
       
      Instalación del Firmware para que funcione la pantalla táctil en Android
      Vamos a utilizar el mismo Firmware que usamos para la pantalla táctil de nuestro Linux.
      Para poder copiar los archivos necesarios en Android, debemos seguir unos pasos. El primero es para poner el sistema de ficheros de Android en modo lectura y escritura, ya que debemos copiar los archivos necesarios en zonas protegidas del sistema:
      Iniciamos desde Linux, e instalamos los programas necesarios.
      sudo apt install nemo-fileroller squashfs-tools rar unrar
      Nos vamos al directorio de instalación de Android, y vamos a ver un archivo llamado system.sfs. Este archivo debe ser extraído con la aplicación que hemos instalado. Nos ponemos encima del archivo, pulsamos el botón izquierdo del ratón, abrir con: y buscamos file-roller
      Una vez se abra la aplicación, le damos a extraer en, por ejemplo, nuestro directorio personal.
      Nos vamos a nuestro directorio personal, y vamos a encontrar lo que hemos extraído, concretamente un archivo llamado system.img
      Lo que tenemos que hacer ahora, es renombrar el archivo original de Android llamado system.sfs, cambiándole el nombre por system.sfs.old
      Una vez le tengamos cambiado el nombre, copiamos el archivo system.img que hemos extraído al directorio raíz de Android.
      Nos vamos al directorio raíz de Android, y pulsamos el ratón derecho en una zona sin nada en la pantalla, seleccionamos abrir terminal aquí.
      Los comandos son los siguientes (2), cambiando los directorios en caso de ser necesario:
       
      sudo mv system.sfs system.sfs.old
       
      sudo cp /home/TU-USUARIO/system.img /media/Android
       
      Ahora que ya podemos modificar archivos del sistema, procedemos a descargar el Firmware. Nos vamos a la siguiente página:
      https://github.com/jakeday/linux-surface/tree/master/firmware
      y escogemos la versión del Firmware que corresponda a nuestra máquina. En nuestro caso, como es una Surface Pro 4, necesitamos la versión v78.
      Os dejo la tabla para otras versiones de Surface a continuación:
       
      v76 para la Surface Book
      v78 para la Surface Pro 4
      v79 para la Surface Laptop
      v101 para la Surface Book 2 15"
      v102 para la Surface Pro 2017
      v137 para la Surface Book 2 13"
       
      Una vez descargado nuestro firmware (v78), descomprimimos el archivo. Nos va a crear un directorio llamado ipts_firmware_v78.
      Ahora lo que tenemos que hacer, es crear una nueva carpeta llamada intel. Dentro de ella creamos otra llamada ipts, y dentro de esta última, deben estar todos los archivos del firmware, que son 10 archivos. Es muy importante que respetéis las mayúsculas y minúsculas de los nombres de carpeta...
       
      Ahora simplemente hay que copiar esa carpeta llamada intel al directorio de Android que corresponda.
      Para ello, la copiamos primero a nuestro directorio raíz de Android desde la terminal:
      sudo cp -rf intel* /media/Android
       
      Ahora ya podemos reiniciar la Surface e iniciar desde Bliss.
      Una vez iniciado Bliss, abrimos una terminal y escribimos:
      su
      Hay que darle permisos de administrador cuando pregunte.
      Ahora copiamos la carpeta intel al directorio /system/lib/firmware
      el comando es el siguiente, suponiendo como siempre que la ruta de archivos es la correcta. Cambiarla si es necesario:
      cp -rf intel* /system/lib/firmware
       
      Si no os da ningún error al copiar, ya podéis reiniciar Bliss. La pantalla táctil debería funcionar después del reinicio.
       
      Instalación de Android Phoenix OS
      Muy buena alternativa a Bliss. Funciona mucho más fluido, pantalla táctil funcionando de serie, trae las aplicaciones de Google instaladas por defecto, root por defecto, posibilidad de escalar texto e iconos de la pantalla, etc, etc.
       
      Para instalar esta rom, no hay que hacer nada especial. Partiendo de la instalación anterior de Bliss, simplemente hay que eliminar todos los archivos de nuestra instalación de Bliss (no formatear la partición), descargar la última versión de Phoenix OS, extraer el contenido y copiarlo en nuestro directorio de Android.
      Las entradas que ya teníamos hechas de antes para el grub nos sirven exactamente igual. Lo único es que el nombre que nos va a aparecer en el grub va a ser Bliss... pero si queremos podemos cambiarlo fácilmente. Abrimos grub-customizer, buscamos la entrada de Bliss que creamos antes y la editamos. únicamente debemos cambiar el nombre de Bliss >> Phoenix OS. El resto permanece igual.
       
      A la hora de eliminar todo el contenido de Bliss para poner en su lugar los archivos de Phoenix OS, recomiendo borrarlo todo a excepción del archivo de datos persistentes "data.img". Más que nada, porque si lo borramos hay que crearlo de nuevo, y tarda un rato. Mejor opción es formatear ese archivo.
      Recordar que los comandos eran los siguientes:
       
      Este primero para crear el archivo data.img por primera vez: (tarda un rato)
      sudo dd if=/dev/zero of=/media/Android/data.img bs=1M count=8000   El segundo para formatear el archivo data.img (no tarda) sudo mkfs.ext4 /media/Android/data.img  
      También recordar que si no os deja eliminar archivos en la partición de Android, debéis ejecutar este comando:
      sudo chown TU-NOMBRE-DE-USUARIO /media/Android
       
      Seguimos... Una vez eliminado todo el contenido de la partición de Android, descargamos la última imágen ISO de Phoenix OS para Pc x86 del siguiente enlace:
      http://www.phoenixos.com/es_ES/download_x86
       
      Una vez descargada, la extraemos con nuestro gestor de archivos comprimidos (ark, file-roller o cualquier otro) y extraemos el contenido de la ISO, copiándo todos los archivos de su interior en nuestro directorio de Android.
      Si hemos eliminado el archivo data.img lo creamos de nuevo con el comando de arriba.
      Si ya le teníamos de antes, lo formateamos con el comando de arriba.
       
      Ya podemos reiniciar la Surface e iniciar desde Phoenix OS.
      Lo primero que tenemos que hacer en el primer inicio es poner un nombre de usuario, conectarnos a internet, ir al panel de control y cambiar los teclados a español, eliminar las versiones inglesas, etc. Tenemos también que buscar la opción de tamaño de pantalla y tamaño de letra y subirlas a nuestro gusto.
      Después de eso, hay que deshabilitar un par de aplicaciones de lo más molestas... Los desarrolladores de la distribución han visto conveniente meter una aplicación de publicidad de lo más molesta.
      Recomiendo encarecidamente instalar Titanium Backup de la tienda (es de pago), que nos va a permitir "congelar" estas aplicaciones para que no molesten.
      Abrimos Titanium, buscamos Phoenix VIP y le damos a congelar. También lo hago con el explorador que trae por defecto y con las apps chinas.
      Otra opción es instalar Blokada desde la página oficial. Esa aplicación open source permite deshabilitar la publicidad tanto de los navegadores como de muchas aplicaciones.
      Dejo un pequeño vídeo de como configurarlo (altamente recomendada y no necesita root)
      https://www.androidsis.com/como-configurar-blokada/
       
      Una vez bloqueado y eliminado el contenido molesto, reiniciamos y ya debería funcionar todo sin complicaciones.
      Aunque Phoenix trae una opción de actualización, NO la uséis, ya que lo único que vais a conseguir es romper el sistema.
      Cuando salga una versión nueva de Phoenix, la descargáis, extraéis y sobreescribís el contenido en vuestra partición de Android, eso es todo.
       

      Instalación de Hackintosh Mojave
      Nos creamos un usuario en esta página para poder descargar los archivos necesarios:
      https://olarila.com/forum/viewtopic.php?f=51&t=6743
       
      Una vez logeados con nuestro usuario, descargamos la imagen del sistema operativo 10.14.3 (o la última disponible).
      También vamos a necesitar la aplicación etcher para Linux:
      https://etcher.io/
       
      Una vez descargados los dos archivos, insertaremos un pendrive de mínimo 8GB, y ejecutamos etcher. Esta aplicación nos va a servir para crear el disco de arranque de Mojave.
      Una vez ejecutado etcher, nos pide la ubicación de la imagen que hemos descargado de Mojave, y también nos pregunta en que unidad USB queremos grabarla. Recomiendo usar un puerto USB 3, así como una unidad USB 3 también, ya que podría tardar un buen rato.
      Una vez creado el pendrive de Mojave, debemos instalar el cargador de arranque Clover. Lo normal sería instalar Clover primero en el pendrive para hacerlo bootable, pero para eso necesitamos tener un Mac...
      Si tenéis un Mac, descargáis Clover Bootloader desde aquí:
      https://sourceforge.net/projects/cloverefiboot/
       
      Y también el archivo Clover Configurator desde aquí:
      https://mackie100projects.altervista.org/download-clover-configurator/
       
      Procedemos a instalar en nuestro Mac la aplicación Clover Configurator, insertamos el pendrive de Mojave que creamos antes y ejecutamos Clover Configurator. Vamos a ver un apartado que pone Montar EFI, que es lo único que debemos tocar de esta aplicación en un Mac real. Le damos a montar EFI, seleccionando la EFI del pendrive de Mojave, no la del disco duro interno del Mac. Una vez tengamos montada la partición EFI del pendrive, instalamos Clover Bootloader. Personalizamos la instalación, seleccionando el USB de Mojave, y en las opciones de instalación, tenemos que marcar las dos primeras, que son:
      *Instalar para UEFI
      *Instalar en la partición ESP
       
      Una vez finalizada la instalación de Clover Bootloader, abrimos la partición EFI del pendrive de Mojave (que estará en el escritorio, en caso de que no aparezca, le damos a propiedades en el finder y marcamos mostrar discos duros.)
      Dentro de esa partición, vamos a ver una carpeta llamada EFI, y dentro de ella otra llamada CLOVER. Pinchamos sobre la carpeta CLOVER y la borramos.
      Descargamos el siguiente archivo, que contiene la carpeta CLOVER modificada para la Surface:
      https://www.mediafire.com/file/jaoxfy42nv3b9t9/Mojave_Surface_Pro_4_OK.zip/file
      Descomprimimos este archivo, y veremos una carpeta llamada también CLOVER. La copiamos y la pegamos donde estaba la otra que borramos.
      Con esto, ya tenemos listo el pendrive bootable de Mojave para la Surface Pro 4.
      Expulsamos el pendrive de Mojave (todas las particiones).
      Si lo hacemos de este modo, para instalar Mojave, iniciamos la Surface con el botón de volumen+ pulsado para acceder a la bios, y marcamos USB (nunca borramos opciones, solamente marcamos y/o desmarcamos).
      Iniciamos desde el pendrive, saltando a la parte siguiente de este tutorial, Vamos ahora a instalar Mojave...
       
       
      Alternativa a la creación del USB de arranque, pero paso obligado una vez Mojave esté instalado en el sistema.
      Este paso es para hacer lo mismo que se hace desde un Mac real (Clover Bootloader), pero como es posible que mucha gente no tenga un Mac, vamos a instalar Clover directamente en la partición EFI de nuestro disco duro, usando Linux y Windows, saltando el paso de instalar Clover Bootloader en el pendrive.
      Para hacer esto, necesitaremos una aplicación llamada EasyUefi.
       
      Iniciamos desde nuestro querido Linux y descargamos el mismo archivo de antes:
      https://www.mediafire.com/file/jaoxfy42nv3b9t9/Mojave_Surface_Pro_4_OK.zip/file
      Descomprimimos el archivo, y copiamos la carpeta CLOVER a nuestro directorio personal.
       
      Abrimos una terminal y montamos nuestra partición EFI con estos comandos, poniendo la clave cuando la pida como siempre y cambiando fulanito por el nombre de nuestro usuario:
      sudo mkdir -p /media/EFI
      sudo mount /dev/nvme0n1p1 /media/EFI/
      sudo su
      sudo cp -R /home/fulanito/CLOVER/ /media/EFI/EFI/
       
      Reiniciamos Linux e iniciamos Windows, ejecutando la aplicación EasyUefi. El cometido de esta aplicación es sencillo, añadir una entrada de booteo (arranque) a la bios del sistema.
      Presionamos en Manage EFI Boot Option.
      Pulsamos el icono de Create a new entry (+ verde).
       
      Type: Linux or other OS
      Description: Clover
      Pulsamos en Disk0 GPT (La primera partición- Hay un circulito blanco en ella)
      File Path: Browse >>  EFI/CLOVER/CLOVERX64.efi
      Pulsamos sobre la entrada llamada Clover que hemos creado, y con las flechas de arriba la ponemos en primera posición.
      Cerramos el programa.
      Con eso, ya tenemos el gestor de arranque Clover instalado en nuestra partición EFI, y va a ser el encargado de iniciar Windows, Mojave y Linux >> BlissOS.
       
      Vamos ahora a instalar Mojave...
      Iniciamos la Surface normalmente con el pendrive del instalador de Mojave insertado. Si hemos instalado Clover Bootloader en el pendrive, iniciamos la Surface desde USB. Si hemos instalado Clover Bootloader en la partición EFI creada por Windows llamada (SYSTEM) del disco duro interno, iniciamos la Surface desde la opción Clover que hemos creado con EasyUefi en la Bios. De un modo u otro, debería iniciarse Clover Bootloader, mostrando los sistemas operativos instalados, y una opción de iniciar el instalador desde el pendrive de Mojave.
      Antes de presionar nada, pulsamos alguna tecla (arriba, abajo, derecha o izquierda) del teclado para que el tiempo se pare y no arranque nada por defecto... Nos vamos a opciones de Clover abajo de todo, buscamos Graphics Injector y dentro de eso, Platform-id.
      Vamos a ver que está puesto por defecto el valor 0x59160000 (que es la opción correcta una vez esté instalado el sistema), pero que si se utiliza durante la instalación, nos dará kernel panic
      Nos situamos encima de este valor y pulsamos intro. Eliminamos este valor, lo cambiamos por 0x12345678 y pulsamos intro. Los cambios realizados desde aquí no son permanentes, y se reinician tras inicio del sistema. Retrocedemos con la tecla escape hasta la ventana principal de Clover, y nos ponemos encima del icono del instalador de Mojave. Para que podamos ver que todo funciona correctamente, sería interesante pulsar la barra espaciadora cuando el icono de instalar Mojave se encuentre seleccionado. De este modo, podremos añadir o eliminar modificadores. En el primer arranque, sería conveniente activar el modificador Verboose (-v), ya que podremos ver si hay algún fallo crítico.
      Iniciamos la instalación del sistema, abrimos la utilidad de discos, seleccionando la partición que habíamos hecho para Mac en formato fat32 y la formateamos en formato nativo de Mac APFS, cambiándole el nombre por Mojave M.2 para no confundirnos luego, cerramos la utilidad de discos y reanudamos la instalación del sistema.
      Cuando termine la primera fase de la instalación, el ordenador se va a reiniciar de forma automática. Hay que estar pendiente de ello para cuando salga de nuevo Clover, podamos cambiar de nuevo el Platform-id a 0x12345678, y activar el modificador -v.
      Marcamos el icono nuevo que ha aparecido para que reanude la instalación (no usamos el mismo de antes). Si nos ponemos encima del icono, nos muestra el nombre. Este paso de cambiar el Plafform-id va a haber que hacerlo varias veces, hasta que el sistema operativo se encuentre totalmente instalado y podamos trastear por el escritorio de forma normal, aunque no tengamos aceleración gráfica y todo funcione a saltos.
      Llegados a ese punto, abrimos una terminal y ejecutamos lo siguiente con copia & pega, poniendo la clave cuando la pida:
      sudo kextcache -i /
       
      y reiniciamos el sistema operativo.
       
      Faltaría un solo paso si no lo habéis hecho ya, que es instalar Clover en la partición EFI (SYSTEM) creada por Windows 10, para no tener que iniciar los sistemas con un pendrive.
      Una vez Mojave esté funcionando correctamente, ejecutamos Clover Configurator, montamos la EFI del disco duro interno (SYSTEM), y una vez montada, procedemos a instalar Clover Bootloader, seleccionando igual que antes durante la instalación las opciones de EFI+ESP.
      Cuando termine la instalación de Clover Bootloader, accedemos a la partición SYSTEM que debería verse en el escritorio (de lo contrario recordar lo de mostrar discos duros en el Finder), buscamos la carpeta CLOVER y la eliminamos, copiando después la que he adjuntado en este Post en su lugar. Una vez hecho esto, podemos expulsar la partición SYSTEM y reiniciar la Surface. Procedemos a acceder a la bios y seleccionar como primera opción de booteo Clover.
       
      En el siguiente inicio de Clover, no tocamos nada y dejamos que inicie la entrada Mojave M.2 de forma normal. Lo único que podemos activar si lo vemos conveniente, es el modificador -v, aunque no sería necesario.
      En principio debería estar el sistema operativo funcionando sin problemas, incluyendo aceleración gráfica, sonido, teclado, trackpad, usb, etc.
      Con esto ya tenemos Windows, Hackintosh Mojave, Android y Linux funcionando en la misma máquina sin darse de tortas entre ellos.


      Ahora, y antes de liarse a navegar con Windows por internet, recomiendo ENCARECIDAMENTE crear una copia de seguridad del disco duro interno ENTERO con la aplicación Macrium (imagen ISO para quemar en un pendrive, que hace copia de seguridad y restauración de discos duros enteros o/y particiones individuales). De este modo, si nos peta la EFI, nos peta Windows, Mojave, etc, podemos restaurar esa partición únicamente sin afectar al resto). También recomiendo instalar telegram desktop en el ordenador, ya que es multiplataforma, y nos va a servir para acceder al grupo donde facilitan estos archivos. El enlace para descargar telegram para Pc es el siguiente:
      https://desktop.telegram.org/
       
      Una vez descargado el instalador de telegram, os unís al grupo siguiente:
      https://t.me/DescargasInside
       
      El archivo que debéis buscar y descargar en ese grupo, se llama Rescue.PE.10.0.64Bits.ES.iso y se puede grabar con Rufus, en GPT para UEFI en un pendrive de muy poca capacidad, ya que ocupa muy poco espacio. Después de crear el pendrive, iniciamos desde él, cambiando previamente en la bios del inicio de Clover a USB. Una vez Macrium inicie, procedemos a crear una copia de seguridad de todas las particiones del disco duro, guardándola en un disco aparte (vamos a necesitar el replicador de puertos USB para eso, ya que la Surface solo tiene un puerto USB, a no ser que excluyamos de la copia de seguridad la partición de almacenamiento (Steam) y guardemos ahí la imagen creada. Una vez creada una copia de seguridad de todo el disco duro de la Surface, podemos pasar esa copia de seguridad a otro ordenador y ya nos podemos liar a trastear sin miedo, configurando Windows con nuestras aplicaciones favoritas, Linux, Mojave y Android. Una vez todo configurado y verificado que no falle nada, podemos hacer una segunda copia de seguridad con Macrium Reflect. Es muy práctico en caso de que algún sistema falle.

      Comentaros que tenéis muchas posibilidades de cargaros todo si actualizáis Windows y/o Hackintosh, con lo que recomiendo simplemente NO HACERLO.



      Llegados a este punto, que funciona y que no?

      Linux:
      https://github.com/jakeday/linux-surface
      El funcionamiento general es fabuloso. El sistema arranca muy rápido y casi todo funciona a la perfección... Wifi, Bluetooth, pantalla táctil, lápiz, sonido, gestión de energía*, Aceleración gráfica, botones de sonido y apagado, teclado y ratón, USB, MicroSD, Indicador de la batería, etc.
      *No funciona la suspensión (realmente si funciona, pero no se puede sacar al equipo de ella). Recomiendo deshabilitarla de momento, al igual que las opciones de cerrar la tapa.

      Android BlissOS:
      El funcionamiento no está aún pulido. Hay cosas que funcionan correctamente, pero otras fallan a la mínima. Imagino que en versiones futuras irá mejorando la estabilidad.
       
      Android Phoenix OS:
      El funcionamiento es muy superior a Bliss. Aunque no es perfecto, funciona prácticamente todo sin hacer nada, tenemos las gapps y root en el sistema, y la pantalla táctil funciona correctamente.
      El único "pero" que le veo es que la pantalla táctil suele fallar cuando ejecutamos algún juego, y al contrario que en Linux, no he encontrado la forma de reactivarla sin tener que reiniciar.

      Mojave:
      El funcionamiento general es tremendo.
      El combo Wifi/Bluetooth va a ser complicado, ya que es un módulo toca narices y no han conseguido aún hacerlo funcionar bajo OSX.
      Recomiendo comprar un dongle Wifi/Bluetooth que funcione bajo Mojave para tener conectividad.
      La pantalla táctil igual... ya caerá, al igual que el indicador de batería y el de brillo de la pantalla.
      Los botones de sonido y la suspensión no funcionan aún.

      Peticiones:
      Necesito conseguir que funcione el indicador de batería y brillo en Mojave. Si alguien consigue hacerlo, le pediría que lo subiera aquí.
      Cualquier tipo de mejora de los sistemas operativos aquí mencionados sería de agradecer.
       
      Si alguien encuentra algún fallo en la guía, necesita aclaración, o los archivos hay que resubirlos, que no dude en decirlo.
       
      Saludos
       
       
    • By Slice
      Since rev 4844 Vector Themes are supported and there are ready-to-use Clovy by Clovy, cesium by Slice and BGM_SVG by Blackosx.
      You may see it's structure to create own theme
      -------------------------------------------------------------------------------------------------------------------------------------------------------
       
       
      Now I want to add vector graphics support in Clover. See rev 4560 and later.
      It is not working yet but designers may begin to create Vector Themes.
      It supposed to consist of SVG elements and has design size. It will be rendered to any screen size scaled from design size.
       
      What application in macOS can create SVG graphics?
      Inkscape is not working in macOS 10.11+. Pity.
      LibreOffice Draw works with SVG but buggy.
      Boxy SVG cost 10$ but looks good enough. It creates the best in simplicity files and have more then enough features.
      Illustrator is good but expensive.
       
      How to improve SVG file?
      Clover has restricted support for SVG. It is your job to make compatible file and as small as possible to speedup rendering.
      Some helps:
      Help:Inkscape – From invalid to valid SVG Inkscape files
      From invalid to valid SVG Adobe Illustrator files
      From invalid to valid SVG files of other editors: BKchem, ChemDraw and CorelDRAW
      Help:Illustrator – Assistance with creating and saving SVG images in Adobe Illustrator that will pass W3C validation
      User:Quibik/Cleaning up SVG files manually
      Later I will write own instructions specific to Clover abilities.
       
      How to create SVG fonts?
      You can google to find ready-to-use SVG fonts.  I found some problems with too beaty fonts: slow rendering and overflow crash. Be careful.
      You can get ttf or otf fonts and convert them into svg by using online WEB services. Not a problem to google.
      But then I want to find a way to simplify the font to reduce a size and speedup rendering.
      You can create own font by FontForge It is opensource and available for Windows, Mac and GNU+Linux. It creates otf font which you can convert to svg font.
       
      Pictures from Badruzeus
      https://www.insanelymac.com/forum/applications/core/interface/file/attachment.php?id=301597
    • By ludufre
      [GUIA] Correção de assinatura BIOS Insyde H2O
       
      Recentemente comprei um notebook Lenovo L440 pra instalar o macOS Mojave e fui substituir a placa wireless pela DW1560 porque a atual não é compatível. Descobri que existia uma whitelist de placas permitidas que as fabricantes estão adotando recentemente (no meu caso utiliza uma bios Phoenix Insyde BIOS H2O).
       
      Procurei em fórums de BIOS MODDING e encontrei pessoas que fizeram o patch pra mim. Só que após substituir a BIOS notei que o computador ficava apitando 5 vezes todas vez que ligava e fui me aprofundar no caso. E foi aí que descobri como resolver isso e por isso criei esse guia baseado nas informações que achei em alguns fóruns russos.
       
       
      Prefácio
       
      Quando a BIOS falha no teste te integridade, algumas funcionalidades Intel AMT param de funcionar e é emitido uma sequência de 5 apitos duas vezes no boot.
      Após modificar para remover whitelist (habilitar placas WI-FI não autorizadas), destravar MSR 0xe2 (hackintosh), habilitar menu avançado, etc. a BIOS não vai passar no teste de integridade causando esse problema.
      Essa verificação de integridade é feita através da assinatura RSA do bloco da BIOS chamado TCPABIOS (mais informações abaixo) com a chave pública no formato modulus 3 também armazenada na BIOS.
      Esse bloco TCPABIOS armazena os checksums de cada volume da BIOS.
       
      O que faremos é gerar novos checkums para esses volumes que foram modificados, gerar um para de chaves RSA (privada e pública), assinar esse bloco com a chave privada e substituir a chave pública.
       
       
      Ferramentas necessárias
       
      - EFITool NE alpha 54: https://github.com/LongSoft/UEFITool/releases
      - HxD 2.1.0: https://mh-nexus.de/en/hxd/
      - OpenSSL: http://gnuwin32.sourceforge.net/packages/openssl.htm (Download -> Binaries)
      - Microsoft File Checksum Integrity Verifier (FCIV.exe): https://www.microsoft.com/en-us/download/details.aspx?id=11533
       
      Passo a passo
       
      Vamos abrir a BIOS modificada, localizar o bloco TCPABIOS e entender sua anatomia.
       
      1. Abra a BIOS no HxD
       

      (Vamos utilizar nesse guia a BIOS modificada no fórum MyDigitalLife.com pelo usuário Serg008 para o notebook Lenovo B590)
       
      2. Busque a palavra TCPABIOS:
       


       
      3. O bloco começa com TCPABIOS e termina com antes de TCPACPUH
       

       
      4. Anatomia:
       
      54 43 50 41 42 49 4F 53 48 31 38 34 61 31 31 2F
      32 36 2F 31 33 49 42 4D 53 45 43 55 52 00 FD 27
      34 2A 35 AB 41 26 39 E3 32 E5 B6 8A D6 49 5B 0B
      77 F9 82 58 48 00 00 00 CE 18 1F 00 00 00 03 00
      00 00 00 00 00 00 27 00 00 00 00 00 00 00 00 00
      00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
      00 00 00 00 00 00 00 00 00 00 00 FF FF 83 04 D4
      52 52 95 C5 D7 21 55 78 0E 5C AD 47 EE C4 3D 1D
      C1 EC 69 03 2B 51 A5 42 61 96 22 F9 7B 88 57 B7
      A8 9D D0 20 DB 5B 11 10 55 07 84 6C 62 DF FA 2F
      6A A8 43 0C 8A 40 AF 79 0D 31 DB 5A 5D C8 2F EB
      F8 7C 87 B0 A6 3D 2A 88 AE 91 9D 88 E3 AA 85 E3
      5A B3 91 7F 28 68 1F BA 92 C4 7E 10 F5 1A 7E 75
      A9 6F CE C0 4F BA FA 79 A5 98 2B 50 60 BA 09 73
      7B 03 D1 0C 3E A2 9C 44 DF E9 F2 92 34 7B
       
      Cinza: Nome e informações do bloco
      Vermelho: Informações dos volumes (Checksum e Cabeçalho)
      Azul: Separação da lista de volumes para a assinatura do bloco
      Verde: Assinatura do bloco TCPABIOS são os últimos 128 bytes
       
      Lista de Volumes:
       
      Cada volume tem o formato: 00 FD 27 34 2A 35 AB 41 26 39 E3 32 E5 B6 8A D6 49 5B 0B 77 F9 82 58 48 00 00 00 CE 18 1F 00 00 00 03 00 00 00 00 00
                                                      (prefixo 3 bytes + checksum 20 bytes + offset 4 bytes + tamanho do volume 6 bytes + separador do fim 6 bytes)
       
      Os volumes são enumerados e utilizam o primeiro byte no prefixo para isso (00 FD 27), começando do 0.
      A BIOS utilizada nesse exemplo possui somente um volume, mas no caso de mais de um volume, seria: 00 FD 27 .., 01 FD 27 ..., 02 FD 27 ...
      - Checksum é o cálculo SHA1 do volume.
      - Offset é a posição do volume dentro da BIOS. Os bytes ficam invertidos, nesse caso seria 00 00 00 48 ou seja: 48h
      - Tamanho do volume também está com os bytes invertidos, então: 1F18CEh
       
      Então é isso. Precisamos corrigir essas informações (checksum, offset e tamanho)
       
      5. Para extrair os volumes abra a BIOS com o UEFITool e veja como identificar os volumes (nosso exemplo há somente um volume, se houvessem outros estariam também dentro de EfiFirmwareFileSystemGuid):
       

       
      Na BIOS original, circulado em vermelho podemos ver o nosso volume.
      Observe que em azul temos Offset e verde o tamanho. Exatamente como verificamos acima no HxD. Já na BIOS modificada vemos que está diferente o tamanho:
      Oridinal: 1F18CEh
      Modificada: 1F12D5h (vamos precisar disso mais tarde)
       
      6. Vamos extrair esse volume escolhendo a opção “Extract as is...”
       
       
       
      7. Utilize esse comando para obter o checkum desse volume: fciv.exe -sha1 File_Volume_image_FvMainCompact.ffs
       

       
      Agora temos o checksum que é 396e0dc987219b4369b1b9e010166302ce635202
       
      8. Substitua as informações no bloco TCPABIOS:
       

       
      Observe que o tamanho do volume precisa ter os bytes invertidos, então se o total são 6 bytes e é 1F12D5h, fica D5 12 1F 00 00 00 no lugar de CE 18 1F 00 00 00.
      Se o offset for diferente, também realizar o mesmo procedimento invertendo os bytes.
      Checksum alterar de 34 2A 35 AB 41 26 39 E3 32 E5 B6 8A D6 49 5B 0B 77 F9 82 58 para 39 6E 0D C9 87 21 9B 43 69 B1 B9 E0 10 16 63 02 CE 63 52 02
       
      Faça esse procedimento para cada volume na BIOS.
       
      9. Agora precisamos gerar o checksum de todo o bloco TCPABIOS mas sem considerar os últimos 131 bytes, ou seja desconsiderar de FF FF 83 + 80 bytes da assinatura anterior.
       
      Copie para um novo arquivo no HxD e salve como tcpabios
       

       
      Utilize o comando para gerar o checksum desse bloco: fciv.exe -sha1 tcpabios
       

       
      Checksum do bloco TCPABIOS: 0da6715509839a376b0a52e81fdf9683a8e70e52
       
      Crie um novo arquivo no HxD e adicione 108 bytes com 00 e cole o checksum no final e salve como tcpabios_sha, ficando assim:
       

       
      10. Agora vamos gerar a chave privada RSA com modulus 3: openssl genrsa -3 -out my_key.pem 1024
       

       
      Assinar o arquivo tcpabios_sha: openssl rsautl -inkey my_key.pem -sign -in tcpabios_hash -raw > tcpabios_sign
       

       
      Agora aproveite para gerar a chave publica: openssl rsa -in my_key.pem -outform der -pubout -out my_key_pub.der
       

       
      E gerar modulus 3 da chave pública: openssl rsa -pubin -inform der -in my_key_pub.der -text -noout
       

       
      Copie e cole a chave em um arquivo de texto para utilizar daqui a pouco. Remova todos os “:” e coloque tudo em uma única linha, ficando assim:
       

       
      11.   Abra o arquivo tcpabios_sign no HxD, copie o conteúdo e substitua a assinatura no final do bloco TCPABIOS:
       
       
       
      12. Agora vamos localizar na BIOS o local da chave pública e substituir. Essa chave começa com 12 04 e termina com 01 03 FF e fica após o bloco TCPABBLK.
       
      A chave fica assim: 12 04 + 81 bytes + 01 03 FF. Faça uma busca por 01 03 FF para localizar mais facilmente. Verifique se antes dos 81 bytes tem os bytes 12 04 para ter certeza que achou.
       

       

       
      Agora substitua pela chave pública que ficou anotado no arquivo de texto anteriormente, ficando assim:
       

       
       
      Salve e está pronto. Sua BIOS está assinada e pronta.
       
    • By ludufre
      [GUIDE] Fix Insyde H2O BIOS signature (5 beeps on Lenovo)
       
      I recently bought a Lenovo L440 laptop to install the Mojave macOS and I replaced the wireless card with the DW1560 because the current one is not compatible. I discovered that there was a whitelist of enabled cards that manufacturers are adopting recently (in my case it uses a Phoenix Insyde BIOS H2O).
       
      I searched the BIOS Modding forums and found people who did the patch for me. But after replacing the BIOS I noticed that the computer keep beeping 5 times every time I boot. So, I went deeper into this issue and that's when I figured out how to solve it. Then I created this guide based on the information I found in some Russian forums.
       
      Preface
       
      When the BIOS integrity test fails, some Intel AMT functionality stops working and a sequence of 5 whistles is issued twice at boot.
      After modifying to remove whitelist (enable unauthorized WI-FI cards), unlock MSR 0xe2 (hackintosh), enable advanced menu, etc. the BIOS will not pass the integrity test causing this problem.
      This integrity check is done through the RSA signature of the BIOS block called TCPABIOS (more information below) with the public key in modulus 3 format also stored in the BIOS.
      This TCPABIOS block stores the checksums of each BIOS volume.
       
      What we will do is generate new checksum for those volumes that have been modified, generate a RSA (private and public) key pair, sign that block with the private key, and replace the public key.
       
       
      Tools needed
       
      - EFITool NE alpha 54: https://github.com/LongSoft/UEFITool/releases
      - HxD 2.1.0: https://mh-nexus.de/en/hxd/
      - OpenSSL: http://gnuwin32.sourceforge.net/packages/openssl.htm (Download -> Binaries)
      - Microsoft File Checksum Integrity Verifier (FCIV.exe): https://www.microsoft.com/en-us/download/details.aspx?id=11533
       
      Step by step
       
      Let's open the modified BIOS, locate the TCPABIOS block and understand its anatomy.
       
      1. Open the BIOS with HxD
       

      (We will use the modded BIOS in the MyDigitalLife.com forum by the Serg008 user for the Lenovo B590 laptop in this guide)
       
      2. Find the word TCPABIOS:
       


       
      3. The block starts with TCPABIOS and ends before TCPACPUH
       

       
      4. Anatomy:
       
      54 43 50 41 42 49 4F 53 48 31 38 34 61 31 31 2F
      32 36 2F 31 33 49 42 4D 53 45 43 55 52 00 FD 27
      34 2A 35 AB 41 26 39 E3 32 E5 B6 8A D6 49 5B 0B
      77 F9 82 58 48 00 00 00 CE 18 1F 00 00 00 03 00
      00 00 00 00 00 00 27 00 00 00 00 00 00 00 00 00
      00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
      00 00 00 00 00 00 00 00 00 00 00 FF FF 83 04 D4
      52 52 95 C5 D7 21 55 78 0E 5C AD 47 EE C4 3D 1D
      C1 EC 69 03 2B 51 A5 42 61 96 22 F9 7B 88 57 B7
      A8 9D D0 20 DB 5B 11 10 55 07 84 6C 62 DF FA 2F
      6A A8 43 0C 8A 40 AF 79 0D 31 DB 5A 5D C8 2F EB
      F8 7C 87 B0 A6 3D 2A 88 AE 91 9D 88 E3 AA 85 E3
      5A B3 91 7F 28 68 1F BA 92 C4 7E 10 F5 1A 7E 75
      A9 6F CE C0 4F BA FA 79 A5 98 2B 50 60 BA 09 73
      7B 03 D1 0C 3E A2 9C 44 DF E9 F2 92 34 7B
       
      Gray: Name and Block Information
      Red: Volume Information (Checksum and Header)
      Blue: Separation of the list of volumes and the block signature
      Green: Signature of the TCPABIOS block are the last 128 bytes
       
      List of Volumes:
       
      Each volume has the format: 00 FD 27 34 2A 35 AB 41 26 39 E3 32 E5 B6 8A D6 49 5B 0B 77 F9 82 58 48 00 00 00 CE 18 1F 00 00 00 03 00 00 00 00 00
                                              (Prefix 3 bytes + checksum 20 bytes + offset 4 bytes + volume size 6 bytes + end delimiter 6 bytes)
       
      The volumes are enumerated and use the first byte in the prefix for this (00 FD 27), starting at 0.
      The BIOS used in this example has only one volume, but in the case of more than one volume, it would be: 00 FD 27 .., 01 FD 27 ..., 02 FD 27 ...
      - Checksum is SHA1 calculation of the volume.
      - Offset is the volume position within the BIOS. The bytes are inverted, in this case it would be 00 00 00 48, equals to 48h
      - Volume Size is also with the bytes inverted, then: 1F18CEh
       
      Then that's it. We need to correct this information (checksum, offset and size)
       
      5. To extract the volumes open the BIOS with the UEFITool and see how to identify the volumes (our example there is only one volume if there were others would also be inside EfiFirmwareFileSystemGuid):
       

       
      In the original BIOS, circled in red we can see our volume.
      Note that in blue we have offset and green the size. Exactly as we checked up on HxD. In the modified BIOS we see that the size is different:
      Original: 1F18CEh
      Modified: 1F12D5h (we'll need this later)
       
      6. Let's extract this volume to calculate the checksum by choosing the "Extract as is ..."
       
       
       
      7. Use this command to get the checksum of this volume: fciv.exe -sha1 File_Volume_image_FvMainCompact.ffs
       

       
      Now we have the checksum that is 396e0dc987219b4369b1b9e010166302ce635202
       
      8. Replace the information in the TCPABIOS block:
       

       
      Note that the volume size must have the bytes inverted, so if the total is 6 bytes and is 1F12D5h, becomes D5 12 1F 00 00 00 in place of CE 18 1F 00 00 00.
      If the offset is different, also perform the same process by inverting the bytes.
      Checksum change from 34 2A 35 AB 41 26 39 E3 32 E5 B6 8A D6 49 5B 0B 77 F9 82 58 to 39 6E 0D C9 87 21 9B 43 69 B1 B9 E0 10 16 63 02 CE 63 52 02
       
      Do this for each volume in the BIOS.
       
      9. Now we need to generate the checksum of the whole TCPABIOS block but without considering the last 131 bytes, that is to dismiss FF FF 83 + 80 bytes from the previous signature.
       
      Copy to a new file in HxD and save as tcpabios
       

       
      Use the command to generate the checksum of this block: fciv.exe -sha1 tcpabios
       

       
      Checksum of TCPABIOS block: 0da6715509839a376b0a52e81fdf9683a8e70e52
       
      Create a new file in HxD and add 108 bytes with 00 and paste the checksum at the end and save as tcpabios_hash, thus:
       

       
      10. Now let's generate the RSA private key with modulus 3: openssl genrsa -3 -out my_key.pem 1024
       

       
      Sign the file tcpabios_hash: openssl rsautl -inkey my_key.pem -sign -in tcpabios_hash -raw > tcpabios_sign
       

       
      Now enjoy to generate the public key: openssl rsa -in my_key.pem -outform der -pubout -out my_key_pub.der
       

       
      And generate public key modulus 3: openssl rsa -pubin -inform der -in my_key_pub.der -text -noout
       

       
      Copy and paste the key into a text file to use soon. Remove all ":" and put everything on a single line, thus:
       

       
      11.   Open the tcpabios_sign file in HxD, copy the contents and replace the signature at the end of the TCPABIOS block:
       
       
       
      12. Now let's locate the location of the public key in the BIOS and replace it. This key starts with 12 04 and ends with 01 03 FF and is after the TCPABBLK block.
       
      The key looks like this: 12 04 + 81 bytes + 01 03 FF. Search for 01 03 FF to locate more easily. Verify that before the 81 bytes have bytes 12 04 to make sure you found.
       

       

       
      Now substitute for the public key that was annotated in the text file previously, thus:
       

       
       
      Save and you're ready. Your BIOS is signed and ready.
    • By Entropi
      PREFACE
       
      I’ve used a 2015 15” MBP as my main system since it was released. I do photo and video editing in the Adobe suite regularly and have been eyeballing the performance of the latest MBP models. I’m on the road all the time, so a laptop is basically my only option.

      After the whole mess with the CPU VRM hardware flaws being made apparent by the poor power management profile shipped at release with the 2018 i9 MBP I’ve been more weary of the hardware design of MacBooks. That’s before I account for losing all USB-A ports, losing the SD card slot (‽), losing reliability and tactility of the keyboard, and losing the ESC key to the touchbar; if I compare the 2018 MBP to my current 2015.
       
      Given these flaws, I have been researching the performance situation comparing the 2018 MBP to the X1 Extreme, XPS 15 9570, and the Razer Blade 15 2018.  These are essentially the only options for a road warrior that needs a high quality panel and the best CPU and GPU that can be crammed into around 4lbs (1.8kg).  
      I used to use a ThinkPad T42p and loved it when it was new. So fast forward to now and the release of the ThinkPad X1 Extreme. It’s a truly tempting machine for an artist, given that the 4K UHD version offers just about the best color gamut available on any laptop panel. I get back the USB-A ports, get one of the fastest SD slots on any laptop, and get one of the best laptop keyboards on the market. That’s before even considering power management and modularity. I’ve been dabbling in learning Machine Learning, so a system with an nVidia GPU (CUDA) is a bonus on that front as well.
       
      For me the best color reproduction on a high resolution display panel was most important. The X1 Extreme has that, so I’ve ordered one. I got it with the fastest i7, base SSD and memory, and have separately purchased two 1TB Samsung 970 Pro M.2 SSDs and 2x16GB DDR4-3200MHz memory (just in case it’s possible to overclock the memory on the X1 Extreme). I got the system for $2,100 from Lenovo USA, and the SSDs ($390 x 2) and memory ($330) from Amazon US for a total of ~$3200.  These are easy to install on the X1 Extreme as the bottom cover is easily removed to reveal the M.2 and SODIMM slots. To compare, the 2018 MBP with the fastest i7, 32GB memory, and 2TB SSD is $4400. So I can save $1200 and get a faster system (on all counts) with a better panel and better connectivity by going with the X1 Extreme.
       
      The only thing I’m compromising is losing the big beautiful haptic touchpad and a bit more refined hardware aesthetic. Though, to be honest, I’ve kept a big thick dual-layer Tech21 case on my 2015 MBP. So I’ll actually be going down in volume and weight by moving to the more rugged ThinkPad. I think I can live without the touchpad.

      Oh, by the way, the 4K UHD panel of the X1 Extreme has touch and decent pen support! Another bonus vs. the MacBook. Though I keep a 12.9” iPad Pro around for my pen work and can’t imagine using a laptop similarly. It’s still nice to have a laptop screen actually respond when I go poke at it accidentally after switching back and forth between laptop and iPad.
       
       
      TOPIC
       
       
      So I want macOS with proper discrete GPU support on a 2018 MacBook class laptop.  That’s not possible on a pure Hackintosh as things stand, but via a macOS virtual machine it looks like it could work with what looks like some relatively bleeding edge support of PCIe UEFI passthrough.

      People have been doing this on Linux hosts to Windows VMs with some great success recently: https://gist.github.com/Misairu-G/616f7b2756c488148b7309addc940b28
      And it looks like that’s coming for macOS VMs as well: https://github.com/kholia/OSX-KVM/blob/a4fb2fd5aae871bdbc371b0cd31d4d8129d0f9ac/UEFI/README.md

      The X1 Extreme, XPS 15 9570, and Razer Blade 15 (2018) are essentially direct competition to the 2018 15” MBP. I would really like to see these three systems get some nicely fleshed out guides for getting maxed out compatibility and performance in macOS running in a VM for these systems. When I get my X1 Extreme I’ll start working on it for that one. I will post updates here. I hope to inspire others with the other two systems (or looking to get them) to do similarly.
       
       
      15” MACBOOK CLASS LAPTOP COMPARISON
       
      I chose the X1 Extreme largely because of the excellent 4K UHD HDR panel (100% of 2D AdobeRGB and 85.5% of 3D AdobeRGB, basically unparalleled), good mix of thermal performance and noise management, and overall ruggedness and connectivity.  If I were a gamer I would go with the Razer 15, but the fast low-gamut 1080p panel just doesn’t work for my purposes. If I were most concerned with aesthetics or battery life (97Wh battery for it vs 80Wh for X1E) I would go with the XPS 15.
       
      I am aware that the second 2018 refresh of the MBP is coming ~Nov 14, with the new AMD Radeon Pro Vega 16 and Vega 20 GPUs, and it looks like the latter might offer up to a 60% performance boost over the Radeon 560X. Maybe it has even given Apple enough time to update the CPU VRM along the way. This could make the performance picture more comparable for the 1050 Ti based X1E and XPS 15. I believe the 1070 Ti based Razer 15 will still win out though.
       
      Still, if you compare the fan and heat pipe solution put into the X1E vs the MBP the MBP just looks wimpy in comparison. MBP has smaller fans, less venting, and only one (smaller, thinner) heatpipe. It’s also more difficult to access if you want to put a better thermal paste or liquid metal on it.  Put simply, the thermal hardware on the MBP is basically the same design for the last 3 years and it can’t keep up with the hex-core processors. So even with the Volta 20 GPU making the MBP competitive again on the graphics end, the MBP will still be falling short on the CPU performance plane. This is before we even look at tuning options.
       
      Getting into tuning, it’s possible to improve thermal performance of all the laptops in this class by around 15-20% by using either a best in class thermal paste like Thermal Grizzly Kryonaut or (if you’re willing to deal with all the caveats that come with using a conductive fluid that permeates other metals) a liquid metal interface like Thermal Grizzly Conductonaut. The liquid metal gives you the best possible conducting interface, and the paste is more forgiving and easier to apply.  Further, it is often possible to stably undervolt the Coffee Lake i7/i9 available in this class of systems to further improve performance, thermals, and power consumption (generally another 10+%).
       
      Apple has deliberately made it impossible to undervolt the CPU on the MBP! This has been true since the first Skylake CPUs a few years ago. You used to be able to use a program called Volta to undervolt your CPU on macOS. This is a huge peeve for me and, combined with the general power and thermal underdevelopment, is one of the main reasons I want to get a competitor’s hardware. As a primer, the default voltage of modern CPUs is typically set conservatively high for the sake of production efficiency.  With the current generation Coffee Lake CPUs it is commonly possible to set the CPU voltage about 100 to 150mv lower safely.  This allows the CPU to run cooler and consume less power. For laptops which are thermally limited (basically everything in this new 6-core 14nm era), this also translates into better performance. It’s a tweak that actually improves reliability of your CPU. So it’s just stupid that Apple has deliberately made this impossible. Shame on them, someone else take my money.
       
      Wrapping up, my biggest quibbles with the X1E (before actually getting it) are that the 4K panel’s responsiveness is about the slowest I’ve seen on a modern panel, and it’s just really not suitable for gaming. There’s also what I consider an annoyingly high level of backlight corner bleed that I’m sure will be distracting during blackboxed video viewing. Hopefully these two issues will be fixed in next year’s iteration.
       
       
      FOOTNOTES
       
      MacBook i9 Thermal / VRM (below-baseline throttling/thrashing) Issue:
      https://www.macrumors.com/2018/07/24/throttling-i9-macbook-pro-power-delivery-chip/
      https://www.kitguru.net/lifestyle/mobile/apple/matthew-wilson/macbook-pro-2018-throttling-fix/
      This was mitigated with software that works around the poor hardware design, but the system would still ultimately perform better if the CPU VRM were redesigned. Non Mac systems with the similar CPUs don’t have this issue and get better sustained performance.
       
      MacBook Nov 2018 Refresh with Radeon Vega 16 and Vega 20:
      https://www.fool.com/investing/2018/11/05/apples-macbook-pro-gets-the-amd-vega-treatment.aspx
       
      MacBook Class Laptop Reviews:
      Lenovo ThinkPad X1 Extreme, 4K: https://www.notebookcheck.net/Lenovo-ThinkPad-X1-Extreme-i7-4K-HDR-GTX-1050-Ti-Max-Q-Laptop-Review.335608.0.html
      https://www.ultrabookreview.com/23223-lenovo-x1-extreme-review/
      https://youtu.be/vOPeXe1ZE74
      https://youtu.be/JgWyGKf_WlM
      Dell XPS 15 9570, 4K: https://www.notebookcheck.net/Dell-XPS-15-9570-i7-UHD-GTX-1050-Ti-Max-Q-Laptop-Review.332758.0.html
      Razer Blade 15 2018, 1070 Ti FHD 144Hz: https://www.notebookcheck.net/Razer-Blade-15-i7-8750H-GTX-1070-Max-Q-FHD-Laptop-Review.305426.0.html
       
      Best Undervolting Guide (keywords: ThrottleStop, Intel XTU):
      https://www.ultrabookreview.com/10167-laptop-undervolting-overcloking/
       
      Undervolting Coffee Lake i7/i9 (2018 MacBook class CPU):
      https://youtu.be/nobnPDtMs-E
      https://linustechtips.com/main/topic/923876-any-information-about-how-coffee-lake-h-series-undervolts/
       
      Replacing Thermal Paste with Liquid Metal on 2018 MBP:
      https://youtu.be/iw4gqfrBN4c ... and follow up: https://youtu.be/JNoZNzOQpVw
       
      Replacing Thermal Paste with Kryonaut on X1E:
      https://www.reddit.com/r/thinkpad/comments/9fyww7/x1_extreme_repaste_undervolt_tdp_limiter_removed/
       
      Replacing Thermal Paste and Undervolting X1 Carbon:
      https://youtu.be/FXR5-HwIre8
       
      Replacing Thermal Paste and Undervolting XPS 15 9570:
      https://youtu.be/ZnFdNGUETSI
       
      Possibly over-conservative BIOS update for thermal throttling on X1E:
      https://www.reddit.com/r/thinkpad/comments/9oqax2/xtu_results_with_x1_extreme_with_liquid_metal/
       
      High Sierra (10.13) drivers only for now:
      https://www.insanelymac.com/forum/topic/324195-nvidia-web-driver-updates-for-macos-high-sierra-update-11032018/
      nVidia “waiting for Apple’s approval” for Mojave (10.14) macOS driver web release:
      https://www.macrumors.com/2018/11/01/nvidia-comment-on-macos-mojave-drivers/

      Breadcrumb Links (other things I found researching this):
      https://forums.servethehome.com/index.php?threads/esxi-6-5-osx-with-gpu-passthrough.12680/
      https://arstechnica.com/civis/viewtopic.php?f=19&t=1432071
       
      https://www.notebookcheck.net/The-Best-Notebook-Displays-As-Reviewed-By-Notebookcheck.120541.0.html
×