Skip to content

Commit 2de5d32

Browse files
committed
Copy feather-m4 to wioterminal
1 parent c72f9eb commit 2de5d32

File tree

5 files changed

+222
-0
lines changed

5 files changed

+222
-0
lines changed

src/machine/board_wioterminal.go

Lines changed: 100 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,100 @@
1+
// +build sam,atsamd51,feather_m4
2+
3+
package machine
4+
5+
import "device/sam"
6+
7+
// used to reset into bootloader
8+
const RESET_MAGIC_VALUE = 0xf01669ef
9+
10+
// GPIO Pins
11+
const (
12+
D0 = PB17 // UART0 RX/PWM available
13+
D1 = PB16 // UART0 TX/PWM available
14+
D4 = PA14 // PWM available
15+
D5 = PA16 // PWM available
16+
D6 = PA18 // PWM available
17+
D8 = PB03 // built-in neopixel
18+
D9 = PA19 // PWM available
19+
D10 = PA20 // can be used for PWM or UART1 TX
20+
D11 = PA21 // can be used for PWM or UART1 RX
21+
D12 = PA22 // PWM available
22+
D13 = PA23 // PWM available
23+
D21 = PA13 // PWM available
24+
D22 = PA12 // PWM available
25+
D23 = PB22 // PWM available
26+
D24 = PB23 // PWM available
27+
D25 = PA17 // PWM available
28+
)
29+
30+
// Analog pins
31+
const (
32+
A0 = PA02 // ADC/AIN[0]
33+
A1 = PA05 // ADC/AIN[2]
34+
A2 = PB08 // ADC/AIN[3]
35+
A3 = PB09 // ADC/AIN[4]
36+
A4 = PA04 // ADC/AIN[5]
37+
A5 = PA06 // ADC/AIN[10]
38+
)
39+
40+
const (
41+
LED = D13
42+
)
43+
44+
// UART0 aka USBCDC pins
45+
const (
46+
USBCDC_DM_PIN = PA24
47+
USBCDC_DP_PIN = PA25
48+
)
49+
50+
// UART1 pins
51+
const (
52+
UART_TX_PIN = D1
53+
UART_RX_PIN = D0
54+
)
55+
56+
// UART2 pins
57+
const (
58+
UART2_TX_PIN = A4
59+
UART2_RX_PIN = A5
60+
)
61+
62+
// I2C pins
63+
const (
64+
SDA_PIN = D22 // SDA: SERCOM2/PAD[0]
65+
SCL_PIN = D21 // SCL: SERCOM2/PAD[1]
66+
)
67+
68+
// I2C on the Feather M4.
69+
var (
70+
I2C0 = I2C{
71+
Bus: sam.SERCOM2_I2CM,
72+
SERCOM: 2,
73+
}
74+
)
75+
76+
// SPI pins
77+
const (
78+
SPI0_SCK_PIN = D25 // SCK: SERCOM1/PAD[1]
79+
SPI0_MOSI_PIN = D24 // MOSI: SERCOM1/PAD[3]
80+
SPI0_MISO_PIN = D23 // MISO: SERCOM1/PAD[2]
81+
)
82+
83+
// SPI on the Feather M4.
84+
var (
85+
SPI0 = SPI{
86+
Bus: sam.SERCOM1_SPIM,
87+
SERCOM: 1,
88+
}
89+
)
90+
91+
// USB CDC identifiers
92+
const (
93+
usb_STRING_PRODUCT = "Adafruit Feather M4"
94+
usb_STRING_MANUFACTURER = "Adafruit"
95+
)
96+
97+
var (
98+
usb_VID uint16 = 0x239A
99+
usb_PID uint16 = 0x8022
100+
)

src/machine/machine_atsamd51p19.go

Lines changed: 58 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,58 @@
1+
// +build sam,atsamd51,atsamd51j19
2+
3+
// Peripheral abstraction layer for the atsamd51.
4+
//
5+
// Datasheet:
6+
// http://ww1.microchip.com/downloads/en/DeviceDoc/60001507C.pdf
7+
//
8+
package machine
9+
10+
import "device/sam"
11+
12+
const HSRAM_SIZE = 0x00030000
13+
14+
// InitPWM initializes the PWM interface.
15+
func InitPWM() {
16+
// turn on timer clocks used for PWM
17+
sam.MCLK.APBBMASK.SetBits(sam.MCLK_APBBMASK_TCC0_ | sam.MCLK_APBBMASK_TCC1_)
18+
sam.MCLK.APBCMASK.SetBits(sam.MCLK_APBCMASK_TCC2_)
19+
sam.MCLK.APBDMASK.SetBits(sam.MCLK_APBDMASK_TCC4_)
20+
21+
//use clock generator 0
22+
sam.GCLK.PCHCTRL[25].Set((sam.GCLK_PCHCTRL_GEN_GCLK0 << sam.GCLK_PCHCTRL_GEN_Pos) |
23+
sam.GCLK_PCHCTRL_CHEN)
24+
sam.GCLK.PCHCTRL[29].Set((sam.GCLK_PCHCTRL_GEN_GCLK0 << sam.GCLK_PCHCTRL_GEN_Pos) |
25+
sam.GCLK_PCHCTRL_CHEN)
26+
sam.GCLK.PCHCTRL[38].Set((sam.GCLK_PCHCTRL_GEN_GCLK0 << sam.GCLK_PCHCTRL_GEN_Pos) |
27+
sam.GCLK_PCHCTRL_CHEN)
28+
}
29+
30+
// getTimer returns the timer to be used for PWM on this pin
31+
func (pwm PWM) getTimer() *sam.TCC_Type {
32+
switch pwm.Pin {
33+
case PA16:
34+
return sam.TCC1
35+
case PA17:
36+
return sam.TCC1
37+
case PA14:
38+
return sam.TCC2
39+
case PA15:
40+
return sam.TCC2
41+
case PA18:
42+
return sam.TCC1
43+
case PA19:
44+
return sam.TCC1
45+
case PA20:
46+
return sam.TCC0
47+
case PA21:
48+
return sam.TCC0
49+
case PA23:
50+
return sam.TCC0
51+
case PA22:
52+
return sam.TCC0
53+
case PB31:
54+
return sam.TCC4
55+
default:
56+
return nil // not supported on this pin
57+
}
58+
}

src/runtime/runtime_atsamd51p19.go

Lines changed: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
// +build sam,atsamd51,atsamd51j19
2+
3+
package runtime
4+
5+
import (
6+
"device/sam"
7+
)
8+
9+
func initSERCOMClocks() {
10+
// Turn on clock to SERCOM0 for UART0
11+
sam.MCLK.APBAMASK.SetBits(sam.MCLK_APBAMASK_SERCOM0_)
12+
sam.GCLK.PCHCTRL[7].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
13+
sam.GCLK_PCHCTRL_CHEN)
14+
15+
// sets the "slow" clock shared by all SERCOM
16+
sam.GCLK.PCHCTRL[3].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
17+
sam.GCLK_PCHCTRL_CHEN)
18+
19+
// Turn on clock to SERCOM1
20+
sam.MCLK.APBAMASK.SetBits(sam.MCLK_APBAMASK_SERCOM1_)
21+
sam.GCLK.PCHCTRL[8].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
22+
sam.GCLK_PCHCTRL_CHEN)
23+
24+
// Turn on clock to SERCOM2
25+
sam.MCLK.APBBMASK.SetBits(sam.MCLK_APBBMASK_SERCOM2_)
26+
sam.GCLK.PCHCTRL[23].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
27+
sam.GCLK_PCHCTRL_CHEN)
28+
29+
// Turn on clock to SERCOM3
30+
sam.MCLK.APBBMASK.SetBits(sam.MCLK_APBBMASK_SERCOM3_)
31+
sam.GCLK.PCHCTRL[24].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
32+
sam.GCLK_PCHCTRL_CHEN)
33+
34+
// Turn on clock to SERCOM4
35+
sam.MCLK.APBDMASK.SetBits(sam.MCLK_APBDMASK_SERCOM4_)
36+
sam.GCLK.PCHCTRL[34].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
37+
sam.GCLK_PCHCTRL_CHEN)
38+
39+
// Turn on clock to SERCOM5
40+
sam.MCLK.APBDMASK.SetBits(sam.MCLK_APBDMASK_SERCOM5_)
41+
sam.GCLK.PCHCTRL[35].Set((sam.GCLK_PCHCTRL_GEN_GCLK1 << sam.GCLK_PCHCTRL_GEN_Pos) |
42+
sam.GCLK_PCHCTRL_CHEN)
43+
}

targets/atsamd51p19a.json

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
{
2+
"inherits": ["cortex-m"],
3+
"llvm-target": "armv7em-none-eabi",
4+
"build-tags": ["atsamd51j19", "atsamd51", "sam"],
5+
"cflags": [
6+
"--target=armv7em-none-eabi",
7+
"-Qunused-arguments"
8+
],
9+
"linkerscript": "targets/atsamd51.ld",
10+
"extra-files": [
11+
"src/device/sam/atsamd51j19a.s"
12+
]
13+
}

targets/wioterminal.json

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
{
2+
"inherits": ["atsamd51j19a"],
3+
"build-tags": ["sam", "atsamd51j19a", "feather_m4"],
4+
"flash-1200-bps-reset": "true",
5+
"flash-method": "msd",
6+
"msd-volume-name": "FEATHERBOOT",
7+
"msd-firmware-name": "firmware.uf2"
8+
}

0 commit comments

Comments
 (0)