2 Commits

Author SHA1 Message Date
f1afd20021 revoke 2024-04-18 15:16:06 +02:00
2befb31ac9 schematics 2024-04-18 15:14:24 +02:00
8 changed files with 35 additions and 64 deletions

Binary file not shown.

View File

@ -13,7 +13,7 @@ CFLAGS+= -g3 -ggdb -gdwarf-2
LDFLAGS=-mmcu=$(MCU) -L $(TOOLCHAIN_PREFIX)/include
$(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 effects.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) $^
$(OBJDUMP) -D $(ARTIFACT).elf > $(ARTIFACT).txt

View File

@ -27,6 +27,35 @@ const uint16_t frequencyCodes[8][12] = {
#define _CS0 BIT2
#define _CS1 BIT0
#define R0 0
#define CHANNEL_A_TONE_PERIOD_FINE_REG R0
#define R1 1
#define CHANNEL_A_TONE_PERIOD_COARSE_REG R1
#define R2 2
#define CHANNEL_B_TONE_PERIOD_FINE_REG R2
#define R3 3
#define CHANNEL_B_TONE_PERIOD_COARSE_REG R3
#define R4 4
#define CHANNEL_C_TONE_PERIOD_FINE_REG R4
#define R5 5
#define CHANNEL_C_TONE_PERIOD_COARSE_REG R5
#define R6 6
#define NOISE_PERIOD_REG R6
#define R7 7
#define _ENABLE_REG R7
#define R10 010
#define CHANNEL_A_AMPLITUDE_REG R10
#define R11 011
#define CHANNEL_B_AMPLITUDE_REG R11
#define R12 012
#define CHANNEL_C_AMPLITUDE_REG R12
#define R13 013
#define ENVELOPE_PERIOD_FINE_REG R13
#define R14 014
#define ENVELOPE_PERIOD_COARSE_REG R13
#define R15 015
#define ENVELOPE_SHAPE_REG R15
uint8_t psgShadowRegisters[2][14];
inline static void BUS_OP_NACT() {
@ -65,11 +94,11 @@ asm volatile (
}
#endif
uint8_t psgReadShadow(uint8_t chip, uint8_t address) {
static uint8_t psgReadShadow(uint8_t chip, uint8_t address) {
return psgShadowRegisters[chip][address];
}
void psgWrite(uint8_t chip, uint8_t address, uint8_t data) {
static void psgWrite(uint8_t chip, uint8_t address, uint8_t data) {
psgShadowRegisters[chip][address] = data;
// according to "State Timing" (p. 15) of datasheet

View File

@ -1,18 +0,0 @@
#include "effects.h"
#include "psg.h"
void effectsInit() {
}
void playEffect1() {
psgWrite(1, NOISE_PERIOD_REG, 0);
psgWrite(1, _ENABLE_REG, psgReadShadow(1, _ENABLE_REG) & ~0b00111000);
psgWrite(1, CHANNEL_A_AMPLITUDE_REG, 020);
psgWrite(1, CHANNEL_B_AMPLITUDE_REG, 020);
psgWrite(1, CHANNEL_C_AMPLITUDE_REG, 020);
psgWrite(1, ENVELOPE_PERIOD_COARSE_REG, 070);
psgWrite(1, ENVELOPE_SHAPE_REG, 0);
}

View File

@ -1,9 +0,0 @@
#ifndef _EFFECTS_H_
#define _EFFECTS_H_
void effectsInit();
#endif // _EFFECTS_H_

View File

@ -9,7 +9,6 @@
#include "melody_tetris.h"
#include "melody_tusch1.h"
#include "mute.h"
#include "effects.h"
int main() {
WDTCTL = WDTPW | WDTHOLD;
@ -29,10 +28,11 @@ int main() {
psgInit();
muteInit();
sequencerInit();
effectsInit();
__enable_interrupt();
// playMelodyTetris();
while (1) {
schExec();
}

View File

@ -36,41 +36,11 @@ typedef enum {
#define e_As e_Gis
#define e_B e_Ais
#define R0 0
#define CHANNEL_A_TONE_PERIOD_FINE_REG R0
#define R1 1
#define CHANNEL_A_TONE_PERIOD_COARSE_REG R1
#define R2 2
#define CHANNEL_B_TONE_PERIOD_FINE_REG R2
#define R3 3
#define CHANNEL_B_TONE_PERIOD_COARSE_REG R3
#define R4 4
#define CHANNEL_C_TONE_PERIOD_FINE_REG R4
#define R5 5
#define CHANNEL_C_TONE_PERIOD_COARSE_REG R5
#define R6 6
#define NOISE_PERIOD_REG R6
#define R7 7
#define _ENABLE_REG R7
#define R10 010
#define CHANNEL_A_AMPLITUDE_REG R10
#define R11 011
#define CHANNEL_B_AMPLITUDE_REG R11
#define R12 012
#define CHANNEL_C_AMPLITUDE_REG R12
#define R13 013
#define ENVELOPE_PERIOD_FINE_REG R13
#define R14 014
#define ENVELOPE_PERIOD_COARSE_REG R13
#define R15 015
#define ENVELOPE_SHAPE_REG R15
void psgInit();
void psgPlayTone(uint8_t chip, uint8_t channel, uint8_t volume, t_octave octave, t_note note);
void psgAmplitude(uint8_t chip, uint8_t channel, uint8_t volume);
uint8_t psgReadShadow(uint8_t chip, uint8_t address);
void psgWrite(uint8_t chip, uint8_t address, uint8_t data);
#endif // _PSG_H_

View File

@ -44,7 +44,6 @@ spiCmdHandler_5:
spiCmdHandler_6:
bit #SOUND_LOCK, &cmd
jz spiCmdHandler_7
call #playEffect1
;; insert a call here
bic #SOUND_LOCK, &cmd
spiCmdHandler_7: