diff options
author | Alexander Sulfrian <alexander@sulfrian.net> | 2011-11-17 02:10:12 +0100 |
---|---|---|
committer | Alexander Sulfrian <alexander@sulfrian.net> | 2011-11-17 02:10:12 +0100 |
commit | e9a9d3c9904b451ee5ed230700688714998c2546 (patch) | |
tree | ec3e00be388a027e182b82fe1dbf8f0e64450bdf | |
download | onkyo-ri-e9a9d3c9904b451ee5ed230700688714998c2546.tar.gz onkyo-ri-e9a9d3c9904b451ee5ed230700688714998c2546.tar.xz onkyo-ri-e9a9d3c9904b451ee5ed230700688714998c2546.zip |
initial version
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | Makefile | 364 | ||||
-rw-r--r-- | onkyo_ri.pde | 143 |
3 files changed, 508 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..0e79e7c --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/applet diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..448924e --- /dev/null +++ b/Makefile @@ -0,0 +1,364 @@ +#http://webcache.googleusercontent.com/search?q=cache:YgFLT7xT3xQJ:www.elenafrancesco.org/arduino/palgenerator/Makefile+arduino/palgenerator/Makefile&cd=1&hl=en&ct=clnk&gl=dk&client=firefox-a&source=www.google.dk
+# Arduino 0022 Makefile - modded 3 Aug 2011, sdaau (tested on Ubuntu 11.04)
+# Arduino 0018 Makefile
+# Arduino adaptation by ferrara, mellis, eighthave, oli.keller,
+# alex norman [with help from http://code.google.com/p/arduino/issues/detail?id=65#c5]
+# Version 0018/Mac modifications made by
+# David Wolever
+# Francesco Ferrara
+# http://blog.codekills.net/
+#
+# This makefile allows you to build sketches from the command line
+# without the Arduino environment (or Java).
+#
+# Detailed instructions for using the makefile:
+#
+# 1. Copy this file into the folder with your sketch. There should be a
+# file with the same name as the folder and with the extension .pde
+# (e.g. foo.pde in the foo/ folder).
+#
+# 2. Modify the line containg "INSTALL_DIR" to point to the directory that
+# contains the Arduino installation (for example, under Mac OS X, this
+# might be /Applications/arduino-0012).
+#
+# 3. Modify the line containing "PORT" to refer to the filename
+# representing the USB or serial connection to your Arduino board
+# (e.g. PORT = /dev/tty.USB0). If the exact name of this file
+# changes, you can use * as a wildcard (e.g. PORT = /dev/tty.usb*).
+#
+# 4. Set the line containing "BUILD_MCU" to match your board's processor.
+# Older one's are atmega8 based, newer ones like Arduino Mini, Bluetooth
+# or Diecimila have the atmega168. If you're using a LilyPad Arduino,
+# change BUILD_F_CPU to 8000000.
+#
+# 5. At the command line, change to the directory containing your
+# program's file and the makefile.
+#
+# 6. Type "make" and press enter to compile/verify your program.
+#
+# 7. Type "make upload", reset your Arduino board, and press enter to
+# upload your program to the Arduino board.
+#
+# $Id$
+
+TARGET = $(notdir $(CURDIR))
+# CHANGE BELOW:
+#~ INSTALL_DIR = /Applications/Arduino.app/Contents/Resources/Java
+INSTALL_DIR = /usr/share/arduino-0017
+#~ PORT = /dev/cu.usbserial*
+PORT = /dev/ttyUSB0
+
+# Get these values from:
+# $(INSTALL_DIR)/hardware/boards.txt
+# (arduino-0022/hardware/arduino/boards.txt)
+# The values below are for the "Arduino Duemilanove or Nano w/ ATmega328"
+# now for "Arduino Mega 2560"
+UPLOAD_SPEED = 19200
+UPLOAD_PROTOCOL = stk500v1
+BUILD_MCU = atmega168
+BUILD_F_CPU = 16000000L
+
+# getting undefined reference to `__cxa_pure_virtual'
+#~ [http://www.arduino.cc/cgi-bin/yabb2/YaBB.pl?num=1254180518 Arduino Forum - Makefile]
+#~ http://www.arduino.cc/playground/OpenBSD/CLI
+#~ [http://arduino.cc/forum/index.php?topic=52041.0 A "simple" makefile for Arduino]
+#~ [http://www.arduino.cc/cgi-bin/yabb2/YaBB.pl?num=1275488191 Arduino Forum - Configuring avr-gcc options in arduino IDE]
+# found in /usr/lib/gcc/avr/4.3.5/cc1plus; fixed with -Wl,--gc-section
+
+############################################################################
+# Below here nothing should be changed...
+
+ARDUINO = $(INSTALL_DIR)/hardware/cores/arduino
+#
+#~ AVR_TOOLS_PATH = $(INSTALL_DIR)/hardware/tools/avr/bin
+# in Ubuntu, avr-gcc is installed separate;
+# only avrdude comes with the IDE
+AVR_TOOLS_PATH = /usr/bin
+AVR_DUDE_PATH = $(INSTALL_DIR)/hardware/tools
+#
+SRC = $(ARDUINO)/pins_arduino.c $(ARDUINO)/wiring.c \
+ $(ARDUINO)/wiring_analog.c $(ARDUINO)/wiring_digital.c \
+ $(ARDUINO)/wiring_pulse.c \
+ $(ARDUINO)/wiring_shift.c $(ARDUINO)/WInterrupts.c
+# added applet/$(TARGET).cpp as in IDE 0022
+CXXSRC = $(ARDUINO)/HardwareSerial.cpp $(ARDUINO)/WMath.cpp \
+ $(ARDUINO)/Print.cpp
+# applet/$(TARGET).cpp # no need, having a rule now for applet/$(TARGET).cpp.o
+# added main.cpp, as in 0022
+FORMAT = ihex
+
+# Name of this Makefile (used for "make depend").
+MAKEFILE = Makefile
+
+# Debugging format.
+# Native formats for AVR-GCC's -g are stabs [default], or dwarf-2.
+# AVR (extended) COFF requires stabs, plus an avr-objcopy run.
+DEBUG = stabs
+
+OPT = s
+
+# Place -D or -U options here
+#~ CDEFS = -DBUILD_F_CPU=$(BUILD_F_CPU)
+#~ CXXDEFS = -DBUILD_F_CPU=$(BUILD_F_CPU)
+# now called DF_CPU
+CDEFS = -DF_CPU=$(BUILD_F_CPU) -DARDUINO=22
+CXXDEFS = -DF_CPU=$(BUILD_F_CPU) -DARDUINO=22
+
+# Place -I options here
+CINCS = -I$(ARDUINO)
+CXXINCS = -I$(ARDUINO)
+
+# Compiler flag to set the C Standard level.
+# c89 - "ANSI" C
+# gnu89 - c89 plus GCC extensions
+# c99 - ISO C99 standard (not yet fully implemented)
+# gnu99 - c99 plus GCC extensions
+CSTANDARD = -std=gnu99
+CDEBUG = -g$(DEBUG)
+# note that typically, IDE 0022 uses -w to suppress warnings (both in cpp and c)!
+CWARN = -Wall
+#~ CWARN = -w
+# "-Wstrict-prototypes" is valid for Ada/C/ObjC but not for C++:
+CCWARN = -Wstrict-prototypes
+CTUNING = -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums
+#CEXTRA = -Wa,-adhlns=$(<:.c=.lst)
+
+# to eliminate pins_ardiuno warnings:
+# http://arduino.cc/pipermail/developers_arduino.cc/2010-December/004005.html
+
+# [http://www.arduino.cc/cgi-bin/yabb2/YaBB.pl?num=1254180518 Arduino Forum - Makefile]
+#~ For building the objects files "-ffunction-sections -fdata-sections" was missing
+#~ and the final avr-gcc call needs "-Wl,--gc-section".
+CXSECTF = -fno-exceptions -ffunction-sections -fdata-sections
+CFINALF = -Wl,--gc-section
+
+CFLAGS = $(CDEBUG) $(CDEFS) $(CINCS) -O$(OPT) $(CWARN) $(CCWARN) $(CSTANDARD) $(CEXTRA)
+# added CWARN also to .cpp
+CXXFLAGS = $(CDEFS) $(CINCS) -O$(OPT) $(CWARN) $(CXSECTF)
+#ASFLAGS = -Wa,-adhlns=$(<:.S=.lst),-gstabs
+LDFLAGS = -lm
+
+# Programming support using avrdude. Settings and variables.
+AVRDUDE_PORT = $(PORT)
+AVRDUDE_WRITE_FLASH = -U flash:w:applet/$(TARGET).hex
+AVRDUDE_FLAGS = -V -F \
+ -p $(BUILD_MCU) -P $(AVRDUDE_PORT) -c $(UPLOAD_PROTOCOL) \
+ -b $(UPLOAD_SPEED) -C $(INSTALL_DIR)/hardware/tools/avrdude.conf
+# -b $(UPLOAD_SPEED) -C $(INSTALL_DIR)/hardware/tools/avr/etc/avrdude.conf
+
+# Program settings
+CC = $(AVR_TOOLS_PATH)/avr-gcc
+CXX = $(AVR_TOOLS_PATH)/avr-g++
+OBJCOPY = $(AVR_TOOLS_PATH)/avr-objcopy
+OBJDUMP = $(AVR_TOOLS_PATH)/avr-objdump
+AR = $(AVR_TOOLS_PATH)/avr-ar
+SIZE = $(AVR_TOOLS_PATH)/avr-size
+NM = $(AVR_TOOLS_PATH)/avr-nm
+#~ AVRDUDE = $(AVR_TOOLS_PATH)/avrdude
+AVRDUDE = $(AVR_DUDE_PATH)/avrdude
+REMOVE = rm -f
+MV = mv -f
+
+# Define all object files.
+# NOTE: obj files will be created in respective src directories (libraries or $(INSTALL_DIR));
+# make clean deletes them fine
+# note that srcs are in libraries or other directories;
+# $(CXXSRC:.cpp=.o) will cause obj files to be in same loc as src files
+#~ OBJ = $(SRC:.c=.o) $(CXXSRC:.cpp=.o) $(ASRC:.S=.o)
+# to change the output directory for object files;
+# must change the obj list here!
+# and then, match to corresponding rule somehow?
+# or leave this - and parse in rule (auth automatic variable $(@F))?
+# "Suffix Replacement"
+OBJ = $(SRC:.c=.o) $(CXXSRC:.cpp=.o) $(ASRC:.S=.o)
+
+# added - OBJ list, transformed into applet/
+OBJT = $(addprefix applet/,$(notdir $(OBJ)))
+ALLSRC = $(SRC) $(CXXSRC) $(ASRC)
+
+# Define all listing files.
+LST = $(ASRC:.S=.lst) $(CXXSRC:.cpp=.lst) $(SRC:.c=.lst)
+
+# Combine all necessary flags and optional flags.
+# Add target processor to flags.
+ALL_CFLAGS = -mmcu=$(BUILD_MCU) -I. $(CFLAGS)
+ALL_CXXFLAGS = -mmcu=$(BUILD_MCU) -I. $(CXXFLAGS)
+ALL_ASFLAGS = -mmcu=$(BUILD_MCU) -I. -x assembler-with-cpp $(ASFLAGS)
+
+# depended libraries of .pde need to be added from
+# $(INSTALL_DIR)/libraries (TODO: and/or ~/sketchbook/libraries)
+# grep for 'include', test if exists, add...
+# note: prefix "a real tab character" http://www.delorie.com/djgpp/doc/ug/larger/makefiles.html
+# $$ to escape $ for shell;
+# note: must NOT put comments # inside bash execution;
+# those would get removed by make; making shell see "EOF in backquote substitution"
+# echo $$ix ; \
+# 'shell' twice - for each subprocess! Backtick doesn't get expanded?
+GREPRES:=$(shell for ix in $(shell grep include $(TARGET).pde | sed 's/.*[<"]\(.*\).h[>"].*/\1/'); do \
+ if [ -d $(INSTALL_DIR)/libraries/$$ix ] ; then \
+ LINCS="$$LINCS -I$(INSTALL_DIR)/libraries/$$ix" ;\
+ fi; \
+ done; \
+ echo $$LINCS)
+# append includes:
+CINCS += $(GREPRES)
+CXXINCS += $(GREPRES)
+# append library source .cpp files too (CXXSRC)
+GREPRESB:=$(shell for ix in $(shell grep include $(TARGET).pde | sed 's/.*[<"]\(.*\).h[>"].*/\1/'); do \
+ if [ -d $(INSTALL_DIR)/libraries/$$ix ] ; then \
+ CPPSRCS="$$CPPSRCS $(INSTALL_DIR)/libraries/$$ix/*.cpp" ;\
+ fi; \
+ done; \
+ echo $$CPPSRCS)
+CXXSRC += $(GREPRESB)
+# added - only CXX obj from libraries:
+CXXLIBOBJ = $(GREPRESB:.cpp=.o)
+
+# Default target.
+all: applet_files build sizeafter
+
+build: elf hex
+
+applet_files: $(TARGET).pde
+ # Here is the "preprocessing".
+ # It creates a .cpp file based with the same name as the .pde file.
+ # On top of the new .cpp file comes the WProgram.h header.
+ # At the end there is a generic main() function attached.
+ # Then the .cpp file will be compiled. Errors during compile will
+ # refer to this new, automatically generated, file.
+ # Not the original .pde file you actually edit...
+ test -d applet || mkdir applet
+ # @ supresses printout of the cmdline itself; so only the out of echo is printed
+ @echo ALL OBJT: $(OBJT)
+ @echo ALL CXXLIBOBJ: $(CXXLIBOBJ)
+# echo '#include "WProgram.h"' > applet/$(TARGET).cpp
+ @echo -e "#include \"WProgram.h\"\nvoid setup();\nvoid loop();\n" > applet/$(TARGET).cpp
+ cat $(TARGET).pde >> applet/$(TARGET).cpp
+ # no more need to cat main.cpp (v0022) - now it is compiled in
+ cat $(ARDUINO)/main.cxx >> applet/$(TARGET).cpp
+
+
+elf: applet/$(TARGET).elf
+hex: applet/$(TARGET).hex
+eep: applet/$(TARGET).eep
+lss: applet/$(TARGET).lss
+sym: applet/$(TARGET).sym
+
+# Program the device.
+upload: applet/$(TARGET).hex
+ arduino-reset $(PORT)
+ $(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH)
+
+# Display size of file.
+HEXSIZE = $(SIZE) --target=$(FORMAT) applet/$(TARGET).hex
+ELFSIZE = $(SIZE) applet/$(TARGET).elf
+sizebefore:
+ @if [ -f applet/$(TARGET).elf ]; then echo; echo $(MSG_SIZE_BEFORE); $(HEXSIZE); echo; fi
+
+sizeafter:
+ if [ -f applet/$(TARGET).elf ]; then echo; echo $(MSG_SIZE_AFTER); $(HEXSIZE); echo; fi
+
+# Convert ELF to COFF for use in debugging / simulating in AVR Studio or VMLAB.
+COFFCONVERT=$(OBJCOPY) --debugging \
+ --change-section-address .data-0x800000 \
+ --change-section-address .bss-0x800000 \
+ --change-section-address .noinit-0x800000 \
+ --change-section-address .eeprom-0x810000
+
+coff: applet/$(TARGET).elf
+ $(COFFCONVERT) -O coff-avr applet/$(TARGET).elf $(TARGET).cof
+
+extcoff: $(TARGET).elf
+ $(COFFCONVERT) -O coff-ext-avr applet/$(TARGET).elf $(TARGET).cof
+
+.SUFFIXES: .elf .hex .eep .lss .sym
+
+.elf.hex:
+ $(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@
+
+.elf.eep:
+ -$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
+ --change-section-lma .eeprom=0 -O $(FORMAT) $< $@
+
+# Create extended listing file from ELF output file.
+.elf.lss:
+ $(OBJDUMP) -h -S $< > $@
+
+# Create a symbol table from ELF output file.
+.elf.sym:
+ $(NM) -n $< > $@
+
+# Link: create ELF output file from library.
+# NOTE: applet/$(TARGET).cpp.o MUST BE BEFORE applet/core.a
+# in the dependency list, so its rule runs first!
+applet/$(TARGET).elf: $(TARGET).pde applet/$(TARGET).cpp.o applet/core.a
+# $(CC) $(ALL_CFLAGS) -o $@ applet/$(TARGET).cpp -L. applet/core.a $(LDFLAGS)
+# changed as in IDE v0022: link cpp obj files
+ @echo $$(tput bold)$$(tput setaf 2) $(CC) $$(tput sgr0) $(ALL_CFLAGS) $(CFINALF) -o $@ applet/$(TARGET).cpp.o $(CXXOBJ) -L. applet/core.a $(LDFLAGS)
+ @$(CC) $(ALL_CFLAGS) $(CFINALF) -o $@ applet/$(TARGET).cpp.o $(CXXOBJ) -L. applet/core.a $(LDFLAGS)
+
+# added: cpp.o depends on cpp (and .pde which generates it)
+# $< "first item in the dependencies list"; $@ "left side of the :"; $^ "right side of the :"
+# http://www.cs.colby.edu/maxwell/courses/tutorials/maketutor/
+applet/$(TARGET).cpp.o: applet/$(TARGET).cpp
+ @echo $$(tput bold) $(CXX) $$(tput sgr0) -c $(ALL_CXXFLAGS) $< -o $@
+ @$(CXX) -c $(ALL_CXXFLAGS) $< -o $@
+
+#~ applet/core.a: $(OBJ)
+#~ @for i in $(OBJ); do echo $(AR) rcs applet/core.a $$i; $(AR) rcs applet/core.a $$i; done
+
+applet/core.a: $(OBJT)
+ @for i in $(OBJT); do echo $(AR) rcs applet/core.a $$i; $(AR) rcs applet/core.a $$i; done
+
+# iterate through OBJ to find the original location; then build depending on source extension
+# TODO: add handling of assembler files
+applet/%.o:
+ @for iob in $(OBJ); do \
+ if [ "`basename $$iob`" = "`basename $@`" ]; then \
+ for ios in $(ALLSRC); do \
+ if [ "$${iob%%.*}" = "$${ios%%.*}" ]; then \
+ case $${ios##*.} in \
+ "cpp") \
+ echo "$$(tput bold)$$(tput setaf 1) $(CXX) $$(tput sgr0) -c $(ALL_CXXFLAGS) $$ios -o $@"; \
+ $(CXX) -c $(ALL_CXXFLAGS) $$ios -o $@;; \
+ "c") \
+ echo "$$(tput bold)$$(tput setaf 1) $(CC) $$(tput sgr0) -c $(ALL_CFLAGS) $$ios -o $@"; \
+ $(CC) -c $(ALL_CFLAGS) $$ios -o $@;; \
+ esac; \
+ fi; \
+ done; \
+ fi; \
+ done;
+
+#~ # Compile: create object files from C++ source files.
+#~ .cpp.o:
+#~ $(CXX) -c $(ALL_CXXFLAGS) $< -o $@
+
+#~ # Compile: create object files from C source files.
+#~ .c.o:
+#~ $(CC) -c $(ALL_CFLAGS) $< -o $@
+
+#~ # Compile: create assembler files from C source files.
+#~ .c.s:
+#~ $(CC) -S $(ALL_CFLAGS) $< -o $@
+
+#~ # Assemble: create object files from assembler source files.
+#~ .S.o:
+#~ $(CC) -c $(ALL_ASFLAGS) $< -o $@
+
+#~ # Automatic dependencies
+#~ %.d: %.c
+#~ $(CC) -M $(ALL_CFLAGS) $< | sed "s;$(notdir $*).o:;$*.o $*.d:;" > $@
+
+#~ %.d: %.cpp
+#~ $(CXX) -M $(ALL_CXXFLAGS) $< | sed "s;$(notdir $*).o:;$*.o $*.d:;" > $@
+
+# Target: clean project.
+clean:
+ $(REMOVE) applet/$(TARGET).hex applet/$(TARGET).eep applet/$(TARGET).cof applet/$(TARGET).elf \
+ applet/$(TARGET).map applet/$(TARGET).sym applet/$(TARGET).lss applet/core.a \
+ $(OBJT) applet/$(TARGET).cpp.o \
+ $(OBJ) $(LST) $(SRC:.c=.s) $(SRC:.c=.d) $(CXXSRC:.cpp=.s) $(CXXSRC:.cpp=.d)
+
+.PHONY: all build elf hex eep lss sym program coff extcoff clean applet_files sizebefore sizeafter
+
diff --git a/onkyo_ri.pde b/onkyo_ri.pde new file mode 100644 index 0000000..89adcfc --- /dev/null +++ b/onkyo_ri.pde @@ -0,0 +1,143 @@ +/* + +RI Codes: + +TAPE = 42157 +DVD = 31612 +CD = 71327 +PORT = 81993 +CDR = 71322 +MD = 71808 + +*/ + +#include "signals.h" + +// Digital pin #2 is the same as Pin D2 see +// http://arduino.cc/en/Hacking/PinMapping168 for the 'raw' pin mapping +#define IRpin_PIN PINB +#define IRpin 0 + +#define ARRAY_LEN(array) (sizeof(array)/sizeof(array[0])) + +#define MAXPULSE 500 +#define RESOLUTION 20 +#define FUZZINESS 20 + +int header[] = {300, 100}; +int values[2][2] = { {100, 100}, {100, 200} }; +int trail[] = { 100 }; +uint8_t bits = 12; + +uint8_t raw[2]; + +uint64_t listenForIR(void); +int getPulseLength(); +int getPulseLengthInRange(int expected); + +void setup(void) { + Serial.begin(9600); + Serial.println("Ready to decode IR!"); + pinMode(13, OUTPUT); +} + +void loop(void) { + uint64_t code = listenForIR(); + Serial.println(code, HEX); +} + +int getPulseLength() { + bool high = IRpin_PIN & (1 << IRpin); + bool check = true; + int length = 0; + + while (check) { + length++; + delayMicroseconds(RESOLUTION); + + if (length >= MAXPULSE) { + return -1; + } + + check = IRpin_PIN & (1 << IRpin); + if (! high) { + check = ! check; + } + } + + return length * RESOLUTION / 10; +} + +bool inRange(int value, int expected) { + return (abs(value - expected) <= FUZZINESS); +} + +int getPulseLengthInRange(int expected) { + int length = getPulseLength(); + + if (!inRange(length, expected)) { + length = 0; + } + + return length; +} + +uint64_t listenForIR(void) { + int length; + uint64_t code; + uint8_t i; + +start: + code = 0; + + for (i = 0; i < ARRAY_LEN(header); i++) { + length = getPulseLengthInRange(header[i]); + + if ((length == 0) || (length < 0)) + goto start; + } + + for (uint8_t j = 0; j < bits; j++) { + for (i = 0; i < ARRAY_LEN(raw); i++) { + raw[i] = getPulseLength(); + + if ((raw[i] == 0) || (raw[i] < 0)) + goto start; + } + + bool found; + + for (uint8_t k = 0; k < ARRAY_LEN(values); k++) { + found = true; + + for (i = 0; i < ARRAY_LEN(raw); i++) { + if (!inRange(raw[i], values[k][i])) { + found = false; + break; + } + } + + if (found) { + code <<= 1; + code += k; + + break; + } + } + + if (!found) { + Serial.println(raw[0]); + Serial.println(raw[1]); + goto start; + } + } + + for (i = 0; i < ARRAY_LEN(trail); i++) { + length = getPulseLengthInRange(trail[i]); + + if ((length == 0) || (length < 0)) + goto start; + } + + return code; +} |