LED Flower: Unterschied zwischen den Versionen

Aus Wiki CCC Göttingen
Zur Navigation springen Zur Suche springen
Zeile 497: Zeile 497:
   
   
  make[1]: Leaving directory `source'
  make[1]: Leaving directory `source'
====USB Port====
<gallery widths=200px heights=200px perrow=3>
Datei:Lf-0090-00.jpeg
</gallery>
====Testing the USB Port====
<gallery widths=200px heights=200px perrow=3>
Datei:Lf-0100-00.jpeg
</gallery>

Version vom 25. Dezember 2010, 18:52 Uhr

PCB

PCB
Generated PCB preview

BOM

Necessary

Designator Value Part-No Price / EUR Count Sum / EUR
R1 3.6 kΩ, 1206 R: 0.01 1 0.01
R2 2.7 kΩ, 1206 R: 0.01 1 0.01
R3, R4 68 Ω, 1%, 1206 CSD: 10-120068 0.01 2 0.02
R5..R19, R38..R40 3.6 kΩ, 1206 R: 0.01 18 0.18
R20..R31 100 Ω, 1206 R: 0.01 12 0.12
R32..R37 150 Ω, 1206 R: 0.01 6 0.06
B1..B3 0 Ω, 1206 R: 0.01 3 0.03
T1..T18 BC807-25, SOT23 R: BC 807-25 SMD 0.04 18 0.72
C1, C2, C3 100 nF, 16 V, 0603 R: X7R-G0603 100N 0.05 3 0.15
C4, C5 22 pF, 0603 R: NPO-G0603 22P 0.05 2 0.10
C6 10 uF, 10 V, 0805 R: X5R-G0805 10/16 0.07 1 0.07
C9 100 nF, 63 V, 1206 R: X7R-G1206 100N 0.05 1 0.05
D2, D3 3.6 V Zener Diode, MiniMELF R: SMD ZF 3,6 0.05 2 0.10
X1 20 MHz R: 20,0000-HC49U-S 0.18 1 0.18
ISP, ADC, PWR 12-pin break-away connector (from a 36-pin strip) R: SL 1X36W 2,54 0.27 1 0.27
CONN_USB USB B connector R: USB BW 0.21 1 0.21
U1 ATmega88-20AU R: ATMEGA 88-20 AU 2.95 1 2.95
LED1..LED6 RGB LED ? 0.30 6 1.80
24 Copper wires 40 cm copper wire cutoff R: CUL 500/0,63 13.90 0.058 0.81
Sum 7.84

Version 1: USB Powered

Designator Value Part-No Price / EUR Count Sum / EUR
L1 10 uH, 450 mA, 1210 CSD: 146-121R010 0.22 1 0.22
U2, C7, C8 Do not populate 0.00 0 0.00
Sum 0.22

Version 2: Externally powered

Designator Value Part-No Price / EUR Count Sum / EUR
U2 LM1117-5.0 CSD: LM1117DT-5,0V 0.95 1 0.95
C7, C8 10 uF, 10 V, 0805 R: X5R-G0805 10/16 0.07 3 0.21
D1 1N4001, MELF R: X7R-G1206 100N 0.04 1 0.04
L1 Do not populate 0.00 0 0.00
Sum 1.20

Option: Button

Designator Value Part-No Price / EUR Count Sum / EUR
R41 3.6 kΩ, 1206 R: 0.01 1 0.01
BTN Pushbutton ? 0.10 1 0.10
Sum 0.11

Tutorial

Soldering the Components onto the PCB

Microcontroller

The first step in soldering this board is also the most difficult: Soldering the microcontroller. We are going to use the drag soldering technique. To do so, we first place the microcontroller on the board to get an idea of how it should be placed afterwards. Note the pin one mark which is a small dip in one corner of the IC. This is used to orient it correctly:

Now remove the microcontroller again, select one pad of the pcb and tin it. For this and the next two steps, you don't have to worry about any solder bridges, we will remove them afterwards.

Now grab the microcontroller with a pair of tweezers, heat up the tinned pad and place the microcontroller correctly. Do not overheat the microcontroller: If you are not able to position the microcontroller within about 10 seconds remove the soldering iron and try again after waiting a short amount of time.

To further secure it, also solder one pin on the opposite corner.

Now select one edge of the microcontroller that has not been used in the previous steps and add some Flux to pins. What comes now is not easy and probably may require multiple attempts: Solder some pins one on side of the edge at once and then just slide the soldering iron slowly and without any pressure to the other side:

If you have done everything right (right speed, correct amound of solder and flux) all pins will be soldered to the board and there will be no bridges between them:

If you have created any bridges, there are two ways to get rid of them:

  • Drag the solder away from the microcontroller.
  • Use a desoldering gun or desoldering wig.

However, repeat this process for the three other edges that are not yet soldered completely:

Decoupling Capacitors

To operate, the microcontroller needs a set of decoupling capacitors. These are two-padded components, so we will esentially replicate the first steps of the microcontroller soldering process:

  • Tin one pad,
  • add the component and
  • solder the other side.

The first one is C9, a 100 nF capacitor in a 1206 package, the biggest of the capacitors included in this kit:

Now continue with C1 using the same process. C1 is also a 100 nF capacitor, but in a 0603 package.

And now C2 and C3, both the same capacitor as C1.

Crystal Oscillator

Next step is the crystal oscillator. To prepare for that, we will first solder the capacitors C4 and C5 which are both 22 pf 0603 capacitors.

The crystal oscillator then goes directly on the other side of the pcb below those two capacitors. Just put it in and solder both pins.

Then clip off anything that is above the solder joint.

Programming and Analog Input Headers

Now we add two headers, one for programming the microcontroller, one for the analog input of the microcontroller. Again, the headers are on the back side of the PCB.

Now simply solder each pin to the PCB:

First Test

Get a lab power supply and set the maximum voltage to 5 V and the maximum current to zero. Connect the positive terminal (red) and negative terminal (black) as shown in the picture below:

Slowly increase the current. The current should not exceed 20 mA.

If you have reached 20 mA, but the voltage is still below the previously set voltage limit, there is something wrong. Do not further increase the current limit as this could damage the device. Check if every component is soldered and oriented correctly, check if there are any solder bridges.

If everything is okay, connect the in-system programmer. From left to right it's: MOSI, MISO, SCK, Vcc, GND, /RESET

Programming the Microcontroller's Fuses

Go into the source folder and execute make fuses:

source$ make fuses
avrdude -c avrispmkII -P usb -B  100 -p m88  -U lfuse:w:0xff:m -U hfuse:w:0xdf:m -U efuse:w:0xf9:m

avrdude: AVR device initialized and ready to accept instructions

Reading | ################################################## | 100% 0.02s

avrdude: Device signature = 0x1e930a
avrdude: reading input file "0xff"
avrdude: writing lfuse (1 bytes):

Writing | ################################################## | 100% 0.01s

avrdude: 1 bytes of lfuse written
avrdude: verifying lfuse memory against 0xff:
avrdude: load data lfuse data from input file 0xff:
avrdude: input file 0xff contains 1 bytes
avrdude: reading on-chip lfuse data:

Reading | ################################################## | 100% 0.00s

avrdude: verifying ...
avrdude: 1 bytes of lfuse verified
avrdude: reading input file "0xdf"
avrdude: writing hfuse (1 bytes):

Writing | ################################################## | 100% 0.00s

avrdude: 1 bytes of hfuse written
avrdude: verifying hfuse memory against 0xdf:
avrdude: load data hfuse data from input file 0xdf:
avrdude: input file 0xdf contains 1 bytes
avrdude: reading on-chip hfuse data:

Reading | ################################################## | 100% 0.00s

avrdude: verifying ...
avrdude: 1 bytes of hfuse verified
avrdude: reading input file "0xf9"
avrdude: writing efuse (1 bytes):

Writing |                                                    | 0% 0.00s ***failed;  
Writing | ################################################## | 100% 0.05s

avrdude: 1 bytes of efuse written
avrdude: verifying efuse memory against 0xf9:
avrdude: load data efuse data from input file 0xf9:
avrdude: input file 0xf9 contains 1 bytes
avrdude: reading on-chip efuse data:

Reading | ################################################## | 100% 0.00s

avrdude: verifying ...
avrdude: verification error, first mismatch at byte 0x0000
         0xf9 != 0x01
avrdude: verification error; content mismatch

avrdude: safemode: efuse changed! Was f9, and is now 1
Would you like this fuse to be changed back? [y/n] n
avrdude: safemode: Fuses OK

avrdude done.  Thank you.

make: *** [fuses] Error 1

If you are asked if you want to change back the efuse as it has not been written correctly, just say 'n'. In fact the fuse has probably been written correctly, the upper bits are just not writable and always remain 1.

To program the microcontroller and check if the oscillator is working, just execute make:

source$ make
Building objects  build/base.o  build/usb.o  build/leds.o  build/usbdrv/usbdrv.o  build/usbdrv/oddebug.o  build/usbdrv/usbdrvasm.o -> build/out.elf -> build/out.hex
make build/out.hex
make[1]: Entering directory `source'
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax   -c src/base.c -o build/base.o 
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax   -c src/usb.c -o build/usb.o 
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax   -c src/leds.c -o build/leds.o 
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax   -c src/usbdrv/usbdrv.c -o build/usbdrv/usbdrv.o 
src/usbdrv/usbdrv.c:115: warning: overflow in implicit constant conversion
src/usbdrv/usbdrv.c:154: warning: overflow in implicit constant conversion
src/usbdrv/usbdrv.c:156: warning: overflow in implicit constant conversion
src/usbdrv/usbdrv.c: In function ‘usbHandleResetHook’:
src/usbdrv/usbdrv.c:550: warning: unused parameter ‘notResetState’
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax   -c src/usbdrv/oddebug.c -o build/usbdrv/oddebug.o 
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax   -c src/usbdrv/usbdrvasm.S -o build/usbdrv/usbdrvasm.o
avr-gcc -std=gnu99  -W -Wall -pedantic -DF_CPU=20000000UL -mmcu=atmega88 -O2 -ffreestanding -Wl,--relax    build/base.o  build/usb.o  build/leds.o  build/usbdrv/usbdrv.o  build/usbdrv/oddebug.o  build/usbdrv/usbdrvasm.o -o build/out.elf 
avr-size build/out.elf 
   text	   data	    bss	    dec	    hex	filename
   1862	      2	     65	   1929	    789	build/out.elf
avr-objcopy -R .eeprom -O ihex -v build/out.elf build/out.hex 
copy from `build/out.elf' [elf32-avr] to `build/out.hex' [ihex]
make[1]: Leaving directory `source'
make flash
make[1]: Entering directory `source'
avrdude -c avrispmkII -P usb -B  1 -p m88  -U flash:w:build/out.hex:i 

avrdude: AVR device initialized and ready to accept instructions

Reading | ################################################## | 100% 0.00s 

avrdude: Device signature = 0x1e930a
avrdude: NOTE: FLASH memory has been specified, an erase cycle will be performed
         To disable this feature, specify the -D option.
avrdude: erasing chip
avrdude: reading input file "build/out.hex"
avrdude: writing flash (1864 bytes):

Writing | ################################################## | 100% 0.20s

avrdude: 1864 bytes of flash written
avrdude: verifying flash memory against build/out.hex:
avrdude: load data flash data from input file build/out.hex:
avrdude: input file build/out.hex contains 1864 bytes
avrdude: reading on-chip flash data:

Reading | ################################################## | 100% 0.10s

avrdude: verifying ...
avrdude: 1864 bytes of flash verified

avrdude: safemode: Fuses OK

avrdude done.  Thank you.

make[1]: Leaving directory `source'

USB Port

Testing the USB Port