This library lets you control the addressable RGB LED strips from Pololu Robotics & Electronics.

Dependents:   WoYaoChengGOng V2-WoYaoChengGOng STM32_MagneticLight tape_Led_Sample ... more

Summary

This is a library for the mbed that allows you to control these addressable RGB LED products from Pololu:

This library is optimized for the SK6812 and WS2812B, so it transmits colors in green-red-blue order.

If you have a WS2811 LED or a high-speed TM1804 LED strip, please note that its red and green channels are swapped relative to the WS2812B, so you will need to swap those channels in your code. You might prefer to use the version of the library from October 2013, which does not require you to swap red and green in your code.

If you need to control the older, low-speed LED strips (items #2540, #2541, and #2542), you will need to use the version of this library from March 2013.

This library allows complete control over the color of an arbitrary number of LED strips with an arbitrary number of LEDs. Each LED can be individually controlled, and LED strips can be chained together.

This library should also work with any other LED strip based on the SK6812, WS281x, or TM1804.

Supported Platforms

This library has been tested on the mbed NXP LPC1768 (Cortex-M3 at 96 MHz), the mbed NXP LPC11U24 (Cortex-M0 at 48 MHz), and the NUCLEO-F303K8 (Cortex-M4 at 72 MHz). It will probably work on many other boards without modification.

This library does not work on chips families such as the STM32F4 where there is a single register for setting and clearing the value of an output pin. The library checks for the GPIO_IP_WITHOUT_BRR preprocessor macro and triggers a compile-time error if that macro is set.

Getting Started

Software

Here are two example programs that show how to use the library:

Import programLedStripRainbow

This is an example program for the PololuLedStrip library. It generates a simple moving rainbow pattern.

Import programLedStripGradient

This is an example program for the PololuLedStrip library. It generates a simple moving gradient pattern.

As a first step, you should compile and upload one of these to the mbed. When the program runs, the mbed should output color data on pin p8 dozens of times per second. The expected signal is documented on the Pololu website. The example programs only send colors for 60 LEDs, but they can easily be changed to send more for a longer strip.

Hardware

The addressable RGB LED strips can be purchased on Pololu's website using the links above.

The LED strip’s data input connector has two pins that should be connected to the Arduino. The LED strip’s ground will need to be connected to one of the mbed’s GND pins, and the LED strip’s signal input line will be need to be connected to one of the Arduino’s I/O lines. Our example programs assume the signal line is connected to p8. These connections can be made using two Male-Female Premium Jumper Wires, with the female ends plugging into the LED strip and the male ends plugged into a breadboard that houses the mbed.

You will also need to connect a suitable power supply to the LED strip using one of the power connectors. The power supply must be at the right voltage and provide enough current to meet the LED strip's requirements.

If everything works properly, you will see a moving pattern of colors on the LED strip.

Timing Details

This library takes about 1.3 ms to update 30 LEDs (1 meter). The LED strips use a high speed one-wire protocol with relatively strict timing requirements, so this library disables interrupts to ensure reliable color transmission. Unfortunately, disabling the interrupts could cause problems in other libraries that uses interrupts.

This library provides an interruptFriendly option that can let it coexist with interrupt-based libraries. When this option is enabled, the library will temporarily enable interrupts after each color is sent, about every 45 microseconds. If you can keep all of your interrupts short enough, then this option should allow this library to work in conjunction with your interrupt-based libraries. However, if you have an interrupt enabled that takes too long, then this interrupt will sometimes cause an extra long low pulse to emitted, which will be interpreted by the LED strip as a reset command. This can cause visible flickering in the LED strip. To turn on the interruptFriendly option, add this line to the beginning of your main() function:

PololuLedStrip::interruptFriendly = true;

Chaining LED Strips together

No special code is required to chain LED strips together. An X-meter LED strip chained to a Y-meter LED strip can be controlled in exactly the same way as a single (X+Y)-meter LED strip.

Committer:
DavidEGrayson
Date:
Wed Feb 27 00:28:26 2013 +0000
Revision:
0:06475317f283
Child:
4:d3b60bd43811
Still working;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
DavidEGrayson 0:06475317f283 1 AREA asm_func, CODE, READONLY
DavidEGrayson 0:06475317f283 2 EXPORT led_strip_write_color
DavidEGrayson 0:06475317f283 3
DavidEGrayson 0:06475317f283 4 led_strip_write_color
DavidEGrayson 0:06475317f283 5 push {r12, r7}
DavidEGrayson 0:06475317f283 6
DavidEGrayson 0:06475317f283 7 ldr r12, [r0] ; Read the next color.
DavidEGrayson 0:06475317f283 8 rbit r12, r12 ; Reverse the order of the bits.
DavidEGrayson 0:06475317f283 9 rev r12, r12 ; Reverse the order of the bytes.
DavidEGrayson 0:06475317f283 10 mov r7, #24 ; Initialize the loop counter register.
DavidEGrayson 0:06475317f283 11
DavidEGrayson 0:06475317f283 12 send_led_strip_bit
DavidEGrayson 0:06475317f283 13 str r3, [r1] ; Drive the line high.
DavidEGrayson 0:06475317f283 14 rrxs r12, r12 ; Rotate right through carry.
DavidEGrayson 0:06475317f283 15
DavidEGrayson 0:06475317f283 16 nop
DavidEGrayson 0:06475317f283 17 nop
DavidEGrayson 0:06475317f283 18 nop
DavidEGrayson 0:06475317f283 19 nop
DavidEGrayson 0:06475317f283 20 nop
DavidEGrayson 0:06475317f283 21 nop
DavidEGrayson 0:06475317f283 22 nop
DavidEGrayson 0:06475317f283 23 nop
DavidEGrayson 0:06475317f283 24 nop
DavidEGrayson 0:06475317f283 25 nop
DavidEGrayson 0:06475317f283 26
DavidEGrayson 0:06475317f283 27 nop
DavidEGrayson 0:06475317f283 28 nop
DavidEGrayson 0:06475317f283 29 nop
DavidEGrayson 0:06475317f283 30 nop
DavidEGrayson 0:06475317f283 31 nop
DavidEGrayson 0:06475317f283 32 nop
DavidEGrayson 0:06475317f283 33 nop
DavidEGrayson 0:06475317f283 34 nop
DavidEGrayson 0:06475317f283 35 nop
DavidEGrayson 0:06475317f283 36 nop
DavidEGrayson 0:06475317f283 37
DavidEGrayson 0:06475317f283 38 nop
DavidEGrayson 0:06475317f283 39 nop
DavidEGrayson 0:06475317f283 40 nop
DavidEGrayson 0:06475317f283 41 nop
DavidEGrayson 0:06475317f283 42 nop
DavidEGrayson 0:06475317f283 43 nop
DavidEGrayson 0:06475317f283 44 nop
DavidEGrayson 0:06475317f283 45 nop
DavidEGrayson 0:06475317f283 46 nop
DavidEGrayson 0:06475317f283 47 nop
DavidEGrayson 0:06475317f283 48
DavidEGrayson 0:06475317f283 49 nop
DavidEGrayson 0:06475317f283 50 nop
DavidEGrayson 0:06475317f283 51 nop
DavidEGrayson 0:06475317f283 52 nop
DavidEGrayson 0:06475317f283 53 nop
DavidEGrayson 0:06475317f283 54 nop
DavidEGrayson 0:06475317f283 55 nop
DavidEGrayson 0:06475317f283 56 nop
DavidEGrayson 0:06475317f283 57 nop
DavidEGrayson 0:06475317f283 58 nop
DavidEGrayson 0:06475317f283 59
DavidEGrayson 0:06475317f283 60 nop
DavidEGrayson 0:06475317f283 61 nop
DavidEGrayson 0:06475317f283 62 nop
DavidEGrayson 0:06475317f283 63 nop
DavidEGrayson 0:06475317f283 64 nop
DavidEGrayson 0:06475317f283 65 nop
DavidEGrayson 0:06475317f283 66 nop
DavidEGrayson 0:06475317f283 67 nop
DavidEGrayson 0:06475317f283 68 nop
DavidEGrayson 0:06475317f283 69 nop
DavidEGrayson 0:06475317f283 70
DavidEGrayson 0:06475317f283 71 nop
DavidEGrayson 0:06475317f283 72 nop
DavidEGrayson 0:06475317f283 73 nop
DavidEGrayson 0:06475317f283 74 nop
DavidEGrayson 0:06475317f283 75 nop
DavidEGrayson 0:06475317f283 76 nop
DavidEGrayson 0:06475317f283 77 nop
DavidEGrayson 0:06475317f283 78 nop
DavidEGrayson 0:06475317f283 79 nop
DavidEGrayson 0:06475317f283 80 nop
DavidEGrayson 0:06475317f283 81
DavidEGrayson 0:06475317f283 82 nop
DavidEGrayson 0:06475317f283 83 nop
DavidEGrayson 0:06475317f283 84 nop
DavidEGrayson 0:06475317f283 85 nop
DavidEGrayson 0:06475317f283 86
DavidEGrayson 0:06475317f283 87 it cc ; If the bit to send it 0...
DavidEGrayson 0:06475317f283 88 strcc r3, [r2] ; Drive the line low.
DavidEGrayson 0:06475317f283 89
DavidEGrayson 0:06475317f283 90 nop
DavidEGrayson 0:06475317f283 91 nop
DavidEGrayson 0:06475317f283 92 nop
DavidEGrayson 0:06475317f283 93 nop
DavidEGrayson 0:06475317f283 94 nop
DavidEGrayson 0:06475317f283 95 nop
DavidEGrayson 0:06475317f283 96 nop
DavidEGrayson 0:06475317f283 97 nop
DavidEGrayson 0:06475317f283 98 nop
DavidEGrayson 0:06475317f283 99 nop
DavidEGrayson 0:06475317f283 100
DavidEGrayson 0:06475317f283 101 nop
DavidEGrayson 0:06475317f283 102 nop
DavidEGrayson 0:06475317f283 103 nop
DavidEGrayson 0:06475317f283 104 nop
DavidEGrayson 0:06475317f283 105 nop
DavidEGrayson 0:06475317f283 106 nop
DavidEGrayson 0:06475317f283 107 nop
DavidEGrayson 0:06475317f283 108 nop
DavidEGrayson 0:06475317f283 109 nop
DavidEGrayson 0:06475317f283 110 nop
DavidEGrayson 0:06475317f283 111
DavidEGrayson 0:06475317f283 112 nop
DavidEGrayson 0:06475317f283 113 nop
DavidEGrayson 0:06475317f283 114 nop
DavidEGrayson 0:06475317f283 115 nop
DavidEGrayson 0:06475317f283 116 nop
DavidEGrayson 0:06475317f283 117 nop
DavidEGrayson 0:06475317f283 118 nop
DavidEGrayson 0:06475317f283 119 nop
DavidEGrayson 0:06475317f283 120 nop
DavidEGrayson 0:06475317f283 121 nop
DavidEGrayson 0:06475317f283 122
DavidEGrayson 0:06475317f283 123 nop
DavidEGrayson 0:06475317f283 124 nop
DavidEGrayson 0:06475317f283 125 nop
DavidEGrayson 0:06475317f283 126 nop
DavidEGrayson 0:06475317f283 127 nop
DavidEGrayson 0:06475317f283 128 nop
DavidEGrayson 0:06475317f283 129 nop
DavidEGrayson 0:06475317f283 130 nop
DavidEGrayson 0:06475317f283 131 nop
DavidEGrayson 0:06475317f283 132 nop
DavidEGrayson 0:06475317f283 133
DavidEGrayson 0:06475317f283 134 nop
DavidEGrayson 0:06475317f283 135 nop
DavidEGrayson 0:06475317f283 136 nop
DavidEGrayson 0:06475317f283 137 nop
DavidEGrayson 0:06475317f283 138 nop
DavidEGrayson 0:06475317f283 139 nop
DavidEGrayson 0:06475317f283 140 nop
DavidEGrayson 0:06475317f283 141 nop
DavidEGrayson 0:06475317f283 142 nop
DavidEGrayson 0:06475317f283 143 nop
DavidEGrayson 0:06475317f283 144
DavidEGrayson 0:06475317f283 145 nop
DavidEGrayson 0:06475317f283 146 nop
DavidEGrayson 0:06475317f283 147 nop
DavidEGrayson 0:06475317f283 148 nop
DavidEGrayson 0:06475317f283 149 nop
DavidEGrayson 0:06475317f283 150 nop
DavidEGrayson 0:06475317f283 151 nop
DavidEGrayson 0:06475317f283 152 nop
DavidEGrayson 0:06475317f283 153 nop
DavidEGrayson 0:06475317f283 154
DavidEGrayson 0:06475317f283 155
DavidEGrayson 0:06475317f283 156 it cs ; If the bit to send is 1...
DavidEGrayson 0:06475317f283 157 strcs r3, [r2] ; Drive the line low.
DavidEGrayson 0:06475317f283 158
DavidEGrayson 0:06475317f283 159 nop
DavidEGrayson 0:06475317f283 160 nop
DavidEGrayson 0:06475317f283 161 nop
DavidEGrayson 0:06475317f283 162 nop
DavidEGrayson 0:06475317f283 163 nop
DavidEGrayson 0:06475317f283 164 nop
DavidEGrayson 0:06475317f283 165 nop
DavidEGrayson 0:06475317f283 166 nop
DavidEGrayson 0:06475317f283 167 nop
DavidEGrayson 0:06475317f283 168 nop
DavidEGrayson 0:06475317f283 169
DavidEGrayson 0:06475317f283 170 nop
DavidEGrayson 0:06475317f283 171 nop
DavidEGrayson 0:06475317f283 172 nop
DavidEGrayson 0:06475317f283 173 nop
DavidEGrayson 0:06475317f283 174 nop
DavidEGrayson 0:06475317f283 175 nop
DavidEGrayson 0:06475317f283 176 nop
DavidEGrayson 0:06475317f283 177 nop
DavidEGrayson 0:06475317f283 178 nop
DavidEGrayson 0:06475317f283 179 nop
DavidEGrayson 0:06475317f283 180
DavidEGrayson 0:06475317f283 181 nop
DavidEGrayson 0:06475317f283 182 nop
DavidEGrayson 0:06475317f283 183 nop
DavidEGrayson 0:06475317f283 184 nop
DavidEGrayson 0:06475317f283 185 nop
DavidEGrayson 0:06475317f283 186 nop
DavidEGrayson 0:06475317f283 187 nop
DavidEGrayson 0:06475317f283 188 nop
DavidEGrayson 0:06475317f283 189 nop
DavidEGrayson 0:06475317f283 190 nop
DavidEGrayson 0:06475317f283 191
DavidEGrayson 0:06475317f283 192 nop
DavidEGrayson 0:06475317f283 193 nop
DavidEGrayson 0:06475317f283 194 nop
DavidEGrayson 0:06475317f283 195 nop
DavidEGrayson 0:06475317f283 196 nop
DavidEGrayson 0:06475317f283 197 nop
DavidEGrayson 0:06475317f283 198 nop
DavidEGrayson 0:06475317f283 199 nop
DavidEGrayson 0:06475317f283 200 nop
DavidEGrayson 0:06475317f283 201 nop
DavidEGrayson 0:06475317f283 202
DavidEGrayson 0:06475317f283 203 nop
DavidEGrayson 0:06475317f283 204 nop
DavidEGrayson 0:06475317f283 205 nop
DavidEGrayson 0:06475317f283 206 nop
DavidEGrayson 0:06475317f283 207 nop
DavidEGrayson 0:06475317f283 208 nop
DavidEGrayson 0:06475317f283 209 nop
DavidEGrayson 0:06475317f283 210 nop
DavidEGrayson 0:06475317f283 211 nop
DavidEGrayson 0:06475317f283 212 nop
DavidEGrayson 0:06475317f283 213
DavidEGrayson 0:06475317f283 214 nop
DavidEGrayson 0:06475317f283 215 nop
DavidEGrayson 0:06475317f283 216 nop
DavidEGrayson 0:06475317f283 217 nop
DavidEGrayson 0:06475317f283 218 nop
DavidEGrayson 0:06475317f283 219 nop
DavidEGrayson 0:06475317f283 220 nop
DavidEGrayson 0:06475317f283 221 nop
DavidEGrayson 0:06475317f283 222 nop
DavidEGrayson 0:06475317f283 223 nop
DavidEGrayson 0:06475317f283 224
DavidEGrayson 0:06475317f283 225 nop
DavidEGrayson 0:06475317f283 226 nop
DavidEGrayson 0:06475317f283 227 nop
DavidEGrayson 0:06475317f283 228 nop
DavidEGrayson 0:06475317f283 229 nop
DavidEGrayson 0:06475317f283 230 nop
DavidEGrayson 0:06475317f283 231 nop
DavidEGrayson 0:06475317f283 232 nop
DavidEGrayson 0:06475317f283 233 nop
DavidEGrayson 0:06475317f283 234 nop
DavidEGrayson 0:06475317f283 235
DavidEGrayson 0:06475317f283 236 nop
DavidEGrayson 0:06475317f283 237 nop
DavidEGrayson 0:06475317f283 238 nop
DavidEGrayson 0:06475317f283 239 nop
DavidEGrayson 0:06475317f283 240 nop
DavidEGrayson 0:06475317f283 241 nop
DavidEGrayson 0:06475317f283 242 nop
DavidEGrayson 0:06475317f283 243 nop
DavidEGrayson 0:06475317f283 244 nop
DavidEGrayson 0:06475317f283 245 nop
DavidEGrayson 0:06475317f283 246
DavidEGrayson 0:06475317f283 247 nop
DavidEGrayson 0:06475317f283 248 nop
DavidEGrayson 0:06475317f283 249 nop
DavidEGrayson 0:06475317f283 250 nop
DavidEGrayson 0:06475317f283 251 nop
DavidEGrayson 0:06475317f283 252 nop
DavidEGrayson 0:06475317f283 253 nop
DavidEGrayson 0:06475317f283 254 nop
DavidEGrayson 0:06475317f283 255 nop
DavidEGrayson 0:06475317f283 256 nop
DavidEGrayson 0:06475317f283 257
DavidEGrayson 0:06475317f283 258 nop
DavidEGrayson 0:06475317f283 259 nop
DavidEGrayson 0:06475317f283 260 nop
DavidEGrayson 0:06475317f283 261 nop
DavidEGrayson 0:06475317f283 262 nop
DavidEGrayson 0:06475317f283 263 nop
DavidEGrayson 0:06475317f283 264 nop
DavidEGrayson 0:06475317f283 265 nop
DavidEGrayson 0:06475317f283 266 nop
DavidEGrayson 0:06475317f283 267 nop
DavidEGrayson 0:06475317f283 268
DavidEGrayson 0:06475317f283 269 nop
DavidEGrayson 0:06475317f283 270 nop
DavidEGrayson 0:06475317f283 271 nop
DavidEGrayson 0:06475317f283 272 nop
DavidEGrayson 0:06475317f283 273 nop
DavidEGrayson 0:06475317f283 274 nop
DavidEGrayson 0:06475317f283 275 nop
DavidEGrayson 0:06475317f283 276
DavidEGrayson 0:06475317f283 277 sub r7, r7, #1 ; Decrement the loop counter.
DavidEGrayson 0:06475317f283 278 cbz r7, led_strip_asm_end ; If we have sent 24 bits, go to the end.
DavidEGrayson 0:06475317f283 279 b send_led_strip_bit ; Otherwise, go back and send another bit.
DavidEGrayson 0:06475317f283 280
DavidEGrayson 0:06475317f283 281 led_strip_asm_end
DavidEGrayson 0:06475317f283 282 pop {r12, r7}
DavidEGrayson 0:06475317f283 283 bx lr
DavidEGrayson 0:06475317f283 284
DavidEGrayson 0:06475317f283 285 END