diff src/cs/drivers/drv_app/buzzer/pwt.c @ 290:0e5ccb343284

implement PWT buzzer driver The piece implemented here is the low-level driver component; there will also be a higher-level buzzer melody player service, to be implemented in RiViera land, that will be the sole caller of PWT API functions provided by the present driver.
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 26 Mar 2022 18:23:50 +0000
parents
children a72feaed133a
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/drivers/drv_app/buzzer/pwt.c	Sat Mar 26 18:23:50 2022 +0000
@@ -0,0 +1,42 @@
+/*
+ * This C module is a FreeCalypso addition: it implements hw driver functions
+ * for Calypso buzzer output in PWT mode.
+ */
+
+#include "main/sys_types.h"
+#include "pwt.h"
+
+#define	ASIC_CONF_REG	(*(volatile SYS_UWORD16 *) 0xFFFEF008)
+#define	PWT_MODE_MASK	0x0020
+
+#define	PWT_FRC_REG	(*(volatile SYS_UWORD8 *) 0xFFFE8800)
+#define	PWT_VCR_REG	(*(volatile SYS_UWORD8 *) 0xFFFE8801)
+#define	PWT_GCR_REG	(*(volatile SYS_UWORD8 *) 0xFFFE8802)
+
+/* flag tells L1 to suppress deep sleep */
+SYS_BOOL PWT_tone_is_on;
+
+void PWT_block_on(void)
+{
+	ASIC_CONF_REG |= PWT_MODE_MASK;
+	PWT_GCR_REG = 0x01;
+}
+
+void PWT_block_off(void)
+{
+	ASIC_CONF_REG &= ~PWT_MODE_MASK;
+	PWT_GCR_REG = 0;
+}
+
+void PWT_play_tone(SYS_UWORD8 note, SYS_UWORD8 volume)
+{
+	PWT_FRC_REG = note;
+	PWT_VCR_REG = (volume << 1) | 1;
+	PWT_tone_is_on = 1;
+}
+
+void PWT_stop_tone(void)
+{
+	PWT_VCR_REG = 0;
+	PWT_tone_is_on = 0;
+}