Compare commits
24 Commits
length_fix
...
sound_inte
Author | SHA1 | Date | |
---|---|---|---|
f1afd20021
|
|||
2befb31ac9
|
|||
36d3b2f735 | |||
d68dae167d
|
|||
3412197cae
|
|||
8dc0569407
|
|||
ac6ca860cb
|
|||
2711f5fb4b
|
|||
9674bc8ef5
|
|||
c0ee849cec
|
|||
78c906ef26
|
|||
0c4533bfac
|
|||
3eed2e30eb
|
|||
3cebb5d351
|
|||
a29525ac9e
|
|||
83e6227581
|
|||
010c493b90
|
|||
2404910870
|
|||
53e538b112
|
|||
1232d0b884 | |||
a1d6422897 | |||
761de5a94d | |||
9a58eedcc4 | |||
2fb12f8af0 |
Binary file not shown.
@ -11,7 +11,7 @@ CFLAGS=-Wall -mmcu=$(MCU) -std=gnu99 -I $(TOOLCHAIN_PREFIX)/include -O1 -g0
|
|||||||
|
|
||||||
LDFLAGS=-mmcu=$(MCU) -L $(TOOLCHAIN_PREFIX)/include
|
LDFLAGS=-mmcu=$(MCU) -L $(TOOLCHAIN_PREFIX)/include
|
||||||
|
|
||||||
$(ARTIFACT).elf: main.o spi.o scheduler.o canvas.o shapes.o game.o buttons.o myrand.o display.o
|
$(ARTIFACT).elf: main.o spi.o scheduler.o canvas.o shapes.o game.o buttons.o myrand.o display.o sound.o
|
||||||
$(CC) -o $@ $(LDFLAGS) $^
|
$(CC) -o $@ $(LDFLAGS) $^
|
||||||
$(OBJDUMP) -D $(ARTIFACT).elf > $(ARTIFACT).txt
|
$(OBJDUMP) -D $(ARTIFACT).elf > $(ARTIFACT).txt
|
||||||
|
|
||||||
|
@ -1,11 +1,13 @@
|
|||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
#include <msp430g2553.h>
|
#include <msp430g2553.h>
|
||||||
|
|
||||||
#include "buttons.h"
|
#include "buttons.h"
|
||||||
#include "scheduler.h"
|
#include "scheduler.h"
|
||||||
#include "shapes.h"
|
#include "shapes.h"
|
||||||
#include "canvas.h"
|
#include "canvas.h"
|
||||||
|
#include "sound.h"
|
||||||
|
|
||||||
|
|
||||||
static uint8_t buttonsMoveLeftPressed() {
|
static uint8_t buttonsMoveLeftPressed() {
|
||||||
@ -45,6 +47,11 @@ static uint8_t buttonsMoveDownPressed() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void buttonsExec(void *handle) {
|
void buttonsExec(void *handle) {
|
||||||
|
static uint32_t unmuteTimestamp;
|
||||||
|
uint32_t currentTimestamp = getSeconds();
|
||||||
|
static bool unmuteFlag = true;
|
||||||
|
|
||||||
|
|
||||||
if (! stoneIsValid()) {
|
if (! stoneIsValid()) {
|
||||||
// don't do anything, the stone has not been initialized
|
// don't do anything, the stone has not been initialized
|
||||||
return;
|
return;
|
||||||
@ -54,27 +61,43 @@ void buttonsExec(void *handle) {
|
|||||||
|
|
||||||
if (buttonsMoveLeftPressed()) {
|
if (buttonsMoveLeftPressed()) {
|
||||||
stoneMoveLeft();
|
stoneMoveLeft();
|
||||||
|
soundCtrl(SOUND_MOTION);
|
||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
}
|
}
|
||||||
if (buttonsMoveRightPressed()) {
|
if (buttonsMoveRightPressed()) {
|
||||||
stoneMoveRight();
|
stoneMoveRight();
|
||||||
|
soundCtrl(SOUND_MOTION);
|
||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
}
|
}
|
||||||
if (buttonsRotateLeftPressed()) {
|
if (buttonsRotateLeftPressed()) {
|
||||||
stoneRotateLeft();
|
stoneRotateLeft();
|
||||||
|
soundCtrl(SOUND_MOTION);
|
||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
}
|
}
|
||||||
if (buttonsRotateRightPressed()) {
|
if (buttonsRotateRightPressed()) {
|
||||||
stoneRotateRight();
|
stoneRotateRight();
|
||||||
|
soundCtrl(SOUND_MOTION);
|
||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
}
|
}
|
||||||
if (buttonsMoveDownPressed()) {
|
if (buttonsMoveDownPressed()) {
|
||||||
stoneMoveDown();
|
stoneMoveDown();
|
||||||
|
soundCtrl(SOUND_MOTION);
|
||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (buttonPressed == 1) {
|
if (buttonPressed == 1) {
|
||||||
canvasShow();
|
canvasShow();
|
||||||
|
|
||||||
|
if (! unmuteFlag) {
|
||||||
|
soundCtrl(SOUND_UNMUTE);
|
||||||
|
unmuteFlag = true;
|
||||||
|
}
|
||||||
|
unmuteTimestamp = currentTimestamp;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (unmuteFlag && (unmuteTimestamp + MUTE_DELAY < currentTimestamp)) {
|
||||||
|
soundCtrl(SOUND_MUTE);
|
||||||
|
unmuteFlag = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#include "canvas.h"
|
#include "canvas.h"
|
||||||
#include "../rgb-driver/colors.h"
|
#include "../rgb-driver/colors.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
|
#include "sound.h"
|
||||||
|
|
||||||
|
|
||||||
#define GAME_CYCLE_TIME 100
|
#define GAME_CYCLE_TIME 100
|
||||||
@ -40,6 +41,7 @@ void gameExec(void *handle) {
|
|||||||
// --- phase: game --------------------------------------------------------
|
// --- phase: game --------------------------------------------------------
|
||||||
case e_Start:
|
case e_Start:
|
||||||
canvasClear();
|
canvasClear();
|
||||||
|
soundCtrl(SOUND_START);
|
||||||
level = 1;
|
level = 1;
|
||||||
score = 0;
|
score = 0;
|
||||||
displaySetValue(score);
|
displaySetValue(score);
|
||||||
@ -71,6 +73,7 @@ void gameExec(void *handle) {
|
|||||||
|
|
||||||
case e_Down:
|
case e_Down:
|
||||||
if (! stoneMoveDown()) {
|
if (! stoneMoveDown()) {
|
||||||
|
soundCtrl(SOUND_LOCK);
|
||||||
state = e_NewStone;
|
state = e_NewStone;
|
||||||
} else {
|
} else {
|
||||||
proceedDelay = delayFactor(level);
|
proceedDelay = delayFactor(level);
|
||||||
@ -80,6 +83,7 @@ void gameExec(void *handle) {
|
|||||||
|
|
||||||
// --- phase: game over ---------------------------------------------------
|
// --- phase: game over ---------------------------------------------------
|
||||||
case e_GameOver:
|
case e_GameOver:
|
||||||
|
soundCtrl(SOUND_GAMEOVER);
|
||||||
rowIndex = CANVAS_HEIGHT;
|
rowIndex = CANVAS_HEIGHT;
|
||||||
phase = e_Phase_GameOver;
|
phase = e_Phase_GameOver;
|
||||||
state = e_GameOverFill;
|
state = e_GameOverFill;
|
||||||
@ -113,17 +117,23 @@ void gameExec(void *handle) {
|
|||||||
|
|
||||||
canvasShow();
|
canvasShow();
|
||||||
if (phase == e_Phase_Game) {
|
if (phase == e_Phase_Game) {
|
||||||
|
uint8_t wipeCnt = 0;
|
||||||
for (uint8_t r = 0; r < CANVAS_HEIGHT; r++) {
|
for (uint8_t r = 0; r < CANVAS_HEIGHT; r++) {
|
||||||
if (canvasIsRowFilled(r)) {
|
if (canvasIsRowFilled(r)) {
|
||||||
score += level;
|
score += level;
|
||||||
displaySetValue(score);
|
displaySetValue(score);
|
||||||
canvasWipeRow(r);
|
canvasWipeRow(r);
|
||||||
canvasShow();
|
canvasShow();
|
||||||
|
wipeCnt += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (wipeCnt != 0) {
|
||||||
|
soundCtrl(SOUND_FANFARE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void gameInit() {
|
void gameInit() {
|
||||||
schAdd(gameExec, NULL, 0, GAME_CYCLE_TIME);
|
schAdd(gameExec, NULL, 0, GAME_CYCLE_TIME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
|
|
||||||
tTask tasks[MAX_NUM_OF_TASKS];
|
tTask tasks[MAX_NUM_OF_TASKS];
|
||||||
|
|
||||||
|
uint32_t seconds;
|
||||||
|
|
||||||
void schInit() {
|
void schInit() {
|
||||||
TACCR0 = 32;
|
TACCR0 = 32;
|
||||||
@ -25,9 +26,18 @@ void schInit() {
|
|||||||
tasks[i].exec = NULL;
|
tasks[i].exec = NULL;
|
||||||
tasks[i].handle = NULL;
|
tasks[i].handle = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
seconds = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void __attribute__ ((interrupt (TIMER0_A0_VECTOR))) schUpdate() {
|
void __attribute__ ((interrupt (TIMER0_A0_VECTOR))) schUpdate() {
|
||||||
|
static uint16_t milliSeconds = 0;
|
||||||
|
if (milliSeconds >= 1000) {
|
||||||
|
seconds += 1;
|
||||||
|
milliSeconds = 0;
|
||||||
|
}
|
||||||
|
milliSeconds += 1;
|
||||||
|
|
||||||
for (uint16_t i = 0; i < MAX_NUM_OF_TASKS; i++) {
|
for (uint16_t i = 0; i < MAX_NUM_OF_TASKS; i++) {
|
||||||
if (tasks[i].exec != NULL) {
|
if (tasks[i].exec != NULL) {
|
||||||
if (tasks[i].delay == 0) {
|
if (tasks[i].delay == 0) {
|
||||||
@ -89,4 +99,13 @@ void schExec() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t getSeconds() {
|
||||||
|
uint32_t s;
|
||||||
|
|
||||||
|
__disable_interrupt();
|
||||||
|
s = seconds;
|
||||||
|
__enable_interrupt();
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -31,6 +31,7 @@ void schDel(void (*exec)(void *), void *handle);
|
|||||||
void schExec();
|
void schExec();
|
||||||
void schUpdate();
|
void schUpdate();
|
||||||
uint8_t schTaskCnt();
|
uint8_t schTaskCnt();
|
||||||
|
uint32_t getSeconds();
|
||||||
|
|
||||||
|
|
||||||
#endif /* PONTCOOPSCHEDULER_H_ */
|
#endif /* PONTCOOPSCHEDULER_H_ */
|
||||||
|
18
game-ctrl/sound.c
Normal file
18
game-ctrl/sound.c
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#include <stdint.h>
|
||||||
|
#include "sound.h"
|
||||||
|
#include "spi.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void soundInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void soundCtrl(uint8_t cmd) {
|
||||||
|
spiSendBegin(e_SPI_SOUND);
|
||||||
|
|
||||||
|
spiSendOctet(cmd);
|
||||||
|
|
||||||
|
spiSendEnd(e_SPI_SOUND);
|
||||||
|
}
|
||||||
|
|
15
game-ctrl/sound.h
Normal file
15
game-ctrl/sound.h
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#ifndef _SOUND_H_
|
||||||
|
#define _SOUND_H_
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#define MUTE_DELAY 30 // seconds
|
||||||
|
|
||||||
|
#include "../sound-driver/soundCodes.h"
|
||||||
|
|
||||||
|
void soundInit();
|
||||||
|
void soundCtrl(uint8_t cmd);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // _SOUND_H_
|
@ -4,20 +4,25 @@ OBJDUMP=$(TOOLCHAIN_PREFIX)/bin/msp430-elf-objdump
|
|||||||
|
|
||||||
ARTIFACT=firmware
|
ARTIFACT=firmware
|
||||||
MCU=msp430g2553
|
MCU=msp430g2553
|
||||||
CFLAGS=-Wall -mmcu=$(MCU) -std=gnu99 -I $(TOOLCHAIN_PREFIX)/include -O1 -g0
|
COMMONFLAGS=-Wall -mmcu=$(MCU) -I $(TOOLCHAIN_PREFIX)/include -O0 -g0
|
||||||
|
CFLAGS=$(COMMONFLAGS) -std=gnu99
|
||||||
|
ASFLAGS=$(COMMONFLAGS) -D__ASSEMBLER__
|
||||||
|
|
||||||
# for debugging
|
# for debugging
|
||||||
#CFLAGS+= -g3 -ggdb -gdwarf-2
|
CFLAGS+= -g3 -ggdb -gdwarf-2
|
||||||
|
|
||||||
LDFLAGS=-mmcu=$(MCU) -L $(TOOLCHAIN_PREFIX)/include
|
LDFLAGS=-mmcu=$(MCU) -L $(TOOLCHAIN_PREFIX)/include
|
||||||
|
|
||||||
$(ARTIFACT).elf: main.o scheduler.o spi.o sequencer.o melody.o ay_3_8913.o
|
$(ARTIFACT).elf: main.o scheduler.o spi.o spi_init.o sequencer.o melody_tetris.o melody_tusch1.o ay_3_8913.o mute.o
|
||||||
$(CC) -o $@ $(LDFLAGS) $^
|
$(CC) -o $@ $(LDFLAGS) $^
|
||||||
$(OBJDUMP) -D $(ARTIFACT).elf > $(ARTIFACT).txt
|
$(OBJDUMP) -D $(ARTIFACT).elf > $(ARTIFACT).txt
|
||||||
|
|
||||||
.c.o:
|
.c.o:
|
||||||
$(CC) $(CFLAGS) -c $<
|
$(CC) $(CFLAGS) -c $<
|
||||||
|
|
||||||
|
.S.o:
|
||||||
|
$(CC) $(ASFLAGS) -c $<
|
||||||
|
|
||||||
|
|
||||||
.PHONY: all
|
.PHONY: all
|
||||||
all: $(ARTIFACT).elf
|
all: $(ARTIFACT).elf
|
||||||
|
Binary file not shown.
@ -6,7 +6,9 @@
|
|||||||
#include "psg.h"
|
#include "psg.h"
|
||||||
#include "scheduler.h"
|
#include "scheduler.h"
|
||||||
#include "sequencer.h"
|
#include "sequencer.h"
|
||||||
#include "melody.h"
|
#include "melody_tetris.h"
|
||||||
|
#include "melody_tusch1.h"
|
||||||
|
#include "mute.h"
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
WDTCTL = WDTPW | WDTHOLD;
|
WDTCTL = WDTPW | WDTHOLD;
|
||||||
@ -22,14 +24,14 @@ int main() {
|
|||||||
|
|
||||||
schInit();
|
schInit();
|
||||||
|
|
||||||
// spiInit();
|
spiInit();
|
||||||
psgInit();
|
psgInit();
|
||||||
|
muteInit();
|
||||||
sequencerInit();
|
sequencerInit();
|
||||||
|
|
||||||
__enable_interrupt();
|
__enable_interrupt();
|
||||||
|
|
||||||
melodyInit();
|
// playMelodyTetris();
|
||||||
|
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
schExec();
|
schExec();
|
||||||
|
@ -1,8 +0,0 @@
|
|||||||
#ifndef _MELODY_H_
|
|
||||||
#define _MELODY_H_
|
|
||||||
|
|
||||||
|
|
||||||
void melodyInit();
|
|
||||||
|
|
||||||
|
|
||||||
#endif // _MELODY_H_
|
|
@ -4,120 +4,6 @@
|
|||||||
#include "sequencer.h"
|
#include "sequencer.h"
|
||||||
#include "scheduler.h"
|
#include "scheduler.h"
|
||||||
|
|
||||||
/*
|
|
||||||
* most simple Tetris from https://de.wikipedia.org/wiki/Korobeiniki
|
|
||||||
const t_tone notes[] = {
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
// Triller
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_32, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_32, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_32, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_32, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_C, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_4, .legato = true , .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_3, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_8, .legato = true , .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_As, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_4, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_B, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_As, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = true , .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_Es, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_3, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
|
|
||||||
{ .octave = e_O_3, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
*/
|
|
||||||
|
|
||||||
const t_tone tonleiter[] = {
|
|
||||||
{ .octave = e_O_6, .note = e_C, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_6, .note = e_D, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_6, .note = e_E, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_6, .note = e_F, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_6, .note = e_G, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_6, .note = e_A, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_6, .note = e_H, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_StopMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tonleiter2[] = {
|
|
||||||
{ .octave = e_O_4, .note = e_C, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_D, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_E, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_F, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_G, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_A, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_H, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tonleiter3[] = {
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_D, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_E, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_F, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_G, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_A, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_H, .length = e_L_1_16, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* three voices theme from https://www.gamemusicthemes.com/sheetmusic/gameboy/tetris/themea/Tetris_-_Theme_A_by_Gori_Fater.pdf
|
* three voices theme from https://www.gamemusicthemes.com/sheetmusic/gameboy/tetris/themea/Tetris_-_Theme_A_by_Gori_Fater.pdf
|
||||||
@ -1036,141 +922,19 @@ const t_tone voice3[] = {
|
|||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
||||||
};
|
};
|
||||||
|
|
||||||
const t_tone tusch1voice1[] = {
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_5, .note = e_F, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_5, .note = e_F, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_5, .note = e_F, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_StopMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tusch1voice2[] = {
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_HoldMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tusch1voice3[] = {
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_A, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_A, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_4, .note = e_A, .length = e_L_1_2, .legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_HoldMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tusch2voice1[] = {
|
|
||||||
{ .octave = e_O_4, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_4, .note = e_E, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_4, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = true },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_StopMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tusch2voice2[] = {
|
|
||||||
{ .octave = e_O_3, .note = e_G, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_3, .note = e_H, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_4, .note = e_D, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_4, .note = e_Fis, .length = e_L_1_2, .legato = false, .staccato = true },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_HoldMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
const t_tone tusch2voice3[] = {
|
|
||||||
{ .octave = e_O_2, .note = e_B, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_3, .note = e_D, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_3, .note = e_F, .length = e_L_1_4, .legato = false, .staccato = true },
|
|
||||||
{ .octave = e_O_3, .note = e_B, .length = e_L_1_2, .legato = false, .staccato = true },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_HoldMark,.legato = false, .staccato = false },
|
|
||||||
|
|
||||||
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
|
||||||
};
|
|
||||||
|
|
||||||
t_melodies tetrisTheme = {
|
t_melodies tetrisTheme = {
|
||||||
.melodies = { { .chip = 0, .amplitude = 3, .tones = voice1 }, { .chip = 0, .amplitude = 3, .tones = voice2 }, { .chip = 0, .amplitude = 3, .tones = voice3 } },
|
.melodies = { { .chip = 0, .amplitude = 8, .tones = voice1 }, { .chip = 0, .amplitude = 8, .tones = voice2 }, { .chip = 0, .amplitude = 8, .tones = voice3 } },
|
||||||
.numOfMelodies = 3,
|
.numOfMelodies = 3,
|
||||||
.pace = 160
|
.pace = 160,
|
||||||
|
.slotMask = 0x01
|
||||||
};
|
};
|
||||||
|
|
||||||
t_melodies tonleiterTheme = {
|
void playMelodyTetris() {
|
||||||
.melodies = { { .chip = 1, .amplitude = 3, .tones = tonleiter }, { .chip = 1, .amplitude = 3, .tones = tonleiter2 }, { .chip = 1, .amplitude = 3, .tones = tonleiter3 } },
|
|
||||||
.numOfMelodies = 3,
|
|
||||||
.pace = 160
|
|
||||||
};
|
|
||||||
t_melodies tusch1 = {
|
|
||||||
.melodies = { { .chip = 1, .amplitude = 8, .tones = tusch1voice1 }, { .chip = 1, .amplitude = 8, .tones = tusch1voice2 }, { .chip = 1, .amplitude = 8, .tones = tusch1voice3 } },
|
|
||||||
.numOfMelodies = 3,
|
|
||||||
.pace = 200
|
|
||||||
};
|
|
||||||
t_melodies tusch2 = {
|
|
||||||
.melodies = { { .chip = 1, .amplitude = 1, .tones = tusch2voice1 }, { .chip = 1, .amplitude = 1, .tones = tusch2voice2 }, { .chip = 1, .amplitude = 1, .tones = tusch2voice3 } },
|
|
||||||
.numOfMelodies = 3,
|
|
||||||
.pace = 160
|
|
||||||
};
|
|
||||||
|
|
||||||
void playTusch1(void *handle) {
|
|
||||||
sequencerPlayMelodies(&tusch1);
|
|
||||||
schAdd(playTusch1, NULL, 30000, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void melodyInit() {
|
|
||||||
sequencerPlayMelodies(&tetrisTheme);
|
sequencerPlayMelodies(&tetrisTheme);
|
||||||
schAdd(playTusch1, NULL, 2000, 0);
|
}
|
||||||
|
|
||||||
|
void stopMelodyTetris() {
|
||||||
|
sequencerStopMelodies(&tetrisTheme);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
9
sound-driver/melody_tetris.h
Normal file
9
sound-driver/melody_tetris.h
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#ifndef _MELODY_TETRIS_H_
|
||||||
|
#define _MELODY_TETRIS_H_
|
||||||
|
|
||||||
|
|
||||||
|
void playMelodyTetris();
|
||||||
|
void stopMelodyTetris();
|
||||||
|
|
||||||
|
|
||||||
|
#endif // _MELODY_TETRIS_H_
|
85
sound-driver/melody_tusch1.c
Normal file
85
sound-driver/melody_tusch1.c
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
#include <stdbool.h>
|
||||||
|
#include <stddef.h>
|
||||||
|
#include "psg.h"
|
||||||
|
#include "sequencer.h"
|
||||||
|
#include "scheduler.h"
|
||||||
|
|
||||||
|
const t_tone tusch1voice1[] = {
|
||||||
|
{ .octave = e_O_5, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
||||||
|
{ .octave = e_O_5, .note = e_F, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_5, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
||||||
|
{ .octave = e_O_5, .note = e_F, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_5, .note = e_C, .length = e_L_1_4, .legato = false, .staccato = true },
|
||||||
|
{ .octave = e_O_5, .note = e_F, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_StopMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
||||||
|
};
|
||||||
|
|
||||||
|
const t_tone tusch1voice2[] = {
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_5, .note = e_C, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_HoldMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
||||||
|
};
|
||||||
|
|
||||||
|
const t_tone tusch1voice3[] = {
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_4, .note = e_A, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_4, .note = e_A, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_8, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Pause, .length = e_L_1_4, .legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_4, .note = e_A, .length = e_L_1_2, .legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_SyncMark,.legato = false, .staccato = false },
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_HoldMark,.legato = false, .staccato = false },
|
||||||
|
|
||||||
|
{ .octave = e_O_Null, .note = e_Null, .length = e_L_EndMark, .legato = false, .staccato = false },
|
||||||
|
};
|
||||||
|
|
||||||
|
t_melodies tusch1 = {
|
||||||
|
.melodies = { { .chip = 1, .amplitude = 12, .tones = tusch1voice1 }, { .chip = 1, .amplitude = 12, .tones = tusch1voice2 }, { .chip = 1, .amplitude = 12, .tones = tusch1voice3 } },
|
||||||
|
.numOfMelodies = 3,
|
||||||
|
.pace = 200,
|
||||||
|
.slotMask = 0x02
|
||||||
|
};
|
||||||
|
|
||||||
|
void playTusch1() {
|
||||||
|
sequencerPlayMelodies(&tusch1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
8
sound-driver/melody_tusch1.h
Normal file
8
sound-driver/melody_tusch1.h
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#ifndef _MELODY_TUSCH1_H_
|
||||||
|
#define _MELODY_TUSCH1_H_
|
||||||
|
|
||||||
|
|
||||||
|
void playTusch1();
|
||||||
|
|
||||||
|
|
||||||
|
#endif // _MELODY_TUSCH1_H_
|
20
sound-driver/mute.c
Normal file
20
sound-driver/mute.c
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#include <msp430g2553.h>
|
||||||
|
#include "mute.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void muteInit() {
|
||||||
|
// BIT6: MuteCtrl
|
||||||
|
P1DIR |= BIT6;
|
||||||
|
P1OUT &= ~BIT6;
|
||||||
|
}
|
||||||
|
|
||||||
|
void mute() {
|
||||||
|
P1OUT |= BIT6;
|
||||||
|
}
|
||||||
|
|
||||||
|
void unMute() {
|
||||||
|
P1OUT &= ~BIT6;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
8
sound-driver/mute.h
Normal file
8
sound-driver/mute.h
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#ifndef _MUTE_H_
|
||||||
|
#define _MUTE_H_
|
||||||
|
|
||||||
|
void muteInit();
|
||||||
|
void mute();
|
||||||
|
void unMute();
|
||||||
|
|
||||||
|
#endif // _MUTE_H_
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define MAX_NUM_OF_TASKS 8
|
#define MAX_NUM_OF_TASKS 4
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -6,8 +6,10 @@
|
|||||||
#include "psg.h"
|
#include "psg.h"
|
||||||
|
|
||||||
|
|
||||||
|
uint8_t slots;
|
||||||
|
|
||||||
void sequencerInit() {
|
void sequencerInit() {
|
||||||
|
slots = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#pragma GCC diagnostic push
|
#pragma GCC diagnostic push
|
||||||
@ -97,12 +99,18 @@ void sequencerExec(void *handle) {
|
|||||||
break;
|
break;
|
||||||
case e_Terminate:
|
case e_Terminate:
|
||||||
schDel(melodies->taskId);
|
schDel(melodies->taskId);
|
||||||
|
slots &= ~(melodies->slotMask);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t sequencerPlayMelodies(t_melodies *melodies) {
|
void sequencerPlayMelodies(t_melodies *melodies) {
|
||||||
|
if ((slots & melodies->slotMask) != 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
slots |= melodies->slotMask;
|
||||||
for (uint8_t i = 0; i < NUM_OF_CHANNELS; i++) {
|
for (uint8_t i = 0; i < NUM_OF_CHANNELS; i++) {
|
||||||
melodies->melodies[i].idx = 0;
|
melodies->melodies[i].idx = 0;
|
||||||
melodies->melodies[i].lengthCnt = 0;
|
melodies->melodies[i].lengthCnt = 0;
|
||||||
@ -112,7 +120,10 @@ uint16_t sequencerPlayMelodies(t_melodies *melodies) {
|
|||||||
melodies->quarterLength = 60000 / melodies->pace / SEQUENCER_PERIOD; // duration of a 1/4 tone in ms
|
melodies->quarterLength = 60000 / melodies->pace / SEQUENCER_PERIOD; // duration of a 1/4 tone in ms
|
||||||
|
|
||||||
melodies->taskId = schAdd(sequencerExec, (void*) melodies, 0, SEQUENCER_PERIOD);
|
melodies->taskId = schAdd(sequencerExec, (void*) melodies, 0, SEQUENCER_PERIOD);
|
||||||
|
}
|
||||||
return melodies->taskId;
|
|
||||||
|
void sequencerStopMelodies(t_melodies *melodies) {
|
||||||
|
slots &= ~(melodies->slotMask);
|
||||||
|
schDel(melodies->taskId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,6 +52,7 @@ typedef struct {
|
|||||||
#define SEQUENCER_PERIOD 4 // ms
|
#define SEQUENCER_PERIOD 4 // ms
|
||||||
#define NUM_OF_CHANNELS 3
|
#define NUM_OF_CHANNELS 3
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
uint8_t slotMask;
|
||||||
uint8_t taskId;
|
uint8_t taskId;
|
||||||
uint16_t quarterLength;
|
uint16_t quarterLength;
|
||||||
uint8_t numOfMelodies;
|
uint8_t numOfMelodies;
|
||||||
@ -61,7 +62,7 @@ typedef struct {
|
|||||||
} t_melodies;
|
} t_melodies;
|
||||||
|
|
||||||
void sequencerInit();
|
void sequencerInit();
|
||||||
uint16_t sequencerPlayMelodies(t_melodies *melodies);
|
void sequencerPlayMelodies(t_melodies *melodies);
|
||||||
|
void sequencerStopMelodies(t_melodies *melodies);
|
||||||
|
|
||||||
#endif // _SEQUENCER_H_
|
#endif // _SEQUENCER_H_
|
||||||
|
14
sound-driver/soundCodes.h
Normal file
14
sound-driver/soundCodes.h
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
#ifndef _SOUND_CODES_H_
|
||||||
|
#define _SOUND_CODES_H_
|
||||||
|
|
||||||
|
#define SOUND_IDLE 0x00
|
||||||
|
#define SOUND_MUTE 0x01
|
||||||
|
#define SOUND_UNMUTE 0x02
|
||||||
|
#define SOUND_START 0x04
|
||||||
|
#define SOUND_GAMEOVER 0x08
|
||||||
|
#define SOUND_FANFARE 0x10
|
||||||
|
#define SOUND_LOCK 0x20
|
||||||
|
#define SOUND_MOTION 0x40
|
||||||
|
#define SOUND_SPEED_UP 0x80
|
||||||
|
|
||||||
|
#endif // _SOUND_CODES_H_
|
70
sound-driver/spi.S
Normal file
70
sound-driver/spi.S
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
#include <msp430g2553.h>
|
||||||
|
#include "soundCodes.h"
|
||||||
|
|
||||||
|
.section ".data"
|
||||||
|
.global cmd
|
||||||
|
cmd:
|
||||||
|
.byte
|
||||||
|
|
||||||
|
.section ".text","ax",@progbits
|
||||||
|
receive_isr:
|
||||||
|
bit #UCB0RXIFG, &UC0IFG
|
||||||
|
jz receive_isr_no_data
|
||||||
|
bis UCB0RXBUF, &cmd
|
||||||
|
receive_isr_no_data:
|
||||||
|
reti
|
||||||
|
|
||||||
|
.global spiCmdHandler
|
||||||
|
spiCmdHandler:
|
||||||
|
spiCmdHandler_1:
|
||||||
|
bit #SOUND_MUTE, &cmd
|
||||||
|
jz spiCmdHandler_2
|
||||||
|
call #mute
|
||||||
|
bic #SOUND_MUTE, &cmd
|
||||||
|
spiCmdHandler_2:
|
||||||
|
bit #SOUND_UNMUTE, &cmd
|
||||||
|
jz spiCmdHandler_3
|
||||||
|
call #unMute
|
||||||
|
bic #SOUND_UNMUTE, &cmd
|
||||||
|
spiCmdHandler_3:
|
||||||
|
bit #SOUND_START, &cmd
|
||||||
|
jz spiCmdHandler_4
|
||||||
|
call #playMelodyTetris
|
||||||
|
bic #SOUND_START, &cmd
|
||||||
|
spiCmdHandler_4:
|
||||||
|
bit #SOUND_GAMEOVER, &cmd
|
||||||
|
jz spiCmdHandler_5
|
||||||
|
;; insert a call here
|
||||||
|
bic #SOUND_GAMEOVER, &cmd
|
||||||
|
spiCmdHandler_5:
|
||||||
|
bit #SOUND_FANFARE, &cmd
|
||||||
|
jz spiCmdHandler_6
|
||||||
|
call #playTusch1
|
||||||
|
bic #SOUND_FANFARE, &cmd
|
||||||
|
spiCmdHandler_6:
|
||||||
|
bit #SOUND_LOCK, &cmd
|
||||||
|
jz spiCmdHandler_7
|
||||||
|
;; insert a call here
|
||||||
|
bic #SOUND_LOCK, &cmd
|
||||||
|
spiCmdHandler_7:
|
||||||
|
bit #SOUND_MOTION, &cmd
|
||||||
|
jz spiCmdHandler_8
|
||||||
|
;; insert a call here
|
||||||
|
bic #SOUND_MOTION, &cmd
|
||||||
|
spiCmdHandler_8:
|
||||||
|
bit #SOUND_SPEED_UP, &cmd
|
||||||
|
jz spiCmdHandler_end
|
||||||
|
;; insert a call here
|
||||||
|
bic #SOUND_SPEED_UP, &cmd
|
||||||
|
spiCmdHandler_end:
|
||||||
|
ret
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.section "__interrupt_vector_8","ax",@progbits
|
||||||
|
.word receive_isr
|
||||||
|
|
||||||
|
|
||||||
|
.end
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
|
|
||||||
void spiInit();
|
void spiInit();
|
||||||
|
void spiCmdHandler();
|
||||||
|
|
||||||
|
|
||||||
#endif // _SPI_H_
|
#endif // _SPI_H_
|
||||||
|
@ -1,13 +1,12 @@
|
|||||||
|
#include <stddef.h>
|
||||||
#include <msp430g2553.h>
|
#include <msp430g2553.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "scheduler.h"
|
||||||
#include "spi.h"
|
#include "spi.h"
|
||||||
|
#include "soundCodes.h"
|
||||||
|
|
||||||
|
|
||||||
void __attribute__ ((interrupt (USCIAB0RX_VECTOR))) receive() {
|
extern uint8_t cmd;
|
||||||
if (UC0IFG & UCB0RXIFG) {
|
|
||||||
// receive an octet
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void spiInit() {
|
void spiInit() {
|
||||||
// SPI slave
|
// SPI slave
|
||||||
@ -15,8 +14,8 @@ void spiInit() {
|
|||||||
// BIT5: UCB0CLK
|
// BIT5: UCB0CLK
|
||||||
// BIT6: UCB0SOMI
|
// BIT6: UCB0SOMI
|
||||||
// BIT7: UCB0SIMO
|
// BIT7: UCB0SIMO
|
||||||
P1SEL |= BIT4 | BIT5 | BIT6 | BIT7;
|
P1SEL |= BIT4 | BIT5 | BIT7;
|
||||||
P1SEL2 |= BIT4 | BIT5 | BIT6 | BIT7;
|
P1SEL2 |= BIT4 | BIT5 | BIT7;
|
||||||
|
|
||||||
// most significant bit first, enable STE
|
// most significant bit first, enable STE
|
||||||
UCB0CTL0 = UCSYNC | UCMSB | UCMODE_2;
|
UCB0CTL0 = UCSYNC | UCMSB | UCMODE_2;
|
||||||
@ -24,6 +23,9 @@ void spiInit() {
|
|||||||
|
|
||||||
// enable RX interrupt
|
// enable RX interrupt
|
||||||
UC0IE |= UCB0RXIE;
|
UC0IE |= UCB0RXIE;
|
||||||
|
|
||||||
|
cmd = SOUND_IDLE;
|
||||||
|
schAdd(spiCmdHandler, NULL, 0, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Reference in New Issue
Block a user