mirror of
https://github.com/stianeikeland/go-rpio.git
synced 2025-01-23 02:31:05 +01:00
Using a better method of base address detection.
This commit is contained in:
parent
acd8baadbf
commit
cf3a8b7ed1
37
rpio.go
37
rpio.go
|
@ -57,7 +57,7 @@ package rpio
|
|||
|
||||
import (
|
||||
"bytes"
|
||||
"io/ioutil"
|
||||
"encoding/binary"
|
||||
"os"
|
||||
"reflect"
|
||||
"sync"
|
||||
|
@ -77,9 +77,6 @@ const (
|
|||
pi1GPIOBase = bcm2835Base + 0x200000
|
||||
memLength = 4096
|
||||
|
||||
bcm2836Base = 0x3f000000
|
||||
pi2GPIOBase = bcm2836Base + 0x200000
|
||||
|
||||
pinMask uint32 = 7 // 0b111 - pinmode is 3 bits
|
||||
)
|
||||
|
||||
|
@ -282,15 +279,10 @@ func Open() (err error) {
|
|||
memlock.Lock()
|
||||
defer memlock.Unlock()
|
||||
|
||||
GPIOBase := int64(pi1GPIOBase)
|
||||
if detectPiVersion() == 2 {
|
||||
GPIOBase = pi2GPIOBase
|
||||
}
|
||||
|
||||
// Memory map GPIO registers to byte array
|
||||
mem8, err = syscall.Mmap(
|
||||
int(file.Fd()),
|
||||
GPIOBase,
|
||||
getGPIOBase(),
|
||||
memLength,
|
||||
syscall.PROT_READ|syscall.PROT_WRITE,
|
||||
syscall.MAP_SHARED)
|
||||
|
@ -318,18 +310,23 @@ func Close() error {
|
|||
|
||||
// Read /proc/cpuinfo and detect whether we're running on an RPI1 or RPI2.
|
||||
// Returns 1 or 2 depending on platform.
|
||||
func detectPiVersion() int {
|
||||
cpuinfo, err := os.Open("/proc/cpuinfo")
|
||||
func getGPIOBase() (base int64) {
|
||||
base = pi1GPIOBase
|
||||
ranges, err := os.Open("/proc/device-tree/soc/ranges")
|
||||
defer ranges.Close()
|
||||
if err != nil {
|
||||
panic(err)
|
||||
return
|
||||
}
|
||||
data, err := ioutil.ReadAll(cpuinfo)
|
||||
b := make([]byte, 4)
|
||||
n, err := ranges.ReadAt(b, 4)
|
||||
if n != 4 || err != nil {
|
||||
return
|
||||
}
|
||||
buf := bytes.NewReader(b)
|
||||
var out int64
|
||||
err = binary.Read(buf, binary.LittleEndian, &out)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
if bytes.Contains(data, []byte("BCM2709")) {
|
||||
return 2
|
||||
} else {
|
||||
return 1
|
||||
return
|
||||
}
|
||||
return out + 0x200000
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user