1
0
mirror of https://github.com/kidoman/embd synced 2025-01-03 10:31:36 +01:00

Merge pull request #13 from alsm/master

embd, rpi: determine pi revision, make rev2 pinmap default
This commit is contained in:
Karan Misra 2014-09-10 09:19:05 +05:30
commit b70d632937
2 changed files with 21 additions and 3 deletions

View File

@ -4,6 +4,7 @@ package embd
import ( import (
"fmt" "fmt"
"io/ioutil"
"os/exec" "os/exec"
"strconv" "strconv"
"strings" "strings"
@ -76,6 +77,22 @@ func kernelVersion() (major, minor, patch int, err error) {
return parseVersion(output) return parseVersion(output)
} }
func getPiRevision() (int, error) {
//default return code of a rev2 board
cpuinfo, err := ioutil.ReadFile("/proc/cpuinfo")
if err != nil {
return 4, err
}
for _, line := range strings.Split(string(cpuinfo), "\n") {
fields := strings.Fields(line)
if len(fields) > 0 && fields[0] == "Revision" {
rev, err := strconv.ParseInt(fields[2], 16, 8)
return int(rev), err
}
}
return 4, nil
}
// DetectHost returns the detected host and its revision number. // DetectHost returns the detected host and its revision number.
func DetectHost() (Host, int, error) { func DetectHost() (Host, int, error) {
major, minor, patch, err := kernelVersion() major, minor, patch, err := kernelVersion()
@ -98,6 +115,7 @@ func DetectHost() (Host, int, error) {
switch node { switch node {
case "raspberrypi": case "raspberrypi":
host = HostRPi host = HostRPi
rev, _ = getPiRevision()
case "beaglebone": case "beaglebone":
host = HostBBB host = HostBBB
default: default:

View File

@ -61,9 +61,9 @@ var ledMap = embd.LEDMap{
func init() { func init() {
embd.Register(embd.HostRPi, func(rev int) *embd.Descriptor { embd.Register(embd.HostRPi, func(rev int) *embd.Descriptor {
var pins = rev1Pins var pins = rev2Pins
if rev > 1 { if rev < 4 {
pins = rev2Pins pins = rev1Pins
} }
return &embd.Descriptor{ return &embd.Descriptor{