aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/machine/machine_rp2040_watchdog.go
blob: 6e9fb874f8022167f14b874c8bdb798201bf7e41 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
//go:build rp2040

package machine

import (
	"device/rp"
	"runtime/volatile"
	"unsafe"
)

type watchdogType struct {
	ctrl    volatile.Register32
	load    volatile.Register32
	reason  volatile.Register32
	scratch [8]volatile.Register32
	tick    volatile.Register32
}

var watchdog = (*watchdogType)(unsafe.Pointer(rp.WATCHDOG))

// startTick starts the watchdog tick.
// cycles needs to be a divider that when applied to the xosc input,
// produces a 1MHz clock. So if the xosc frequency is 12MHz,
// this will need to be 12.
func (wd *watchdogType) startTick(cycles uint32) {
	wd.tick.Set(cycles | rp.WATCHDOG_TICK_ENABLE)
}