Skip to main content

Test programming the ATtiny85

Just got my ATtiny85 chip today from the postman and playing with it now.

There are quite a number of ways to program the ATtiny85, from the very cheap (USBasp, Tiny AVR Programmer, USBtinyISP) to the more expensive (AVRISP mkII). The Tiny AVR Programmer is probably the most convenient of the lot because it targets the ATtiny family specifically, so no cables are required. Just plug the chip into the provided socket.

Since I already have a spare Arduino Uno lying around, I am going the no-cost way, using the Uno to program the ATtiny85. You basically need to hook up the Uno to the ATtiny85 on a breadboard via 6 jumper wires. It's actually easier than it sounds, and took all of a couple of minutes to do.

Configuring the Uno to become an ISP

The next step is crucial. You need to upload a sketch to the Uno so that it has the necessary code to become an ISP. That's how you can then program the ATtiny85 through the Uno.

The first step is to load the ArduinoISP sketch from the built-in examples:


Make sure you have the board type selected as "Arduino Uno"


Now click "Sketch, Upload" and the upload should be completed without errors.

Installing ATtiny85 support


Under "File, Preferences", in the "Additional Boards Manager URLs" field, add this URL: https://raw.githubusercontent.com/damellis/attiny/ide-1.6.x-boards-manager/package_damellis_attiny_index.json


Then under "Tools, Board. Boards Manager...", type in "attiny" in the Filter field. You should see "attiny by David A. Mellis". Select and install.


Now that we have ATtiny85 support, under "Tools, Board", scroll to the end of the menu and select "Attiny 25/45/85".


Under "Tools, Processor", select "ATtiny85".

 
Under "Tools, Programmer", select "Arduino as ISP".


We are now ready to program the ATtiny85! Open up the sample "Blink" sketch:


 Change all references of LED_BUILTIN to 1. So the code looks like this:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
// the setup function runs once when you press reset or power the board
void setup() {
  // initialize digital pin LED_BUILTIN as an output.
  pinMode(1, OUTPUT);
}

// the loop function runs over and over again forever
void loop() {
  digitalWrite(1, HIGH); // turn the LED on (HIGH is the voltage level)
  delay(1000); // wait for a second
  digitalWrite(1, LOW); // turn the LED off by making the voltage LOW
  delay(1000); // wait for a second
}

Select "Sketch, Uploading Using Programmer" to upload the compiled sketch to the ATtiny85. Using "Upload Using Programmer" is important, as it indicates to upload the sketch through the Uno which we have setup as an ISP.


Once the sketch is successfully upload, we can connect a LED to the ATtiny85 (longer lead (+) to Pin 1, shorter lead (-) to GND) and watch it blink.



► Breadboard diagram created using Tinkercad.
► Source code formatted using hilite.me ("manni" style).

Comments

  1. Arduino: 1.8.9 (Windows 10), Board: "ATtiny25/45/85, ATtiny85, Internal 1 MHz"

    Sketch uses 956 bytes (11%) of program storage space. Maximum is 8192 bytes.
    Global variables use 17 bytes (3%) of dynamic memory, leaving 495 bytes for local variables. Maximum is 512 bytes.
    avrdude: Yikes! Invalid device signature.
    Double check connections and try again, or use -F to override
    this check.

    An error occurred while uploading the sketch

    This report would have more information with
    "Show verbose output during compilation"
    option enabled in File -> Preferences.

    ReplyDelete

Post a Comment

Popular posts from this blog

Update: Line adapter for Ozito Blade Trimmer

Update (Dec 2021): If you access to a 3D printer, I would now recommend this solution , which makes it super easy to replace the trimmer line. I have been using it for a few months now with zero issue.

Filament Joiner Part 2 (With Display and Knob)

Thanks to the current corona-virus crisis, the parts I ordered for the filament joiner project were taking forever to arrive. But now that they have finally arrived, I can put them to good use. These were the parts ordered: 0.96" OLED display SSD1306 Rotary switch encoder KY-040 Here is the final circuit diagram: The OLED display is connected to the SDA and SCL pins of the Nano (A4 and A5 respectively), and powered by 5V and GND. The rotary switch encoder is connected as follows: VCC => 5V GND = > GND CLK => D9 DT => D8 SW => D2 My prototype board now looks like this: The updated code for driving the knob and display is available in  heater-with-display.ino in the Github repository . We now have a fairly compact (about 7cm x 5cm) and independent filament joiner (no need to connect to PC) that is driven solely by a 12V power supply. Here's how to use it to join printer filaments. More usage details in my previous post .

Adding "Stereo Mixer" to Windows 7 with Conexant sound card

This procedure worked for my laptop (Thinkpad E530) with a Conexant 20671 sound card, but I suspect it will work for other sound cards in the Conexant family. I was playing with CamStudio to do a video capture of a Flash-based cartoon so that I can put it on the WDTV media player and play it on the big screen in the living room for my kids. The video capture worked brilliantly, but to do a sound capture, I needed to do some hacking. Apparently, there was this recording device called "Stereo Mixer" that was pretty standard in the Windows XP days. This allowed you to capture whatever was played to the speaker in all its digital glory. Then under pressure from various organizations on the dark side of the force, Microsoft and soundcard makers starting disabling this wonderful feature from Windows Vista onwards. So after much Googling around, I found out that for most sound cards, the hardware feature is still there, just not enabled on the software side. Unfortunately, to