Anet A6/A8 OS X and Windows Drivers


A fully signed drivers for Windows can be found below:

Mac OS-X


(Added: October, 2016)

The Version 1.3 of the driver available on the vendor’s website causes a crash on Mac OS-X Sierra. Thankfully, Adrian Mihalko patched the driver, and made it available to the public.

El Capitan

(Added: Nov 22, 2015)

Many instructions down below were written for the old driver, which was not signed, and therefore was not working out of the box on OS-X Yosemite and El Capitan. The latest driver appears to be signed, and should work out the box. The new driver is here: (111Kb).

Thanks to Björn’s Techblog for posting the driver.

Inside the driver is a brief README with the following instructions:


CH34X USB-SERIAL DRIVER INSTALLATION INSTRUCTIONS Version: V1.0 Copyright (C) Jiangsu Qinheng Co., Ltd. Support System: OSX 10.9 and above

Installation Process: * Extract the contents of the zip file to a local installation directory * Double-click CH34x_Install.pkg * Install according to the installation on procedure * Restart after finishing installing

After the installation is completed, you will find serial device in the device list(/dev/tty.wchusbserial*), and you can access it by serial tools.

If you can’t find the serial port then you can follow the steps below:

  1. Open terminal and type ‘ls /dev/tty*’ ande see is there device like tty.wchusbserial;
  2. Open ‘System Report’->Hardware->USB, on the right side “USB Device Tree” there will be device named “Vendor-Specific Device” and check if the Current is normal. If the steps upper don’t work at all, please try to install the package again.

Note: Please enter System Preferences ➜ Security & Privacy ➜ General, below the title “Allow apps downloaded from:” you should choose the choice 2 ➜ “Mac App Store and identified developers” so that our driver will work normally.

Older Driver

This older version requires some hacking in order to get it to work. I am leaving instructions just in case someone needs it, or the new driver does not work for someone.

Download The Driver

There are two main sites that people mention in the discussions about the driver:

  • Chinese company that developed it:
    • This driver appears newer than on the second link, and is from Dec 2013.
    • Note: for me that site took a long long time to load, and then it took forever to download this tiny driver, so I put up a copy here CH341SER_MAC.ZIP (256Kb), so that you don’t have to wait. Hopefully they won’t go after me for mirroring their driver 🙂
  • Second site is the Russian company that sells the USB programmer based on this chip: but this site only has an older version of the driver, from 2012, so I do not recommend downloading it.


Note: the following pre-installation steps are only required on the two most recent versions of OS-X Yosemite and El Capitan. It is because the driver is not signed properly from Apple’s perspective. We are waiting on the developer to update the driver so that these pre-installation steps are no longer needed.

OS-X El Capitan Steps (Only For The Older Driver!)

These are not needed for the newer driver above.

  • Reboot and press ⌘-R immediately after the chime to enter Recovery Mode
  • Open Terminal from the recovery mode
  • run the command csrutil enable --without kext
  • Reboot.
Thanks to this post for these instructions.

OS-X Yosemite Steps

  • Open Terminal Application (it’s located in /Application/Utilities) and type this command once you see a prompt:
  • sudo nvram boot-args="kext-dev-mode=1"
  • Reboot.
see this post if you wish to know more details.


  • Download the driver from here: CH341SER_MAC.ZIP (256Kb)
  • Double click the ZIP file do unzip it
  • Open the folder ~/Downloads/CH341SER_MAC
  • Run installer found in that folder
  • Restart when asked.


If the driver properly loaded, you should see the device in you /dev folder (this is for advanced command-line users of OSX only). On my machine it was called /dev/cu.wchusbserial1441140

This port is showing up correctly in Arduino 1.0.6 and Arduino 1.5.8.

However, if you are using the Eclipse Plugin, it is not smart enough to list this port in the list of available serial ports (either in project properties, or in the serial monitor). You will have to type the entire thing yourself: /dev/cu.wchusbserial1441140 and then Eclipse can upload your sketch.

That’s it! You should be ready to use the drivers and the board.




How to print directly from CURA 2.3.1 to USB Anet A6/A8 printer.



First… important information from Ultimaker forum:

“USB printing is possible with the Ultimakers it’s not recommended because the amount of data to transfer is important. It seems that USB printing can be un-reliable because there can be some small disconnections that can create errors in printing.”


1 – Ultimaker Cura 2.3.x+  download link:

2 – Install the Cura (Mac or Windows)

3 – add printer settings to printer definitions folder (open app content and search for this folder), example:

create new file with name: “anet_a6.def.json”:

    "id": "anet_a6",
    "version": 2,
    "name": "Anet A6",
    "inherits": "fdmprinter",
    "metadata": {
        "visible": true,
        "author": "JP",
        "manufacturer": "Anet",
        "category": "Anet",
        "file_formats": "text/x-gcode",
        "icon": "icon_ultimaker2",
        "platform": "prusai3_platform.stl"

    "overrides": {
        "machine_name": { "default_value": "Anet A6" },
        "machine_heated_bed": {
            "default_value": true
        "machine_width": {
            "default_value": 220
        "machine_height": {
            "default_value": 190
        "machine_depth": {
            "default_value": 200
        "machine_center_is_zero": {
            "default_value": false
        "machine_nozzle_size": {
            "default_value": 0.4
        "material_diameter": {
            "default_value": 1.75
        "machine_nozzle_heat_up_speed": {
            "default_value": 2
        "machine_nozzle_cool_down_speed": {
            "default_value": 2
        "machine_head_polygon": {
            "default_value": [
                [-75, -18],
                [-75, 35],
                [18, 35],
                [18, -18]
        "gantry_height": {
            "default_value": 55
        "machine_gcode_flavor": {
            "default_value": "RepRap (Marlin/Sprinter)"
        "machine_start_gcode": {
            "default_value": "G21 ;metric values\nG90 ;absolute positioning\nM82 ;set extruder to absolute mode\nM107 ;start with the fan off\nG28 X0 Y0 ;move X/Y to min endstops\nG28 Z0 ;move Z to min endstops\nM84 ;steppers off\nM0 S12 ;wait 12 seconds\nM17 ;turn steppers on\nG1 Z10.0 F300 ;move the platform down 10mm\nG92 E0 ;zero the extruded length\nG1 F200 E8 ;extrude 8mm of feed stock\nG92 E0 ;zero the extruded length again\nM0 S5 ;wait 5 seconds\nG1 F9000\n;Put printing message on LCD screen\nM117 Printing..."
        "machine_end_gcode": {
            "default_value": "M104 S0 ;extruder heater off\nM140 S0 ;heated bed heater off (if you have it)\nG91 ;relative positioning\nG1 E-1 F300  ;retract the filament a bit before lifting the nozzle, to release some of the pressure\nG1 Z+4 E-5 X-20 Y-20 F9000 ;move Z up a bit and retract filament even more\nG28 X0 Y0 ;move X/Y to min endstops, so the head is out of the way\nG1 Y210 F9000 ;move out to get part off\nM84 ;steppers off\nG90 ;absolute positioning"

Now, it’s possible to configure the Anet but it’s not possible to print directly from usb.

Go to folder: “plugins/Usbprint” and follow the instructions:

1-open “ “, comment all text with new programmer reference:

programmer = stk500v2.Stk500v2() 
#programmer = stk500v2.Stk500v2()

Anet controller need time to start, add time for response by “T:” request:

if b"T:" in line:
    Logger.log("d", "Correct response for auto-baudrate detection received.")
    self._serial.timeout = 10
    sucesfull_responses += 1
       if sucesfull_responses >= self._required_responses_auto_baud:
       self._serial.timeout = 12 # Reset serial timeout"

Open “” and change all lines with text:

"only_list_usb = True" to False;


Start CURA .. works 🙂

Execute script and services on Start-Up – RPi /Linux


In order to have a command or program run when the Pi boots, you can add commands to the rc.local file. This is especially useful if you want to be able to plug your Pi in to power headless, and have it run a program without configuration or a manual start.

Example – Create autostart for one service and one bash/shell (*.sh):

sudo nano /etc/rc.local


#!/bin/sh -e
# rc.local
/wifiscan/ &            #<< startup bash
service yourservice start         #<< startup service 
/etc/init.d/cron start            #<< start cron for future usage with full path
exit 0

Now, your RPi it’s ready to auto-start your tasks!

>> create file / bash:

sudo nano /YourFolder/

#example - update ntp clock
sudo service ntp stop
sudo ntpdate -s $NTP_SERVER
sudo service ntp start

echo "Today is $(date)"

>> set file permissions:

sudo chmod +x /YourFolder/

>> create yourservice file:

sudo nano /etc/init.d/yourservice
#! /bin/sh

# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: start a program from boot
# Description: start YOURSERVICENAME program

# Put any commands you always want to run here.

case "$1" in
echo "Starting example"
# run the program you want to start
echo "Stopping example"
# end the program you want to stop
 echo "Usage: /etc/init.d/YOURSERVICENAME {start|stop}"
 exit 1

>> set file permissions:

sudo chmod +x /etc/init.d/yourservice

Your service is ready to start.

You need to restart your service at 01h00 o’clock daily | weekly ?? use crontab -e


sudo crontab -e  (note ... crontab -e != sudo crontab -e)
# Edit this file to introduce tasks to be run by cron.
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').#
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
# For more information see the manual pages of crontab(5) and cron(8)
# m h dom mon dow command
0 0 * * * /YOURFOLDER/ > /tmp/log 2>&1 # remove old files at 0h00 o'clock and add to log
0 1 * * * /etc/init.d/YOURSERVICE restart > /tmp/log 2>&1 # restart service at 1h00 o'clock and add to log

#test here :