Marlin 12

Guía completa: Configurar Marlin 2.x desde cero y no morir en el intento

Recientemente algunos usuarios del canal de Telegram se interesaron sobre como configurar Marlin 2.x. y lo expusieron en el grupo. Visto lo visto pensé, ¿Por qué no redactar una guía completa para configurar Marlin paso a paso?

Era algo que me rondaba la mente desde hacía tiempo, ya que mis impresoras continuaban trabajando con una versión antigua de firmware (concretamente la v1.1.9). Así que sin más miramientos me puse manos a la obra y empecé a escribir.

Esta guía no pretende ser un aburrido y tedioso manual sobre Marlin. Simplemente te mostraré las opciones imprescindibles (o más básicas) a tener en cuenta para configurar Marlin rápidamente.

Utilizaré como ejemplo una impresora «Custom» que diseñé tiempo atrás, y paso a paso descubrirás dónde y cómo configurar Marlin 2.0.x con éxito para tu impresora.

Configurar Marlin 2.x desde cero

Te recomiendo encarecidamente que sigas el orden del artículo a la hora de configurarlo. El motivo es que los parámetros los encontrarás también en ese mismo orden cuando edites el firmware. Y de esta forma no correrás el riesgo de dejarte alguno por el camino.

Lo más importante es perderle el miedo a Marlin, y si este artículo te sirviera de ayuda habría cumplido con creces su objetivo. Conociendo Marlin lograrás entender y disfrutar un poquito más el apasionante mundo de la impresión 3D y todas sus posibilidades.

Y si te surge alguna duda por el camino siempre puedes compartirla en nuestro canal de Telegram. Seguro que algún compañero estará más que dispuesto a echarte un cable.

Os dejo por aquí el índice, así si lo precisas puedes acceder a un parámetro específico a consultar más rápidamente. Vamos entonces con el artículo sin más dilación…

Tabla de contenidos
  1. Configurar Marlin 2.x desde cero
  2. Introducción a Marlin 2.x
  3. Prepara tu propio Marlin para poder personalizarlo
  4. Marlin Builder: Configurando Marlin vía web
  5. Marlin usando las fuentes de código
  6. Archivo "Configuration.h"
  7. Nivelación de la cama (BED_LEVELING)
  8. EXTRA: Trucos interesantes para Marlin
  9. Compilación final de Marlin
  10. Subiendo Marlin a tu impresora
  11. Compilar electrónicas de 32bits con Visual Studio Code y Platform.io
  12. Observaciones finales

Introducción a Marlin 2.x

Guía completa para configurar Marlin 2.0.x desde cero y no morir en el intento

Configurar Marlin 2.x en tu impresora puede parecer un reto a simple vista y algo que solamente programadores avezados pueden conseguir. Pero esa afirmación no puede estar más lejos de la realidad, créeme.

Con un poquito de paciencia y un buen editor de texto, podemos configurar cualquier impresora basada en arduino con las últimas versiones de firmware sin problema alguno (y sin conocimientos de programación). De hecho, Marlin está compuesto de muchísimos archivos, pero solamente necesitaremos modificar uno o dos a lo sumo para compilar un firmware funcional y después subirlo a nuestra impresora.

Por supuesto, puedes personalizar Marlin 2 hasta donde tu quieras, pero ya precisamos de modificar bastantes archivos que de momento no vamos a mencionar o que lo haremos más adelante.

Es probable que te estés preguntando qué necesidad tienes de aprender a configurar Marlin 2.x. Las respuestas pueden ser diversas, pero la que más me convence es que nos aporta seguridad, mejoras de rendimiento, y como no, correcciones de posibles errores reportados en versiones previas.

No obstante, no voy a negar que durante el proceso de configuración y compilación se pueden presentar errores o problemas aparentemente difíciles de solventar. Pero con Google y un poco de paciencia, no deberíamos tener excesivos problemas. Somos Makers, ¿Quién dijo miedo?

En este manual para configurar Marlin 2.x, y tal como mencioné unas líneas arriba, usaremos como ejemplo una impresora «Custom» que tiempo atrás diseñe y construí. Así podrás ver los cambios que efectúo y después aplicarlo a vuestra propia máquina. Abriremos los archivos e iremos cambiando los parámetros por orden (desde el principio del archivo al final).

Sobra comentar que para configurar Marlin 2 necesitarás conocer de antemano todas las características técnicas y componentes de vuestra máquina. Como por ejemplo tipo de extrusor, volumen de impresión, termistor, etc. Así que recopila toda esta información previamente y vamos a ello sin más dilación.

Markets2

Prepara tu propio Marlin para poder personalizarlo

Con esta guía os vamos a facilitar los pasos para poder generar vuestro propio Marlin base para impresoras comerciales o que Marlin disponga de vuestro preconfigurado… aunque podéis usarlo bajando la última version estable desde el repositorio de Marlin y personalizarlo a mano aunque normalmente es aconsejable partir de un preconfigurado de una máquina similar.

Tenemos dos opciones para generar nuestro Marlin base:

  • Usando directamente las fuentes de Marlin desde su Github, aunque también aplicaria si vuestro fabricante dispone de uno personalizado aunque normalmente no están completamente actualizados
  • Usando el Marlin Builder de 3Dwork, con el cual en unos cuantos clicks podréis tener vuestro Marlin listo para compilar.

Marlin Builder

La versión de Marlin Builder web está basada en la versión 2.0.9.1 que no es la última disponible, por lo que si tienes una máquina o electrónica actual que no esté soportada por esta versión o tengas un problema o función que no incluya esta versión te aconsejamos hacer el proceso manual.

Marlin Builder: Configurando Marlin vía web

marlin2

Antes de comenzar esta guía completa sobre como configurar Marlin 2.x desde cero, quería mostraros una aplicación que desarrollé tiempo atrás en 3DWork denominada Marlin Builder.

Como en breve aprenderás, la forma «ortodoxa» de compilar un firmware de Marlin se resume en lo siguiente: Descargar el firmware de su web, editarlo a mano, compilarlo y subirlo a tu impresora (4 pasos).

Como la edición del firmware es bastante tediosa creé una página web denominada Marlin Builder, una «alternativa» a la hora de editar a mano todo ese código. Si lo que deseas es editarlo a mano, cosa que a mi me encanta lo reconozco, sigue leyendo desde el siguiente punto del artículo donde ya explico todo el proceso.

Pero si por el contrario deseas editar vía web el firmware de Marlin, accede a nuestra aplicación en el siguiente enlace: Marlin Builder.

Básicamente, Marlin Builder se compone de un Wizard (o asistente de configuración) qué nos guiará por 5 secciones. Cada una de estas secciones controla los parámetros básicos para poder compilar un Marlin acorde a la mecánica y electrónica. Así que cuando tengas las 5 secciones configuradas, le das a descargar firmware y ya lo tienes listo. Suena fácil ¿Verdad?

Bueno, pues no te alegres tanto ya que Marlin Builder no hace milagros. Si algo lo configuras mal, el compilador te mostrará error. No obstante puedes consultar todos los parámetros en este mismo articulo, y si no tienes experiencia previa, es prácticamente obligatorio que lo leas. Suerte con ello!

Marlin usando las fuentes de código

Lo primero que debes hacer es preparar nuestro entorno para poder compilar el firmware (y editarlo obviamente). Simplemente serán tres sencillos pasos, así que vamos a ello:

Descargando el Firmware Marlin

Muy sencillo,

Es importante recordar las diferentes versiones disponibles
versión release, que es la normalmente estable... ej. 2.1.1.zip
spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2F57FIRGpc2BB1Y7H554JF%2Fimage

versión release con actualizaciones, esta versión contiene resolución de problemas sobre la versión estable... ej.. 2.1.x.zip
spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2F0aJPCgEq0CE9mgfd0864%2Fimage

versión bugfix, son usadas para integrar correcciones para testearsiempre que no sea porque corrije un fallo para nuestra máquina lo ideal es evitarlas… ej. bugfix-2.1.x.zip
spaces%2F MTqLw6KI5FruaRNEMZD

En nuestro caso vamos a optar por descargarlo desde su Github:

image 15
Link de descarga para el repositorio Marlin
image 16
Selección de versión de Marlin

El siguiente paso, si tenemos una impresora comercial, descargaremos los pre-configurados de configuración desde https://github.com/MarlinFirmware/Configurations y siguiendo el mismo proceso que el explicado en el punto anterior:

image 17

IMPORTANTE!!! Recuerda bajar la versión de pre configuraciones que concuerde con la versión de Marlin descargada con release en su nombre. Como referencia existen las siguientes ramas en los pre configurados:
release : son las versiones que se usan con las versiones estables de Marlin que compiles
bugfix : en el caso de que uses un Marlin bugfix, normalmente no aconsejable, deberás usar los pre configurados de esta rama
import : esta rama no es aconsejable, ya que están integrados cambios que no están ligados con versiones de Marlin directamente y pueden contener configuraciones erróneas o problemáticas

Ahora y dispones de los archivos de Marlin en tu ordenador deberemos de descomprimirlos. Idealmente, no dejar la carpeta con tu Marlin dentro de muchas carpetas anidadas ni con símbolos o acentos en los nombres de las mismas, ya que pueden provocar errores en la compilación.

Combinaremos Marlin estable con el pre configurado de nuestra máquina

  • Abrimos el explorador de archivos de Windows y accedemos a la carpeta donde hemos descargado y descomprimido el repositorio de Marlin .
  • Una vez ahí, abriremos otro explorador de ficheros con el contenido del repositorio de pre-configuraciones
  • Encontraremos dos ficheros de pre-configuración de Marlin para nuestra impresora, en la imagen de ejemplo usaremos una Ender 3 con las pre-configuraciones para una placa SKR MINI v2 (la carpeta a buscar sería lo indicado en el cuadro azul de la siguiente captura):
image 18
  • Copiamos los archivos del interior de la carpeta de nuestro pre-configurado (cuadro rojo de la captura anterior y los pegaremos (substituyendo los existentes) en la carpeta «…\Marlin» donde dejamos descomprimido el repositorio de Marlin

Con esto ya tenemos nuestro Marlin listo para compilar!!!

Instalación de software necesario para la edición y compilación de Marlin

El siguiente paso es instalar el software necesario, para ello descargue e instale los siguientes programas:

  • Python: https://www.python.org/downloads/ tambien puedes descargarlo desde la Store de Apps de Windows que en algunos casos realiza una instalación de forma más correcta
  • Visual Studio Code: https://code.visualstudio.com/A pesar de que parezca que Python y Git no se usan en ningún paso, son requerimientos de Visual Studio Code para este tutorial
  • Una vez instalados ambos programas, vedemos instalar el plugin PlatformIO en Visual Studio Code, para ello seguiremos los siguientes pasos:
  • Presionamos los cuadrados del menú izquierdo
  • en el buscador escribimos «PlatformIO»
  • presionamos sobre le rectángulo verde de instalar
image 19

Posibles soluciones a problemas en la instalación de la extensión Platformio:
Instala Python antes, tal como se sugiere en esta guía, desde su web o la App Store de Windows
Ejecuta VSC como administrador, al menos durante la instalación de las extensiones necesarias, así evitaras que en determinadas configuraciones de Windows ciertas acciones estén restringidas o bloqueadas
– Ves a «Aplicaciones y características» en caso de Windows, eligiremos la opción de «Alias de ejecución de aplicaciones» desactivando el instalador de aplicaciones python.exe y python3.exe. Una vez realizado este paso reiniciaremos VSC y volveremos a intentar la instalación.
Asegúrate que tú antivirus/firewall no está bloqueando el proceso de VSC/instalación Platformio ya que partes del proceso requieren descargar módulos desde Internet.
– Si no ha funcionado… empieza de cero y en el orden correcto de instalación:
Desinsta completamente VSC y cualquier otro componente relacionado que instalaste
Lanzar un limpiador de registro como CCleaner, PrivaZer o similar, eliminando cualquier referencia a aplicaciones que no sean necesarias
Borrar cualquier directorio que quede relacionado con estas tareas de compilado de Marlin
– Instalar todo de cero siguiendo los pasos de la guía de esta guía

Comprobaciones para verificar que Python está correctamente instalado (depende de version de Python instalada y de sistema operativo), ya que es una parte fundamental tanto de la instalación de Platformio y para que funcione:

– Ejecutar desde una línea de comandos (tecla Windows + R -> cmd.exe)
echo %PATH% – esto debería retornar un listado de directorios donde uno de ellos debería de ser el de Python y hay que asegurarse que apunte a la versión compatible con nuestra versión de Platformio… ejemplo, el path muestra una version 2.5 y nuestro Platformio necesita Python 3.6+
echo %PYTHONPATH% – al igual que el anterior debería retornar el path de Python
– python –version – en el caso de que esté correcto lo anterior debería retornar la versión de nuestro Python instalado
pip –version – pip es un instalador de paquetes de Python y también puede ser necesario para algunas acciones

Lista de alternativas si no es posible hacer funcionar VSC+Platformio:
Usar Sublime en lugar de VSC
– Usar cualquier editor de textos y lanzar Platformio desde linea de comandos
– Usar Atom en lugar de VSC

Compilando nuestro Marlin

Una vez tenemos nuestro Marlin a nivel de ficheros y el software necesario instalado correctamente toca compilarlo para poder generar el fichero a usar en nuestras impresoras:

  • Una vez realizado este paso, abrimos Visual Studio Code, presionamos sobre el icono con dos documentos del menú izquierdo, y a continuación sobre le botón azul de «Agregar carpeta»
image 20
  • Buscamos la ubicación donde tenemos nuestro repositorio Marlin y presionamos Agregar:
image 22

Os aconsejamos no tener la carpeta con vuestras fuentes de Marlin en muchos directorios anidados ya que esto puede provocar algunos problemas.

Lo ideal es tenerlo en la raíz de cualquiera de vuestras unidades, ej. C:/Marlin

  • En Visual Studio Code, seleccionamos el archivo plaformio.ini del área de trabajo de Marlin que acabamos de añadir.
  • Editamos la fila de «default_envs» y sustituimos » megaatmega2560 » por el adecuado para nuestra placa/impresora, haciendo scroll en este documento encontraras diversas placas, encuentra la tuya y substituye «megaatmega2560» por tu placa en caso de que sea necesario
image 23

Otro truco para encontrar cual es nuestro default_envs si solo conocemos la placa que tenemos que poder en MOTHERBOARD dentro de /Marlin/configuration.h es ir al fichero pins de Marlin (Marlin/Marlin/src/pins/pins.h) donde buscaremos por nuestro MOTHERBOARD y en la parte final de la linea encontraremos esa información:
spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2FWPQnoNreVfKvO50fQb6B%2Fimage
En la captura anterior podéis ver un ejemplo para una SKR MINI V3 donde:
1.encontraréis los valores a poner en vuestro platformio.ini en ocasiones podéis encontrar varios, normalmente usar el primero
2.hace referencia a la carpeta donde se encuentra el fichero pins de nuestra electrónica en el caso que tengamos que averiguar el ID de un pin o cambiar el rol a alguno

  • A continuación, si queremos hacer cambios en la configuración básica de nuestra impresora, ya sea porque le hemos hecho una modificación o para mejorar algún ajuste, desplegamos la carpeta Marlin y nos aparecerán los dos archivos de configuración. Podéis encontrar información de opciones básicas de Marlin en el siguiente link de su documentación o explicado de una forma más “sencilla” en esta guía de Marlin.
image 21
  • Una vez realizados los ajustes deseados, presionamos sobre el botón de compilar, este se encuentra en la parte inferior izquierda y tiene forma de «check»
image 25

Para errores del tipo «IncludePath»/ faltas de librerías se aconseja borrar la caché:
– borrar la carpeta .pio
– borrar la carpeta .vscode
– hacer click en el icono de papelera (Clean) de la barra azul de Platformio
– Del menú de Platformio lanzar un Rebuild IntelliSense Index o el icono de basura de la barra inferior azul del VSC
Si no funciona lo ideal es desinstalar y reinstalar las extensiones C++ y Platformio

  • Cuando ya esté compilado el código, vamos a la carpeta: «…\Marlin\.pio\build\xxxx» donde encostraremos un fichero llamado «firmware.bin» o similar dependiendo de las características que necesite nuestra electrónica.

En el caso de ejemplo se describe el proceso para una placa de 32b en las cuales es suficiente copiar el fichero generado en la tarjeta SD de nuestra impresora.
Para impresoras más antiguas el fichero generado suele ser un .hex el cual con la impresora conectada por USB podemos directamente subir desde VSC o usar PrusaSlicer o Cura para actualizar nuestra impresora.
Recuerda que es posible que VSC no lo haga directamente en el caso de que no instales los drivers de tu placa y sea capaz de detectar correctamente el COM que se crea o tengas, por ejemplo, Cura abierto

  • Copiamos este fichero en una tarjeta SD vacía en el directorio raíz o seguiremos el proceso adecuado para nuestra electrónica.
  • Extraemos la SD del ordenador
  • Apagamos la impresora (Desconectamos el USB y la alimentación si están ambos conectados)
  • Esperamos unos 30 segundos
  • Colocamos la tarjeta SD con el nuevo Firmware
  • Encendemos la Impresora, tras unos segundos, veremos como esta instalando el nuevo firmware, poco después, y se iniciara con nuestro nuevo Marlin instalado.

Actualizando nuestro Marlin a una nueva versión

Muchos usuarios ven muy complicado el proceso de actualización de la versión última cocinada por ellos a una nueva, a continuación os damos algunos consejos de como realizar el proceso para que sea más sencillo.

spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2FrffdBUbLeWs7bre2Q6gB%2Fimage

Descargar Marlin desde documentación

spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2FzigAGeydoF8K13THDOsR%2Fimage

Descargar Marlin desde su Github, es importante seleccionar la rama adecuada en la esquina superior izquierda.

  • Una vez descargado y descomprimido añadiremos esa carpeta a nuestro proyecto en VSC junto con la antigua versión
spaces%2F MTqLw6KI5FruaRNEMZD
  • Ahora que tenemos ambos directorios en nuestro proyecto tan solo tendremos que usar la herramienta de comparacion que lleva incluida VSC para comparar los ficheros de configuración de Marlin
    • platformio.ini, es el fichero donde básicamente encontraremos el env de nuestra electrónica
    • Marlin/configuration.h, fichero donde normalmente habilitaremos las funciones y configuración de la impresora/electrónica/extensiones
    • Marlin/configuration_adv.h, similar al anterior pero donde encontraremos ciertas funciones avanzadas
  • Para comparar dos ficheros y desde el panel lateral donde se muestra la estructura de ficheros y carpetas de nuestro proyecto (Explorer) sobre el fichero a comparar de nuestra antigua versión pulsaremos Select for Compare del menú que aparece al hacer click derecho sobre el
spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2FsQsJII4bfGqBfOavzwtj%2Fimage
  • A continuación haremos lo mismo pero con el fichero de nuestra nueva versión pero en este caso seleccionaremos la opción Compare with Selected y nos aparecerá una nueva pantalla con la comparación entre ellos
    • En la parte superior marcada en la captura siguiente veremos el nombre y carpeta de los ficheros a comparar
    • En la parte central vemos como marca los cambios, en el primer bloque indica en rojo las partes que no incluye el destino (rojo), el central donde indica cambios en ambos sitios y la que normalmente usaremos para detectar ajustes (rojo/verde) y la parte inferior (verde) donde encontrarás lo que se encuentra en el nuevo y no en el antiguo
spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2FdtPPoIg8vfQ2ycpo5b5I%2Fimage

— podéis invertir el orden de selección de ficheros si el código de colores os es más amigable
— os aconsejamos que siempre se añadan comentarios, con // al final de las líneas que modifiquéis, ya que os será más sencillo identificar cambios
— en ocasiones puede que funciones cambien de sitio o nombre así como el formato de valores, aquí tan solo es fijarse y leer los comentarios del propio código

  • Una vez ajustados todos los cambios solamente toca cargar el nuevo proyecto en Platformio como os explicamos al inicio de la guía y compilar ajustando cualquier error que nos aparezca, ya que normalmente los errores suelen ser bastante descriptivos.

Últimos Consejos

  • Si vas a actualizar una impresora y no tienes los ficheros de Marlin originales y has hecho cambios en la configuración de la pantalla te aconsejamos hacer un M503 desde un cliente de terminal como Pronterface y guardarte la información que devuelve ya que son los valores de la EEPROM muy útiles a ajustar en tu nuevo firmware
  • Recuerda que es aconsejable después de subir el firmware cargar los valores de fábrica de la EEPROM, esto lo puedes hacer por terminal con un M502 y seguido un M500 o desde la pantalla en modo Marlin en Configuración/Restaurar y seguido Configuración/Salvar EEPROM… además del M503 con el que podrás listar los valores de tu EEPROM para asegurarte que son correctos.

Entender como Marlin utiliza su RAM y/o EEPROM de la electrónica de tu impresora para guardar ciertas configuraciones puede llegar a ser algo confuso al inicio y si no lo hacemos correctamente puede ocasionar problemas al perder ciertos ajustes al reiniciar nuestra máquina.
Marlin emplea lo que llamamos EEPROM, que puede estar en un chip de memoria dedicado o integrada en una zona reservada por Marlin en la propia ROM de la electrónica… siendo estas las más aconsejables/comunes también contamos con la opción de guardar nuestra EEPROM en la SD de nuestra electrónica donde crea un eeprom.dat (depende de la versión de Marlin este nombre puede variar).
En esta EEPROM Marlin guarda valores de configuración que suelen ser ajustables por el usuario, esto permite un ajuste más sencillo sin requerir tener que ajustar estos valores en las fuentes de Marlin, compilar y aplicar el nuevo firmware a nuestra máquina.
Al arrancar Marlin lo que hace es cargar los valores guardados en la EEPROM (memoria no volátil) a la RAM (que es una memoria volátil) para poderlos usar, consultar y ajustar durante nuestras impresiones, al apagar la máquina esta RAM se borra para realizar el proceso de carga de valores de la EEPROM al arrancar de nuevo Marlin.
A continuación os explicaremos algunos gcodes que vamos a disponer para gestionar esta EEPROM, cuando la tengamos activa activando EEPROM_SETTINGS, y como usarlos en cada caso:
M500 (Save Settings) El gcode M500 (Save Settings) guarda la configuración que tengamos activa en nuestra RAM a la EEPROM para que los cambios realizados no se pierdan al apagar la máquina. También podemos lanzar este comando desde la pantalla modo emulación Marlin con Store Settings o en pantallas táctiles, suelen contar con opciones para realizar el proceso también.
marlin m500
M501 (Restore Settings) El gcode M501 (Restore Settings) carga los valores de nuestra EEPROM sobre nuestra RAM, básicamente realiza el proceso contrario que M500. Normalmente, el uso normal del M501 es para deshacer ajustes realizados en nuestra RAM y que no fueron aplicados a nuestra EEPROM. También desde la pantalla modo emulación Marlin disponemos de la opción Load Settings con la que ejecutaremos el M501. spaces%2F MTqLw6KI5FruaRNEMZD 887967055%2Fuploads%2FNtiFahGKKzKMQ6y1NsUC%2Fimage
M502 (Factory Reset) Con M502 (Factory Reset) cargaremos las configuraciones incluídas en el firmware, no en la EEPROM, en nuestra RAM asegurándonos que volvemos a los valores originales de nuestro firmware. Suele ser aconsejable realizar un M502, seguido de un M500, cada vez que apliquemos una nueva versión de firmware a nuestra máquina ya que de esta forma cargamos los valores del nuevo firmware reseteando cualquier resto de configuraciones que tuviéramos del anterior en nuestra EEPROM. Es importante decir que en últimas versiones de Marlin, en el caso de detectar cambios significativos en la estructura de la EEPROM con respecto a nuevo firmware, ya nos va a sugerir por pantalla que realicemos este Reset de la EEPROM.marlin m502
M503 (Report Settings) El gcode M503 (Report Settings) nos va a permitir mostrar los valores de nuestra RAM por la consola serial (Pronterface por ejemplo) lo cual es algo extremadamente útil para verificar que valores está usando nuestra máquina verdaderamente. En versiones actuales de Marlin contamos con una función llamada CONFIGURATION_EMBEDDING que nos permitirá añadir el parámetro C a nuestro M503 y que nos deje un fichero zip en nuestro SD, siempre que sea posible, con los valores de nuestra RAM en formato texto. marlin m503
M504 (Validate EEPROM) Por último contamos con M504 (Validate EEPROM) que nos va a validar que el formato/estructura de EEPROM es correcta para la versión de nuestro firmware, dado que en el caso de que no lo fuera nuestro firmware podría no arrancar correctamente en determinadas circunstancias.
marlin m504

  • Las placas actuales se genera un firmware.bin que se pone en la SD, en estos casos si el proceso de actualización se hizo de forma correcta este fichero queda renombrado a .CUR. Así que para comprobar si el proceso fué de forma correcta extrae la SD después de realizar el proceso de actualización y comprueba desde tu ordenador que el .BIN cambió a .CUR
  • Otras placas, normalmente antiguas de 8b, se «quema» directamente el nuevo firmware en la placa con lo que es necesario tenerlas conectadas por USB. En algunos casos puede dar problemas al programarla por USB por lo que puedes ir a la ubicación donde dejó el binario compilado… en estos casos es un fichero .hex normalmente… y subirlo desde otras herramientas especificas para tu impresora, los slicers/fileteadores como PrusaSlicer o Cura pueden realizar este paso de forma bastante sencilla también

Archivo «Configuration.h»

Como comenté anteriormente existen 2 archivos principales que gestionan todo a la hora de configurar Marlin 2.0.x. Por supuesto, existen muchos más cambios y modificaciones que podríamos hacer pero para nuestro propósito actual no son necesarios de momento (modificaciones del menú original, logotipos, etc.)

Así que vamos a comenzar a editar el archivo Configuration.h con el editor que hemos escogido (en mi caso Sublime), y seguiremos por orden las distintas opciones más comunes a tener en cuenta. Comentar que este archivo contiene las configuraciones principales de hardware, idiomas y controladores, así como configuraciones para las características y componentes más comunes de nuestra impresora.

En blanco, podréis ver las opciones que he activado (o que vienen activadas por defecto), y en gris oscuro las opciones que están desactivadas. Para activar una opción solamente debemos eliminar las dos barras «//» delante del parámetro en cuestión. Y para desactivarlas lo contrario, añadirlas. Si eres programador ya estarás bastante familiarizado con este procedimiento.

En el supuesto que nos dejemos algún parámetro en el tintero debido a la innumerable cantidad de impresoras existentes, no dudéis en indicarlo en los comentarios al final del artículo. De esta manera iremos completando poco a poco toda la información y podrá ser útil a más usuarios.

Logotipo Marlin (SHOW_BOOTSCREEN)

Es el logotipo de Marlin que aparece al arrancar el firmware. Por defecto aparece activo, podemos desactivarlo si lo deseamos sin problema alguno. No es algo imprescindible para configurar Marlin 2 pero quizá hasta liberemos algo de memoria si vas muy justo.

Puedes también poner tu propio logo o imagen personalizada, pero eso lo explicaremos al final de esta guía en la sección «Trucos interesantes para Marlin«.

// Show the Marlin bootscreen on startup. ** ENABLE FOR PRODUCTION **
#define SHOW_BOOTSCREEN

Puertos de comunicación (SERIAL_PORT y SERIAL_PORT_2)

Son los puertos de comunicación de nuestra electrónica. En principio el primero no deberías modificarlo salvo que dispongas de alguna electrónica exótica. El segundo yo lo dejo deshabilitado porque dispongo de una electrónica MKS Gen v1.4.

Si tu placa fuera una SKR V1.4 o SKR V1.4 Turbo deberías activar SERIAL_PORT_2 y poner el valor -1 (tal y como esta por defecto). Y para electrónicas SKR GTR V1.0 deberás poner los valores -1 y 3 respectivamente en SERIAL_PORT y SERIAL_PORT_2.

Estas son ciertamente las electrónicas con las que estoy más familiarizado. Para otras deberás buscar los valores por Internet, algo que no te costará demasiado tiempo de localizar.

/**
* Select the serial port on the board to use for communication with the host.
* This allows the connection of wireless adapters (for instance) to non-default port pins.
* Serial port -1 is the USB emulated serial port, if available.
* Note: The first serial port (-1 or 0) will always be used by the Arduino bootloader.
*
* :[-1, 0, 1, 2, 3, 4, 5, 6, 7]
*/
#define SERIAL_PORT 0

/**
* Select a secondary serial port on the board to use for communication with the host.
* :[-1, 0, 1, 2, 3, 4, 5, 6, 7]
*/
//#define SERIAL_PORT_2 -1

Velocidad de comunicación (BAUDRATE)

Velocidad a la que conectaremos nuestro ordenador a la impresora, por defecto es 250000 así que la dejaremos así.

Si por un casual tuvieras problemas de comunicación con tu impresora puedes bajar la velocidad de este parámetro para intentar solventarlo.

/**
* This setting determines the communication speed of the printer.
*
* 250000 works in most cases, but you might try a lower speed if
* you commonly experience drop-outs during host printing.
* You may try up to 1000000 to speed up SD file transfer.
*
* :[2400, 9600, 19200, 38400, 57600, 115200, 250000, 500000, 1000000]
*/
#define BAUDRATE 250000

Placa base o electrónica (MOTHERBOARD)

Parámetro importantísimo. Aquí seleccionaremos la electrónica que tenemos instalada en nuestra impresora 3D. Como hay bastantes electrónicas disponibles, tendremos que buscar cual es la nuestra y el valor a colocar aquí.

Disponéis de un listado de electrónicas compatibles a utilizar en el archivo «boards.h«. Este se encuentra en la siguiente ruta de vuestro firmware Marlin: \Marlin\src\core\boards.h

En mi caso, mi impresora 3D utiliza una placa MKS Gen v1.4. Para ella debo escribir «BOARD_MKS_GEN_13» como podéis comprobar en el ejemplo. Vosotros configurad la que tengáis.

// Choose the name from boards.h that matches your setup
#ifndef MOTHERBOARD
#define MOTHERBOARD BOARD_MKS_GEN_13
#endif

Nombre de tu máquina (CUSTOM_MACHINE_NAME)

Esta es fácil, el nombre que deseas que tenga tu nueva impresora configurada. Por defecto te darás cuenta que viene desactivada, de allí que aparezcan estas 2 barras «//» delante del #define.

Eliminaremos las 2 barras y dejaremos la configuración de esta manera:

// Name displayed in the LCD "Ready" message and Info menu
#define CUSTOM_MACHINE_NAME "Pulsar X1 PRO"

Número de extrusores (EXTRUDERS)

Aquí vamos a configurar en Marlin el número de extrusores que tiene nuestra impresora 3D. Por defecto el valor inicial es 1, ya que la mayoría disponen de un extrusor. Si no es tu caso, introduce el número de extrusores correcto.

// This defines the number of extruders
// :[1, 2, 3, 4, 5, 6, 7, 8]
#define EXTRUDERS 1

Diámetro del filamento (DEFAULT_NOMINAL_FILAMENT_DIA)

En este apartado seleccionaremos el tipo de diámetro que gasta nuestra impresora. Por defecto viene 3.0, algo extraño ya que ahora la mayoría de las impresoras ya suelen operar en 1.75 de diámetro. Deberemos cambiarlo, muy importante 🙂

// Generally expected filament diameter (1.75, 2.85, 3.0, ...). Used for Volumetric, Filament Width Sensor, etc.
#define DEFAULT_NOMINAL_FILAMENT_DIA 1.75

Kit multimaterial de Prusa (PRUSA_MMU2)

Activarlo si has instalado en tu impresora 3D el kit multimaterial original de Josef Prusa o algún clon chino que hay disponibles en el mercado. Si no es así, déjalo como está, con las dos barritas puestas.

/**
* Prusa Multi-Material Unit v2
*
* Requires NOZZLE_PARK_FEATURE to park print head in case MMU unit fails.
* Requires EXTRUDERS = 5
*
* For additional configuration see Configuration_adv.h
*/
//#define PRUSA_MMU2

Sensores de temperatura (TEMP_SENSORS)

En esta sección del firmware Marlin definiremos los sensores de temperatura existentes en nuestra impresora 3D. En esta última versión, la 2.0.7.2, se ha añadido soporte para más extrusores (con un total de 11 soportados) contando un sensor para el habitáculo.

Como podéis comprobar existen un montón de ellos, y en el propio código os aparece un listado. En el caso que no dispongas de información acerca del tuyo, prueba a consultar en Google ya que probablemente estará documentado de algún otro usuario con tu misma impresora.

Por defecto solamente viene configurado el TEMP_SENSOR_0 con valor «1». En mi caso, allí debo colocar el valor «5».

Como además dispongo de una cama calefactable, para mejorar la adherencia durante la impresión y evitar problemas de Warping, configuro TEMP_SENSOR_BED con el valor 1. El resto lo dejo a 0 ya que no dispongo de más extrusores ni de habitáculo caliente (Chamber Temp).

/**
* --NORMAL IS 4.7kohm PULLUP!-- 1kohm pullup can be used on hotend sensor, using correct resistor and table
*
* Temperature sensors available:
*
*    -5 : PT100 / PT1000 with MAX31865 (only for sensors 0-1)
*    -3 : thermocouple with MAX31855 (only for sensors 0-1)
*    -2 : thermocouple with MAX6675 (only for sensors 0-1)
*    -4 : thermocouple with AD8495
*    -1 : thermocouple with AD595
*     0 : not used
*     1 : 100k thermistor - best choice for EPCOS 100k (4.7k pullup)
*   331 : (3.3V scaled thermistor 1 table)
*     2 : 200k thermistor - ATC Semitec 204GT-2 (4.7k pullup)
*     3 : Mendel-parts thermistor (4.7k pullup)
*     4 : 10k thermistor !! do not use it for a hotend. It gives bad resolution at high temp. !!
*     5 : 100K thermistor - ATC Semitec 104GT-2/104NT-4-R025H42G (Used in ParCan & J-Head) (4.7k pullup)
*   501 : 100K Zonestar (Tronxy X3A) Thermistor
*   512 : 100k RPW-Ultra hotend thermistor (4.7k pullup)
*     6 : 100k EPCOS - Not as accurate as table 1 (created using a fluke thermocouple) (4.7k pullup)
*     7 : 100k Honeywell thermistor 135-104LAG-J01 (4.7k pullup)
*    71 : 100k Honeywell thermistor 135-104LAF-J01 (4.7k pullup)
*     8 : 100k 0603 SMD Vishay NTCS0603E3104FXT (4.7k pullup)
*     9 : 100k GE Sensing AL03006-58.2K-97-G1 (4.7k pullup)
*    10 : 100k RS thermistor 198-961 (4.7k pullup)
*    11 : 100k beta 3950 1% thermistor (4.7k pullup)
*    12 : 100k 0603 SMD Vishay NTCS0603E3104FXT (4.7k pullup) (calibrated for Makibox hot bed)
*    13 : 100k Hisens 3950  1% up to 300°C for hotend "Simple ONE " & "Hotend "All In ONE"
*    15 : 100k thermistor calibration for JGAurora A5 hotend
*    18 : ATC Semitec 204GT-2 (4.7k pullup) Dagoma.Fr - MKS_Base_DKU001327
*    20 : Pt100 with circuit in the Ultimainboard V2.x
*   201 : Pt100 with circuit in Overlord, similar to Ultimainboard V2.x
*    60 : 100k Maker's Tool Works Kapton Bed Thermistor beta=3950
*    61 : 100k Formbot / Vivedino 3950 350C thermistor 4.7k pullup
*    66 : 4.7M High Temperature thermistor from Dyze Design
*    67 : 450C thermistor from SliceEngineering
*    70 : the 100K thermistor found in the bq Hephestos 2
*    75 : 100k Generic Silicon Heat Pad with NTC 100K MGB18-104F39050L32 thermistor
*    99 : 100k thermistor with a 10K pull-up resistor (found on some Wanhao i3 machines)
*
*       1k ohm pullup tables - This is atypical, and requires changing out the 4.7k pullup for 1k.
*                              (but gives greater accuracy and more stable PID)
*    51 : 100k thermistor - EPCOS (1k pullup)
*    52 : 200k thermistor - ATC Semitec 204GT-2 (1k pullup)
*    55 : 100k thermistor - ATC Semitec 104GT-2 (Used in ParCan & J-Head) (1k pullup)
*
*  1047 : Pt1000 with 4k7 pullup
*  1010 : Pt1000 with 1k pullup (non standard)
*   147 : Pt100 with 4k7 pullup
*   110 : Pt100 with 1k pullup (non standard)
*
*  1000 : Custom - Specify parameters in Configuration_adv.h
*
*         Use these for Testing or Development purposes. NEVER for production machine.
*   998 : Dummy Table that ALWAYS reads 25°C or the temperature defined below.
*   999 : Dummy Table that ALWAYS reads 100°C or the temperature defined below.
*/
#define TEMP_SENSOR_0 5
#define TEMP_SENSOR_1 0
#define TEMP_SENSOR_2 0
#define TEMP_SENSOR_3 0
#define TEMP_SENSOR_4 0
#define TEMP_SENSOR_5 0
#define TEMP_SENSOR_6 0
#define TEMP_SENSOR_7 0
#define TEMP_SENSOR_BED 1
#define TEMP_SENSOR_PROBE 1
#define TEMP_SENSOR_CHAMBER 0

Limitadores de temperatura (MINTEMP & MAXTEMP)

Configurar en Marlin 2 estos parámetros es muy importante, ya que controlan las temperaturas máximas y mínimas de nuestra impresora.

Definiremos en qué rangos deben estar todos y cada uno de los sensores disponibles. De esta manera, si algún sensor no alcanza o sobrepasa dicha temperatura, Marlin emite un error en el display y desactiva los Hotend y la cama calefactable.

En mi caso suelo configurar las temperaturas de los extrusores en 5 grados (mínima) y 265 grados (máxima). En el caso de que un extrusor o la cama no llegue a 5º grados, deduciremos que el Termistor no esta instalado correctamente, o se encuentra dañado físicamente.

De igual modo, nos protegerá en el caso de que accidentalmente se sobrepase la temperatura máxima, algo crucial para nuestra seguridad y la de nuestra vivienda.


// Below this temperature the heater will be switched off
// because it probably indicates a broken thermistor wire.
#define HEATER_0_MINTEMP 5
#define HEATER_1_MINTEMP 5
#define HEATER_2_MINTEMP 5
#define HEATER_3_MINTEMP 5
#define HEATER_4_MINTEMP 5
#define HEATER_5_MINTEMP 5
#define HEATER_6_MINTEMP 5
#define HEATER_7_MINTEMP 5
#define BED_MINTEMP 5

// Above this temperature the heater will be switched off.
// This can protect components from overheating, but NOT from shorts and failures.
// (Use MINTEMP for thermistor short/failure protection.)
#define HEATER_0_MAXTEMP 265
#define HEATER_1_MAXTEMP 265
#define HEATER_2_MAXTEMP 265
#define HEATER_3_MAXTEMP 265
#define HEATER_4_MAXTEMP 265
#define HEATER_5_MAXTEMP 265
#define HEATER_6_MAXTEMP 265
#define HEATER_7_MAXTEMP 265
#define BED_MAXTEMP 120

PID Tuning (Extrusores)

Sección que controla los ajustes del algoritmo que se encarga de gestionar la temperatura de los extrusores y de la cama calefactable.

Podríamos entrar en más detalle sobre como funciona, pero no es el artículo adecuado. Si estáis interesados en aprender más sobre PID Tuning os recomiendo que echéis un vistazo al siguiente artículo en REPRAP sobre Pid Tuning.

Por defecto vienen ya predeterminados algunos valores para varias de las más conocidas impresoras del mercado. Como mi impresora no coincide con la descripción, simplemente he añadido mis propios valores.

#if ENABLED(PIDTEMP)
//#define PID_EDIT_MENU         // Add PID editing to the "Advanced Settings" menu. (~700 bytes of PROGMEM)
//#define PID_AUTOTUNE_MENU     // Add PID auto-tuning to the "Advanced Settings" menu. (~250 bytes of PROGMEM)
//#define PID_PARAMS_PER_HOTEND // Uses separate PID parameters for each extruder (useful for mismatched extruders)
// Set/get with gcode: M301 E[extruder number, 0-2]

#if ENABLED(PID_PARAMS_PER_HOTEND)
// Specify between 1 and HOTENDS values per array.
// If fewer than EXTRUDER values are provided, the last element will be repeated.
#define DEFAULT_Kp_LIST {  22.20,  22.20 }
#define DEFAULT_Ki_LIST {   1.08,   1.08 }
#define DEFAULT_Kd_LIST { 114.00, 114.00 }
#else
#define DEFAULT_Kp  20.3
#define DEFAULT_Ki  1.43
#define DEFAULT_Kd  71.84
#endif
#endif // PIDTEMP

Para sacar los valores de vuestra impresora, podéis consultarlos en Internet o podéis hacerlos vosotros mismos con una función interna de Marlin denominada PID Autotune.

Para ello, conecta tu impresora a Repetier/Simplify3D o cualquier otro software que te permita utilizar comandos Gcode. Una vez conectado, envia el comando M303 E0 S200 C8 y comenzará el proceso.

Tras calentar y enfriar el fusor 8 veces, finalizará y mostrará la siguiente información. Solamente deberéis coger los valores de Kp, Ki y Kd e introducirlos en vuestro firmware, en los campos DEFAULT_Kp, DEFAULT_Ki y DEFAULT_Kd.

bias: 92 d: 92 min: 196.56 max: 203.75
Ku: 32.59 Tu: 54.92
Clasic PID
Kp: 19.56
Ki: 0.71
Kd: 134.26
PID Autotune finished ! Place the Kp, Ki and Kd constants in the configuration.h

PID Bed Tuning (Cama calefactable)

Lo mismo de antes, pero para nuestra cama calefactable. Por defecto en el nuevo firmware vendrá desactivado. Si dispones de cama calefactable debes descomentar la opción #define PIDTEMPBED como verás en mi configuración.

También puedes ejecutar otra función interna de Marlin para sacar los valores de la cama. Esta se efectúa con el comando Gcode M303 E-1 C8 S90.

//===========================================================================
//====================== PID > Bed Temperature Control ======================
//===========================================================================

/**
* PID Bed Heating
*
* If this option is enabled set PID constants below.
* If this option is disabled, bang-bang will be used and BED_LIMIT_SWITCHING will enable hysteresis.
*
* The PID frequency will be the same as the extruder PWM.
* If PID_dT is the default, and correct for the hardware/configuration, that means 7.689Hz,
* which is fine for driving a square wave into a resistive load and does not significantly
* impact FET heating. This also works fine on a Fotek SSR-10DA Solid State Relay into a 250W
* heater. If your configuration is significantly different than this and you don't understand
* the issues involved, don't use bed PID until someone else verifies that your hardware works.
*/
#define PIDTEMPBED

//#define BED_LIMIT_SWITCHING

/**
* Max Bed Power
* Applies to all forms of bed control (PID, bang-bang, and bang-bang with hysteresis).
* When set to any value below 255, enables a form of PWM to the bed that acts like a divider
* so don't use it unless you are OK with PWM on your bed. (See the comment on enabling PIDTEMPBED)
*/
#define MAX_BED_POWER 255 // limits duty cycle to bed; 255=full current

if ENABLED(PIDTEMPBED)
//#define MIN_BED_POWER 0
//#define PID_BED_DEBUG // Sends debug data to the serial port.

//120V 250W silicone heater into 4mm borosilicate (MendelMax 1.5+)
//from FOPDT model - kp=.39 Tp=405 Tdead=66, Tc set to 79.2, aggressive factor of .15 (vs .1, 1, 10)
#define DEFAULT_bedKp 347.77
#define DEFAULT_bedKi 48.46
#define DEFAULT_bedKd 623.90

//120V 250W silicone heater into 4mm borosilicate (MendelMax 1.5+)
//from pidautotune
//#define DEFAULT_bedKp 97.1
//#define DEFAULT_bedKi 1.41
//#define DEFAULT_bedKd 1675.16

// FIND YOUR OWN: "M303 E-1 C8 S90" to run autotune on the bed at 90 degreesC for 8 cycles.
#endif // PIDTEMPBED

No obstante, hay ocasiones en las cuales activar el parámetro PIDTEMPBED es más perjudicial que no activarlo. Yo te recomiendo de principio no habilitarlo.

Extrusión en frío (PREVENT_COLD_EXTRUSION)

Ambas funciones gestionan en Marlin la extrusión en frío. Como todos sabemos, no es recomendable extruir filamento si nuestro Hotend no esta encendido.

La opción PREVENT_COLD_EXTRUSION directamente evitará que podamos extruir material si nuestro hotend no alcanza la temperatura mínima delimitada.

Podremos configurar a qué mínima temperatura le permitiremos a Marlin extruir filamento con el parámetro EXTRUDE_MINTEMP. Por defecto ambas vienen activas, así que no deberías preocuparte.

No obstante, he considerado importante nombrarla para que tengas constancia de que existe.

/**
* Prevent extrusion if the temperature is below EXTRUDE_MINTEMP.
* Add M302 to set the minimum extrusion temperature and/or turn
* cold extrusion prevention on and off.
*
* *** IT IS HIGHLY RECOMMENDED TO LEAVE THIS OPTION ENABLED! ***
*/
#define PREVENT_COLD_EXTRUSION
#define EXTRUDE_MINTEMP 170

Longitud de extrusión (PREVENT_LENGTHY_EXTRUDE)

Como bien indica en los comentarios, previene efectuar extrusiones de filamento de una distancia superior a la que hayamos configurado. Esto significa que Marlin solamente te va a dejar en un solo comando GCODE extruir un máximo de 200mm.

Si desearas extruir mucho más de 200mm en un solo comando, por ejemplo en el caso de tener una función para cargar el filamento desde el display usando Bowden, deberás modificar el parámetro EXTRUDE_MAXLENGTH por un valor superior. Ambos vienen activados por defecto en Marlin 2.

Si no es tu caso déjalo como está. Yo por ejemplo introduzco el filamento a mano, así que no tengo necesidad alguno de modificarlo, pero siempre está bien saberlo.

/**
* Prevent a single extrusion longer than EXTRUDE_MAXLENGTH.
* Note: For Bowden Extruders make this large enough to allow load/unload.
*/
#define PREVENT_LENGTHY_EXTRUDE
#define EXTRUDE_MAXLENGTH 200

Protecciones térmicas (THERMAL_PROTECTION)

Estos tres parámetros activan la protección adicional térmica que ofrece Marlin 2.0.x para prevenir daños en nuestras impresoras. Siempre han de estar activas, de hecho así vienen en Marlin 2 por defecto, así que de ningún modo las tocaremos.

/**
* Thermal Protection provides additional protection to your printer from damage
* and fire. Marlin always includes safe min and max temperature ranges which
* protect against a broken or disconnected thermistor wire.
*
* The issue: If a thermistor falls out, it will report the much lower
* temperature of the air in the room, and the the firmware will keep
* the heater on.
*
* If you get "Thermal Runaway" or "Heating failed" errors the
* details can be tuned in Configuration_adv.h
*/

#define THERMAL_PROTECTION_HOTENDS // Enable thermal protection for all extruders
#define THERMAL_PROTECTION_BED     // Enable thermal protection for the heated bed
#define THERMAL_PROTECTION_CHAMBER // Enable thermal protection for the heated chamber

Parámetros mecánicos (Cinemáticas COREXY)

Existen diferentes impresoras con diferentes cinemáticas en el mercado. Por ejemplo cinemáticas cartesianas, deltas, tripteron, corexy (y sus variantes), etc. La verdad es que daría para un solo artículo hablar de ellas.

En el caso de que tu impresora utilice cinemática COREXY o cualquiera de sus variantes, deberías activar su parámetro correspondiente. Yo como tengo cinemática cartesiana, dejo todo deshabilitado como puedes comprobar.

//===========================================================================
//============================= Mechanical Settings =========================
//===========================================================================

// @section machine

// Enable one of the options below for CoreXY, CoreXZ, or CoreYZ kinematics,
// either in the usual order or reversed
//#define COREXY
//#define COREXZ
//#define COREYZ
//#define COREYX
//#define COREZX
//#define COREZY
//#define MARKFORGED_XY  // MarkForged. See https://reprap.org/forum/read.php?152,504042

Finales de carrera disponibles (USE_XMIN_PLUG & USE_XMAX_PLUG)

En este apartado vamos a indicarle a nuestro firmware Marlin los finales de carrera que tenemos conectados a nuestra placa base. Lo más normal es disponer de 3 finales de carrera para indicar los recorridos mínimos (o topes). De esta forma Marlin determina la posición inicial (0) en todos los ejes cuando hace un HOMING.

Se pueden instalar además sensores extra para determinar los máximos recorridos. Nos servirán para prevenir que la máquina se desplace más allá de lo estrictamente necesario. No son imprescindibles, pero sí una buena opción para tener todos los imprevistos bajo control.

En mi caso particular, yo dispongo de dos finales de carrera mecánicos en el eje X (extrusor) y en el eje Y (cama), y aparte tengo un sensor de nivelación en Z. Así que dejo activos en el firmware solamente los finales de carrera mínimos, como puedes comprobar tu mismo en las siguientes líneas.

// Specify here all the endstop connectors that are connected to any endstop or probe.
// Almost all printers will be using one per axis. Probes will use one or more of the
// extra connectors. Leave undefined any used for non-endstop and non-probe purposes.
#define USE_XMIN_PLUG
#define USE_YMIN_PLUG
#define USE_ZMIN_PLUG
//#define USE_XMAX_PLUG
//#define USE_YMAX_PLUG
//#define USE_ZMAX_PLUG

Lógica de los finales de carrera (ENDSTOP_INVERTING)

Dependiendo del tipo de sensor o final de carrera que usemos tendrán una lógica diferente. No tiene mayor misterio, simplemente déjalos todos en FALSE, y si alguno no te funciona, cambia aquí la lógica (le indicas TRUE). En mi caso particular, X e Y tuve que pasarlos a TRUE como puedes ver.

// Mechanical endstop with COM to ground and NC to Signal uses "false" here (most common setup).
#define X_MIN_ENDSTOP_INVERTING true // Set to true to invert the logic of the endstop.
#define Y_MIN_ENDSTOP_INVERTING true // Set to true to invert the logic of the endstop.
#define Z_MIN_ENDSTOP_INVERTING false // Set to true to invert the logic of the endstop.
#define X_MAX_ENDSTOP_INVERTING false // Set to true to invert the logic of the endstop.
#define Y_MAX_ENDSTOP_INVERTING false // Set to true to invert the logic of the endstop.
#define Z_MAX_ENDSTOP_INVERTING false // Set to true to invert the logic of the endstop.
#define Z_MIN_PROBE_ENDSTOP_INVERTING false // Set to true to invert the logic of the probe.

Configurar los drivers (DRIVER_TYPE)

Configurar el firmware de Marlin 2 con los drivers que disponemos viene a ser algo imprescindible. Pero no te preocupes, ya que es un proceso muy sencillo.

Por defecto verás que todas las opciones vienen inhabilitadas, así que deberás habilitar las que vayas a utilizar que serán donde hayas instalado drivers en tu placa.

En mi impresora tengo 3 motores en los 3 ejes (X, Y, Z), y un solo motor para el extrusor. Así que habilito las opciones necesarias. El primer extrusor siempre se denomina E0 como puedes comprobar.

Pero no solo deberemos habilitar la opción, sino también indicarle el driver que tienes montado en tu electrónica. Como yo tengo DRV8825, se lo he indicado al compilador, y listo.

En los comentarios puedes ver todos los tipos de drivers disponibles en Marlin 2, así que localiza el tuyo y anótalo tal y como aparece.

/**
* Stepper Drivers
*
* These settings allow Marlin to tune stepper driver timing and enable advanced options for
* stepper drivers that support them. You may also override timing options in Configuration_adv.h.
*
* A4988 is assumed for unspecified drivers.
*
* Options: A4988, A5984, DRV8825, LV8729, L6470, L6474, POWERSTEP01,
*          TB6560, TB6600, TMC2100,
*          TMC2130, TMC2130_STANDALONE, TMC2160, TMC2160_STANDALONE,
*          TMC2208, TMC2208_STANDALONE, TMC2209, TMC2209_STANDALONE,
*          TMC26X,  TMC26X_STANDALONE,  TMC2660, TMC2660_STANDALONE,
*          TMC5130, TMC5130_STANDALONE, TMC5160, TMC5160_STANDALONE
* :['A4988', 'A5984', 'DRV8825', 'LV8729', 'L6470', 'L6474', 'POWERSTEP01', 'TB6560', 'TB6600', 'TMC2100', 'TMC2130', 'TMC2130_STANDALONE', 'TMC2160', 'TMC2160_STANDALONE', 'TMC2208', 'TMC2208_STANDALONE', 'TMC2209', 'TMC2209_STANDALONE', 'TMC26X', 'TMC26X_STANDALONE', 'TMC2660', 'TMC2660_STANDALONE', 'TMC5130', 'TMC5130_STANDALONE', 'TMC5160', 'TMC5160_STANDALONE']
*/
#define X_DRIVER_TYPE  DRV8825
#define Y_DRIVER_TYPE  DRV8825
#define Z_DRIVER_TYPE  DRV8825
//#define X2_DRIVER_TYPE A4988
//#define Y2_DRIVER_TYPE A4988
//#define Z2_DRIVER_TYPE A4988
//#define Z3_DRIVER_TYPE A4988
#define E0_DRIVER_TYPE DRV8825
//#define E1_DRIVER_TYPE A4988
//#define E2_DRIVER_TYPE A4988
//#define E3_DRIVER_TYPE A4988
//#define E4_DRIVER_TYPE A4988
//#define E5_DRIVER_TYPE A4988
//#define E6_DRIVER_TYPE A4988
//#define E7_DRIVER_TYPE A4988

Configuración de los pasos (DEFAULT_AXIS_STEPS_PER_UNIT)

En este apartado le indicaremos a nuestra impresora cuantos pasos se efectuarán para cada unidad de movimiento. Las unidades podrán estar definidas en milímetros o pulgadas.

En el caso de utilizar pulgadas deberás activar el parámetro INCH_MODE_SUPPORT. Nosotros no vamos a activar ese parámetro, ya que solemos trabajar con milímetros, e introduciremos en este apartado nuestros pasos para cada uno de los ejes y el extrusor.

Precisas previamente conocer los valores a introducir, así que te recomiendo que los extraigas de algún firmware ya disponible de tu impresora (para ir sobre seguro).

Otra opción es buscarlo por Internet de algún otro usuario, navegar en foros, consultar al fabricante o como última opción, calcularlos tu mismo como puedes ver en este vídeo.

/**
* Default Axis Steps Per Unit (steps/mm)
* Override with M92
*                                      X, Y, Z, E0 [, E1[, E2...]]
*/
#define DEFAULT_AXIS_STEPS_PER_UNIT   { 160, 160, 800, 803 }

Ubicación sensor auto nivelación (NOZZLE_TO_PROBE_OFFSET)

En el supuesto que utilicemos un sensor de auto nivelación (como es mi caso), deberás indicarle la posición del mismo respecto al nozzle. Este obligatoriamente se encontrará separado y lo definiremos como coordenadas y en milímetros.

Mi sensor de nivelación se encuentra 37mm a la derecha del fusor, y 2 mm más atrás del mismo, así que quedaría la siguiente configuración:

/**
* Nozzle-to-Probe offsets { X, Y, Z }
*
* - Use a caliper or ruler to measure the distance from the tip of
*   the Nozzle to the center-point of the Probe in the X and Y axes.
* - For the Z offset use your best known value and adjust at runtime.
* - Probe Offsets can be tuned at runtime with 'M851', LCD menus, babystepping, etc.
*
* Assuming the typical work area orientation:
*  - Probe to RIGHT of the Nozzle has a Positive X offset
*  - Probe to LEFT  of the Nozzle has a Negative X offset
*  - Probe in BACK  of the Nozzle has a Positive Y offset
*  - Probe in FRONT of the Nozzle has a Negative Y offset
*
* Some examples:
*   #define NOZZLE_TO_PROBE_OFFSET { 10, 10, -1 }   // Example "1"
*   #define NOZZLE_TO_PROBE_OFFSET {-10,  5, -1 }   // Example "2"
*   #define NOZZLE_TO_PROBE_OFFSET {  5, -5, -1 }   // Example "3"
*   #define NOZZLE_TO_PROBE_OFFSET {-15,-10, -1 }   // Example "4"
*
*     +-- BACK ---+
*     |    [+]    |
*   L |        1  | R <-- Example "1" (right+,  back+)
*   E |  2        | I <-- Example "2" ( left-,  back+)
*   F |[-]  N  [+]| G <-- Nozzle
*   T |       3   | H <-- Example "3" (right+, front-)
*     | 4         | T <-- Example "4" ( left-, front-)
*     |    [-]    |
*     O-- FRONT --+
*/
#define NOZZLE_TO_PROBE_OFFSET { 37, -2, 0 }

Velocidad desplazamiento nivelación (XY_PROBE_SPEED)

Este parámetro define la velocidad que utilizará Marlin 2 al mover el sensor de auto nivelación entre 2 puntos de medición. Por defecto viene en 133*60 mm/min, podéis dejarlo por defecto o subirlo, a vuestra discrección.

// X and Y axis travel speed (mm/min) between probes
#define XY_PROBE_SPEED (133*60)

Invertir dirección de motores (INVERT_X_DIR)

Modificaremos estos parámetros si al hacer un HOME o al imprimir cualquier pieza con nuestra impresora, alguno de los motores va en la dirección incorrecta. Por defecto vienen todos configurados con la opción FALSE, yo en particular tuve que invertir la dirección de mi cama (eje Y) como podéis ver a continuación.

No obstante, otra opción es invertir el cable de la conexión del motor, eso ya como más comodo sea para vosotros.

// Invert the stepper direction. Change (or reverse the motor connector) if an axis goes the wrong way.
#define INVERT_X_DIR false
#define INVERT_Y_DIR true
#define INVERT_Z_DIR false

Volumen de impresión (X_BED_SIZE & Y_BED_SIZE)

Definiremos aquí las medidas exactas de nuestro volumen de impresión (cama). Mi impresora dispone de una cama en posición horizontal de 285 mm x 206 mm, así que quedaría de esta forma configurada:

// The size of the print bed
#define X_BED_SIZE 285
#define Y_BED_SIZE 206

Límites de movimiento (MIN_POS & MAN_POS)

Una vez definidas las medidas de nuestra base de impresión (cama), debemos configurar Marlin 2 con los mínimos y máximos límites de movimiento.

Por defecto para los mínimos Marlin viene configurado con el valor 0, el cual no debemos modificar ya que es el HOME. Para los límites máximos Marlin directamente usa las medidas actuales de nuestra cama en X e Y (que previamente habíamos dejamos configuradas en el parámetro anterior.

Para finalizar con la configuración, en el eje Z la medida que debemos añadir es la altura máxima de impresión de nuestra máquina. En mi caso particular puedo imprimir unos 296mm aproximadamente, así que introduzco su valor.

// Travel limits (mm) after homing, corresponding to endstop positions.
#define X_MIN_POS 0
#define Y_MIN_POS 0
#define Z_MIN_POS 0
#define X_MAX_POS X_BED_SIZE
#define Y_MAX_POS Y_BED_SIZE
#define Z_MAX_POS 296

Restricciones de movimiento (MIN_SOFTWARE_ENDSTOPS)

Por seguridad, y para no dañar los componentes de nuestra impresora, Marlin 2 viene por defecto configurado para que no podamos superar los límites mínimos. Esto significa que al llegar a un final de carrera o sensor, no dejará avanzar más el motor aunque lo hagas manualmente.

Sin embargo, como muchas otras cosas en Marlin 2.0.x, puedes inhabilitar ese límite si lo deseas. Es una opción que NO RECOMIENDO, pero que quería comentaros para conocer su existencia.

Yo personalmente suelo quitar el límite en el eje Z. Pero como os he comentado, salvo que sea imprescindible o sepas muy bien lo que haces, debes dejar los valores que trae el firmware por defecto.

// Min software endstops constrain movement within minimum coordinate bounds
#define MIN_SOFTWARE_ENDSTOPS
#if ENABLED(MIN_SOFTWARE_ENDSTOPS)
#define MIN_SOFTWARE_ENDSTOP_X
#define MIN_SOFTWARE_ENDSTOP_Y
#define MIN_SOFTWARE_ENDSTOP_Z
#endif

Almacenamiento en EEPROM (EEPROM_SETTINGS)

Marlin nos ofrece la posibilidad de cambiar la configuración de nuestra impresora desde el propio display y luego guardar los cambios en la Eeprom.

Si deseamos tener activa esa posibilidad, debemos activar este parámetro en nuestro firmware.

#define EEPROM_SETTINGS     // Persistent storage with M500 and M501

Pre-calentamiento ABS/PLA (PREHEAT)

Como habrás podido comprobar si ya has trasteado tu impresora, Marlin te ofrece dos opciones iniciales para pre-calentar la impresora previamente a una impresión. P

uedes configurar las temperaturas disponibles para filamentos de ABS y PLA, aunque podrías añadir más si lo desearas.

Algo bastante útil porque las que vienen por defecto en el firmware son mejorables. Yo personalmente dejo estas configuraciones:

// Preheat Constants
#define PREHEAT_1_LABEL "PLA"
#define PREHEAT_1_TEMP_HOTEND 200
#define PREHEAT_1_TEMP_BED 60
#define PREHEAT_1_FAN_SPEED 0 // Value from 0 to 255

#define PREHEAT_2_LABEL "ABS"
#define PREHEAT_2_TEMP_HOTEND 250
#define PREHEAT_2_TEMP_BED 100
#define PREHEAT_2_FAN_SPEED 0 // Value from 0 to 255

Idioma de los menús (LCD_LANGUAGE)

Idioma que aparecerá en todos y cada uno de los menús del firmware Marlin 2 (display). De momento, el que más me convence es el español, así que es el que tengo seleccionado. Por defecto viene inglés, probablemente desearás cambiarlo.

/**
* LCD LANGUAGE
*
* Select the language to display on the LCD. These languages are available:
*
*   en, an, bg, ca, cz, da, de, el, el_gr, es, eu, fi, fr, gl, hr, it, jp_kana,
*   ko_KR, nl, pl, pt, pt_br, ru, sk, tr, uk, vi, zh_CN, zh_TW, test
*
* :{ 'en':'English', 'an':'Aragonese', 'bg':'Bulgarian', 'ca':'Catalan', 'cz':'Czech', 'da':'Danish', 'de':'German', 'el':'Greek', 'el_gr':'Greek (Greece)', 'es':'Spanish', 'eu':'Basque-Euskera', 'fi':'Finnish', 'fr':'French', 'gl':'Galician', 'hr':'Croatian', 'it':'Italian', 'jp_kana':'Japanese', 'ko_KR':'Korean (South Korea)', 'nl':'Dutch', 'pl':'Polish', 'pt':'Portuguese', 'pt_br':'Portuguese (Brazilian)', 'ru':'Russian', 'sk':'Slovak', 'tr':'Turkish', 'uk':'Ukrainian', 'vi':'Vietnamese', 'zh_CN':'Chinese (Simplified)', 'zh_TW':'Chinese (Traditional)', 'test':'TEST' }
*/
#define LCD_LANGUAGE es

Soporte para SD Card (SDSUPPORT)

Más que probable, imprescindible activar esta opción. Te permite cargar los archivos STL utilizando una SDCard.

Aunque no lo creas, viene por defecto desactivada en nuestro firmware Marlin. Necesitarás activarla, como yo he hecho en mi firmware.

/**
* SD CARD
*
* SD Card support is disabled by default. If your controller has an SD slot,
* you must uncomment the following option or it won't work.
*
*/
#define SDSUPPORT

Simplificar menús (SLIM_LCD_MENUS)

Marlin te da la posibilidad de navegar por infinidad de menús desde su display, hasta un punto que es agobiante (al menos para mí).

Muchos de estos parámetros deberías haberlos configurado previamente en tu firmware, sin necesidad de modificarlos «al vuelo».

Para reducir los menús, Marlin te ofrece la opción de simplificarlos con el parámetro SLIM_LCD_MENUS. No solamente simplificará los menús, sino que ahorrarás una no despreciable cantidad de memoria. Te recomiendo que actives esta opción.

/**
* LCD Menu Items
*
* Disable all menus and only display the Status Screen, or
* just remove some extraneous menu items to recover space.
*/
//#define NO_LCD_MENUS
#define SLIM_LCD_MENUS

Tipo de display (LCD / Controller Selection)

Guía completa para configurar Marlin 2.0.x desde cero y no morir en el intento

Y por último, hemos llegado a la configuración del display. Si echamos un detenido vistazo al archivo Configuration.h veremos que hay infinidad de displays.

Puede parecer un poco complicado, pero en realidad lo único que debemos hacer es encontrar la descripción de nuestra pantalla LCD y descomentar para poder configurar Marlin 2.

Existen displays basados en texto, displays LCD gráficos, OLED displays, y alguno más que otro. Yo tengo uno basado en gráficos denominado MKS MINI 12864 (foto arriba). Para ello he descomentado la siguiente linea.

Si no encuentras el nombre de tu display, te recomiendo que utilices la función «Buscar» de Windows, es lo más rápido y sencillo.

//
// MKS MINI12864 with graphic controller and SD support
// https://reprap.org/wiki/MKS_MINI_12864
//
#define MKS_MINI_12864

Un pequeño detalle a tener en cuenta. En algunos casos (como el mío particular), es necesario disponer de librerías externas para compilar el firmware con soporte a nuestro display. Es el caso del display MKS MINI12864, precisa de buscar e instalarlas manualmente.

Si intentas compilarlo Marlin te dará error, y te indicará qué librería precisas instalar. A mi por ejemplo en mi compilación me pide la librería U8glib, veamos el error:

sketch\src\HAL\HAL_AVR\u8g_com_HAL_AVR_sw_spi.cpp:65:10: fatal error: U8glib.h:
No such file or directory

La solución es muy sencilla, iremos al menú Herramientas -> Administrar bibliotecas… y haremos clic. En el cuadro de búsqueda introduciremos U8glib y presionaremos INTRO.

Nos aparecerán las librerías online disponibles con este parámetro de búsqueda y veremos que al final se encuentra la nuestra «U8glib by Oliver». Otro clic en el botón INSTALAR y solucionado.

Por último, la configuración de contraste del display no me convencía demasiado, ya que se veía algo oscura al principio, así que decidí cambiarla.

Puedes modificar el contraste (poner la pantalla más clara/oscura) desde el propio display, pero prefiero dejárselo ya puesto en el mismo firmware, ya que es una opción que no volveré a modificar, y en caso de que resetee la EEPROM no tendré que configurarlo de nuevo.

Para ello tuve que editar un archivo especial denominado «pins_RAMPS.h» localizado en la ruta \Marlin\src\pins\ramps\. Una vez editado, añadiremos la línea #define LCD_CONTRAST 150 tal y como podemos ver en las siguientes líneas:

#elif ENABLED(MINIPANEL)

#define BEEPER_PIN 42
// not connected to a pin
#define LCD_BACKLIGHT_PIN 65 // backlight LED on A11/D65

#define DOGLCD_A0 44
#define DOGLCD_CS 66

// GLCD features
// Uncomment screen orientation
//#define LCD_SCREEN_ROT_90
//#define LCD_SCREEN_ROT_180
//#define LCD_SCREEN_ROT_270

#define BTN_EN1 40
#define BTN_EN2 63
#define BTN_ENC 59

#define SD_DETECT_PIN 49
#define KILL_PIN 64
#define LCD_CONTRAST 150

Nivelación de la cama (BED_LEVELING)

Existen diversos métodos o funciones disponibles en Marlin 2 para ayudarnos con la auto-nivelación de nuestra cama. Por defecto vienen desactivadas en el firmware así que deberemos activarlas para poder hacer uso de ellas.

Explicarlas todas y cada una de ellas daría para escribir un artículo completo, así que directamente os mostraré cómo nivelar la cama de dos formas distintas. La primera en el caso de que no dispongamos de un sensor de nivelación instalado y la segunda en el caso de que sí.

Para comenzar, y en ambos casos, debemos descomentar la función AUTO_BED_LEVELING_BILINEAR y después la función RESTORE_LEVELING_AFTER_G28, para que queden activas en nuestro firmware.

/**
* Choose one of the options below to enable G29 Bed Leveling. The parameters
* and behavior of G29 will change depending on your selection.
*
*  If using a Probe for Z Homing, enable Z_SAFE_HOMING also!
*
* - AUTO_BED_LEVELING_3POINT
*   Probe 3 arbitrary points on the bed (that aren't collinear)
*   You specify the XY coordinates of all 3 points.
*   The result is a single tilted plane. Best for a flat bed.
*
* - AUTO_BED_LEVELING_LINEAR
*   Probe several points in a grid.
*   You specify the rectangle and the density of sample points.
*   The result is a single tilted plane. Best for a flat bed.
*
* - AUTO_BED_LEVELING_BILINEAR
*   Probe several points in a grid.
*   You specify the rectangle and the density of sample points.
*   The result is a mesh, best for large or uneven beds.
*
* - AUTO_BED_LEVELING_UBL (Unified Bed Leveling)
*   A comprehensive bed leveling system combining the features and benefits
*   of other systems. UBL also includes integrated Mesh Generation, Mesh
*   Validation and Mesh Editing systems.
*
* - MESH_BED_LEVELING
*   Probe a grid manually
*   The result is a mesh, suitable for large or uneven beds. (See BILINEAR.)
*   For machines without a probe, Mesh Bed Leveling provides a method to perform
*   leveling in steps so you can manually adjust the Z height at each grid-point.
*   With an LCD controller the process is guided step-by-step.
*/
//#define AUTO_BED_LEVELING_3POINT
//#define AUTO_BED_LEVELING_LINEAR
#define AUTO_BED_LEVELING_BILINEAR
//#define AUTO_BED_LEVELING_UBL
//#define MESH_BED_LEVELING

/**
* Normally G28 leaves leveling disabled on completion. Enable
* this option to have G28 restore the prior leveling state.
*/
#define RESTORE_LEVELING_AFTER_G28

De esta forma, nuestro sensor bajará en diversos puntos y creará una malla virtual con las diferentes alturas. Y como me gusta hacer siempre el HOME en el centro de la cama activo la opción Z_SAFE_HOMING.

#define Z_SAFE_HOMING

#if ENABLED(Z_SAFE_HOMING)
#define Z_SAFE_HOMING_X_POINT ((X_BED_SIZE) / 2) // X point for Z homing when homing all axes (G28).
#define Z_SAFE_HOMING_Y_POINT ((Y_BED_SIZE) / 2) // Y point for Z homing when homing all axes (G28).
#endif

Una vez configurado todo esto, aplica solamente la opción que necesites para tu firmware, opción 1 sin sensor u opción 2 con sensor. Activar las 2 no es necesario y puede darte problemas o fallos de compilación. Vamos a ello…

Opción 1: Configuración sin sensor (4 esquinas)

Esta configuración es la que vamos a aplicar si no tenemos en nuestro cabezal de impresión un sensor de nivelación. Primero le indicaremos a Marlin 2 que vamos a efectuar la nivelación sin disponer de dicho sensor.

/**
* The "Manual Probe" provides a means to do "Auto" Bed Leveling without a probe.
* Use G29 repeatedly, adjusting the Z height at each point with movement commands
* or (with LCD_BED_LEVELING) the LCD controller.
*/
#define PROBE_MANUALLY
//#define MANUAL_PROBE_START_Z 0.2

Después indicaremos cuantos puntos de prueba (Probe points) deseamos que efectúe nuestra nivelación manual, así que modificaremos los parámetros GRID_MAX_POINTS. Para nivelar las 4 esquinas necesitaremos de 4 puntos, así que dejaremos la configuración de esta forma.

// Set the number of grid points per dimension.
#define GRID_MAX_POINTS_X 2
#define GRID_MAX_POINTS_Y GRID_MAX_POINTS_X

Por último, y no menos importante, activaremos las funciones LCD_BED_LEVELING y LEVEL_BED_CORNERS. Esto creará en el display los menús oportunos para tal efecto.

/**
* Add a bed leveling sub-menu for ABL or MBL.
* Include a guided procedure if manual probing is enabled.
*/
#define LCD_BED_LEVELING

#if ENABLED(LCD_BED_LEVELING)
#define MESH_EDIT_Z_STEP 0.025 // (mm) Step size while manually probing Z axis.
#define LCD_PROBE_Z_RANGE 4 // (mm) Z Range centered on Z_MIN_POS for LCD Z adjustment
//#define MESH_EDIT_MENU // Add a menu to edit mesh points
#endif

// Add a menu item to move between bed corners for manual bed adjustment
#define LEVEL_BED_CORNERS

Opción 2: Configuración con sensor (BABYSTEPPING)

Esta es la configuración que yo personalmente utilizo en mi impresora con mi sensor de nivelación en el cabezal. En mi caso utilizo un sensor de infrarrojos, pero es aplicable para cualquier tipo de sensor (inductivo, capacitivo, IR, etc.)

Si dispones de un BLTouch, si que te recomiendo que busques algún manual más específico, ya que Marlin trae funciones específicas para él.

Precisamente en 3DWork publicamos un artículo muy completo sobre como configurarlo: Instalar y configurar BLTouch / 3DTouch en Marlin 2.0.x (MKS Gen, SKR, Anet A8, RAMPS)

Volviendo a nuestra configuración, la primera modificación que efectuaremos será indicarle a Marlin que disponemos de un sensor de autonivelación fijo en nuestra máquina, para ello editaremos la siguiente línea y la dejaremos así:

/**
* A Fix-Mounted Probe either doesn't deploy or needs manual deployment.
*   (e.g., an inductive probe or a nozzle-based probe-switch.)
*/
#define FIX_MOUNTED_PROBE

Luego configuraremos cuantos puntos de prueba (Probe points) deseamos que efectúe nuestra nivelación con sensor, así que modificaremos los parámetros GRID_MAX_POINTS.

Yo suelo efectuar 9 puntos de comprobación antes de cada impresión, así que dejo las opciones por defecto que son 3 por eje (3 x 3 = 9).

// Set the number of grid points per dimension.
#define GRID_MAX_POINTS_X 3
#define GRID_MAX_POINTS_Y GRID_MAX_POINTS_X

Después debemos editar un nuevo archivo denominado configuration_adv.h. Se diferencia del primero básicamente en que nos ofrece opciones de personalización más detalladas, complementos y funciones experimentales o en desarrollo (como es el BABYSTEPPING)

Guía completa para configurar Marlin 2.0.x desde cero y no morir en el intento

Yo en mi impresora uso una función de nivelación disponible en Marlin 2 denominada BABYSTEPPING. Esta función me permite calibrar con un folio la altura de mi sensor de nivelación en el centro de la cama una sola vez.

Más tarde, la impresora efectuará 9 puntos de testeo (Probe Points) automáticamente al comenzar cada impresión. De esta forma no tendré que ir esquina por esquina innecesariamente para calibrar mi cama.

Por defecto viene desactivada, así que activaremos la opción BABYSTEPPING tal y como os muestro a continuación:

/**
* Babystepping enables movement of the axes by tiny increments without changing
* the current position values. This feature is used primarily to adjust the Z
* axis in the first layer of a print in real-time.
*
* Warning: Does not respect endstops!
*/
#define BABYSTEPPING
#if ENABLED(BABYSTEPPING)
//#define INTEGRATED_BABYSTEPPING         // EXPERIMENTAL integration of babystepping into the Stepper ISR
//#define BABYSTEP_WITHOUT_HOMING
#define BABYSTEP_ALWAYS_AVAILABLE         // Allow babystepping at all times (not just during movement).
//#define BABYSTEP_XY                     // Also enable X/Y Babystepping. Not supported on DELTA!
#define BABYSTEP_INVERT_Z false           // Change if Z babysteps should go the other way
//#define BABYSTEP_MILLIMETER_UNITS       // Specify BABYSTEP_MULTIPLICATOR_(XY|Z) in mm instead of micro-steps
#define BABYSTEP_MULTIPLICATOR_Z  20      // (steps or mm) Steps or millimeter distance for each Z babystep
#define BABYSTEP_MULTIPLICATOR_XY 1       // (steps or mm) Steps or millimeter distance for each XY babystep

#define DOUBLECLICK_FOR_Z_BABYSTEPPING    // Double-click on the Status Screen for Z Babystepping.
#if ENABLED(DOUBLECLICK_FOR_Z_BABYSTEPPING)
#define DOUBLECLICK_MAX_INTERVAL 1250   // Maximum interval between clicks, in milliseconds.
// Note: Extra time may be added to mitigate controller latency.
//#define MOVE_Z_WHEN_IDLE              // Jump to the move Z menu on doubleclick when printer is idle.
#if ENABLED(MOVE_Z_WHEN_IDLE)
#define MOVE_Z_IDLE_MULTIPLICATOR 1   // Multiply 1mm by this factor for the move step size.
#endif
#endif

//#define BABYSTEP_DISPLAY_TOTAL          // Display total babysteps since last G28

#define BABYSTEP_ZPROBE_OFFSET            // Combine M851 Z and Babystepping
#if ENABLED(BABYSTEP_ZPROBE_OFFSET)
//#define BABYSTEP_HOTEND_Z_OFFSET      // For multiple hotends, babystep relative Z offsets
#define BABYSTEP_ZPROBE_GFX_OVERLAY     // Enable graphical overlay on Z-offset editor
#endif
#endif

EXTRA: Trucos interesantes para Marlin

Visualizar tu malla en 3D

leveling mesh 5

Desde que las nuevas versiones de Marlin aparecieron (2.0.x) es posible generar mallas en 3D de nuestra superficie de impresión sin la necesidad de utilizar Octoprint  o cualquier de sus interesantísimos plugins.

Marlin ahora te facilita un archivo que puedes modificar y cargar en Open SCAD para visualizar nuestra malla en cualquier momento. Puedes leer el artículo completo en el siguiente enlace: Visualizar malla en 3D de nuestra superficie de impresión con Marlin 2.x (y sin Octoprint) 

Instalar juegos en Marlin

Habilitando juegos ocultos en Marlin 2.0.x para tu impresora 3D

Otro curioso truco que nos ofrece Marlin es poder activar una serie de juegos ocultos dentro de su firmware. Para ello es preciso disponer de una pantalla LCD gráfica, y modificar algunas cosillas dentro del mismo firmware.

Tienes el artículo completo en el siguiente enlace: Habilitando juegos ocultos en Marlin 2.0.x para tu impresora 3D

Logotipo personalizado en Marlin

Marlin custom logo

Desde la aparición de la versión 1.1.0 del firmware Marlin es relativamente sencillo añadir logotipos personalizados al firmware Marlin. Como es lógico, precisas de una pantalla LCD gráfica, generar el logotipo y preparar la imagen deseada.

Por supuesto deberás modificar algunas cosillas dentro del mismo firmware. Puedes leer el artículo completo en el siguiente enlace: Crea tu propio logotipo personalizado de inicio en Marlin 2.0.x 

Compilación final de Marlin

Guía completa para configurar Marlin 2.0.x desde cero y no morir en el intento

Bueno, parece que ha costado pero al final hemos llegado a este punto. Si todo está correcto deberíamos de poder compilar nuestro firmware Marlin sin problema alguno. Lo primero que debemos hacer para poder compilar el firmware es cargarlo en el IDE de Arduino, o en el Visual Studio Code.

Si utilizamos el IDE de Arduino directamente, abriremos la carpeta donde teníamos descomprimido el firmware, iremos a la carpeta /Marlin y haremos clic dos veces en el archivo del proyecto denominado Marlin.ino. Esto debería cargar el proyecto completo en el IDE.

Guía completa para configurar Marlin 2.0.x desde cero y no morir en el intento

Tenemos básicamente dos opciones, una es verificar/compilar el firmware. Esta opción simplemente hará una compilación previa del firmware y nos indicará si está todo correctamente configurado. La segunda opción es subir el firmware, la cual directamente lo compilará y lo subirá a tu impresora.

Ten en cuenta que si le das a subir el firmware, deberás haber previamente configurado el IDE de arduino y conectado tu impresora por USB a tu ordenador. Si no detecta la placa de tu impresora, después de la compilación dará error y no subirá el firmware.

Así, que llegados a este punto, nos vamos a limitar simplemente a darle a la opción verificar/compilar el firmware, y una vez veamos que compila todo correctamente pasaremos al siguiente paso que ya será el definitivo, subir el firmware a nuestra máquina. Para ello iremos al menú Programa -> Verificar/Compilar o pulsaremos las teclas rápidas Ctrl+R.

Subiendo Marlin a tu impresora

Guía completa para configurar Marlin 2.0.x desde cero y no morir en el intento

Como hemos comentado en el apartado previo, antes de poder subir el firmware finalizado a nuestra impresora debemos configurar el IDE de Arduino. Iremos al menú Herramientas y configuraremos estos 3 apartados:

  • Placa: Selecciona el tipo de placa de tu impresora
  • Procesador: ATMega 2560 o ATMega 1280
  • Puerto: Aparecerá un puerto COM, seleccionalo manualmente

Si hemos seleccionado todo correctamente, no deberíamos tener mayor problema. Para subirlo definitivamente iremos a Programa -> Subir o pulsaremos las teclas rápida Ctrl+U.

Compilar electrónicas de 32bits con Visual Studio Code y Platform.io

Actualiza tu impresora 3D a Marlin 2.x.x con Visual Studio Code y Platform.io

En el supuesto de que dispongas de una placa electrónica de 32bits, te recomiendo encarecidamente utilizar Visual Studio Code y su extensión Platform.io, el cual es un editor freeware de código muy ligero y potente.

Tienes un estupendo artículo también en nuestra página web donde paso a paso se explica como hacerlo, te dejo por aquí el enlace directo: Configura y actualiza tu impresora 3D utilizando Visual Studio Code y Platform.io

Observaciones finales

Espero y deseo que el artículo Configurar Marlin 2.0.x desde cero haya podido ser de ayuda para ti. No obstante, tal como comenté al principio, no pretende ser un manual específico de uso, sino una sencilla introducción a él usando mi actual impresora como ejemplo.

Si bien, la idea es ir completando día a día el artículo con mucha más información. No descarto que se te pueda presentar algún imprevisto a la hora de configurar Marlin 2.0.x para tu impresora.

Si ese fuera el caso, te agradecería que lo compartieras con nosotros en los comentarios o directamente en nuestro canal de Telegram.

Y bueno ya por último, si existe alguna errata en el artículo te pido disculpas por adelantado. Configurar Marlin 2.0.x como puedes comprobar es bastante laborioso (que no es lo mismo que difícil).

Y es completamente factible que algún parámetro se me haya pasado por alto (nada más fácil que corregirlo en alguna posterior edición). No dudes en notificármelo al final en los comentarios.

Como siempre, os dejamos por aquí otros interesantes artículos de 3DWork: