mirror of
https://github.com/linux-sunxi/meta-sunxi.git
synced 2024-11-14 09:18:23 +01:00
5699690a98
Unfortunately there is a difference between different boards when using pyA20 - the GPIO mappings. Olimex tried to solve this by providing different packages for different boards. Just made the receipe use different mappings.h, so it can be easily adjusted to different boards in one receipe. Signed-off-by: Jens Lucius <info@jenslucius.com>
303 lines
10 KiB
C
303 lines
10 KiB
C
/*
|
|
*
|
|
* This file is part of pyA20.
|
|
* mapping.h is python GPIO extension.
|
|
*
|
|
* Copyright (c) 2014 Stefan Mavrodiev @ OLIMEX LTD, <support@olimex.com>
|
|
*
|
|
* pyA20 is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
* MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef __MAPPING_H
|
|
#define __MAPPING_H
|
|
|
|
#include "gpio_lib.h"
|
|
|
|
/**
|
|
Structure that describe all gpio
|
|
*/
|
|
typedef struct _pin {
|
|
char name[10]; // The processor pin
|
|
int offset; // Memory offset for the pin
|
|
int pin_number; // Number on the connector
|
|
}pin_t;
|
|
|
|
typedef struct _gpio {
|
|
char connector_name[10];
|
|
pin_t pins[41];
|
|
}gpio_t;
|
|
|
|
|
|
gpio_t gpio[] = {
|
|
{"lcd",
|
|
{
|
|
{ "PD16", SUNXI_GPD(16), 5 },
|
|
{ "PD17", SUNXI_GPD(17), 6 },
|
|
{ "PD18", SUNXI_GPD(18), 7 },
|
|
{ "PD19", SUNXI_GPD(19), 8 },
|
|
{ "PD20", SUNXI_GPD(20), 9 },
|
|
{ "PD21", SUNXI_GPD(21), 10 },
|
|
{ "PD22", SUNXI_GPD(22), 11 },
|
|
{ "PD23", SUNXI_GPD(23), 12 },
|
|
{ "PD8", SUNXI_GPD(8), 13 },
|
|
{ "PD9", SUNXI_GPD(9), 14 },
|
|
{ "PD10", SUNXI_GPD(10), 15 },
|
|
{ "PD11", SUNXI_GPD(11), 16 },
|
|
{ "PD12", SUNXI_GPD(12), 17 },
|
|
{ "PD13", SUNXI_GPD(13), 18 },
|
|
{ "PD14", SUNXI_GPD(14), 19 },
|
|
{ "PD15", SUNXI_GPD(15), 20 },
|
|
{ "PD0", SUNXI_GPD(0), 21 },
|
|
{ "PD1", SUNXI_GPD(1), 22 },
|
|
{ "PD2", SUNXI_GPD(2), 23 },
|
|
{ "PD3", SUNXI_GPD(3), 24 },
|
|
{ "PD4", SUNXI_GPD(4), 25 },
|
|
{ "PD5", SUNXI_GPD(5), 26 },
|
|
{ "PD6", SUNXI_GPD(6), 27 },
|
|
{ "PD7", SUNXI_GPD(7), 28 },
|
|
{ "PD26", SUNXI_GPD(26), 29 },
|
|
{ "PD27", SUNXI_GPD(27), 30 },
|
|
{ "PD24", SUNXI_GPD(24), 31 },
|
|
{ "PD25", SUNXI_GPD(25), 32 },
|
|
{ "PH8", SUNXI_GPH(8), 35 },
|
|
{ "PB2", SUNXI_GPB(2), 36 },
|
|
{
|
|
{ 0, 0, 0}
|
|
},
|
|
}
|
|
},
|
|
/*
|
|
#define PIN_PG0 SUNXI_GPG(0)
|
|
#define PIN_PG1 SUNXI_GPG(1)
|
|
#define PIN_PG2 SUNXI_GPG(2)
|
|
#define PIN_PG3 SUNXI_GPG(3)
|
|
#define PIN_PG4 SUNXI_GPG(4)
|
|
#define PIN_PG5 SUNXI_GPG(5)
|
|
#define PIN_PG6 SUNXI_GPG(6)
|
|
#define PIN_PG7 SUNXI_GPG(7)
|
|
#define PIN_PG8 SUNXI_GPG(8)
|
|
#define PIN_PG9 SUNXI_GPG(9)
|
|
#define PIN_PG10 SUNXI_GPG(10)
|
|
#define PIN_PG11 SUNXI_GPG(11)
|
|
*/ {"gpio1",
|
|
{
|
|
{ "PG0", SUNXI_GPG(0), 5 },
|
|
{ "PG1", SUNXI_GPG(0), 7 },
|
|
{ "PG2", SUNXI_GPG(0), 9 },
|
|
{ "PG3", SUNXI_GPG(0), 11 },
|
|
{ "PG4", SUNXI_GPG(0), 13 },
|
|
{ "PG5", SUNXI_GPG(0), 15 },
|
|
{ "PG6", SUNXI_GPG(0), 17 },
|
|
{ "PG7", SUNXI_GPG(0), 19 },
|
|
{ "PG8", SUNXI_GPG(0), 21 },
|
|
{ "PG9", SUNXI_GPG(0), 23 },
|
|
{ "PG10", SUNXI_GPG(0), 25 },
|
|
{ "PG11", SUNXI_GPG(0), 27 },
|
|
{
|
|
{ 0, 0, 0}
|
|
},
|
|
}
|
|
},
|
|
|
|
/*
|
|
//GPIO 2
|
|
#define PIN_PE0 SUNXI_GPE(0)
|
|
#define PIN_PE1 SUNXI_GPE(1)
|
|
#define PIN_PI0 SUNXI_GPI(0)
|
|
#define PIN_PE2 SUNXI_GPE(2)
|
|
#define PIN_PI1 SUNXI_GPI(1)
|
|
#define PIN_PE3 SUNXI_GPE(3)
|
|
#define PIN_PI2 SUNXI_GPI(2)
|
|
#define PIN_PE4 SUNXI_GPE(4)
|
|
#define PIN_PI3 SUNXI_GPI(3)
|
|
#define PIN_PE5 SUNXI_GPE(5)
|
|
#define PIN_PI10 SUNXI_GPI(10)
|
|
#define PIN_PE6 SUNXI_GPE(6)
|
|
#define PIN_PI11 SUNXI_GPI(11)
|
|
#define PIN_PE7 SUNXI_GPE(7)
|
|
#define PIN_PC3 SUNXI_GPC(3)
|
|
#define PIN_PE8 SUNXI_GPE(8)
|
|
#define PIN_PC7 SUNXI_GPC(7)
|
|
#define PIN_PE9 SUNXI_GPE(9)
|
|
#define PIN_PC16 SUNXI_GPC(16)
|
|
#define PIN_PE10 SUNXI_GPE(10)
|
|
#define PIN_PC17 SUNXI_GPC(17)
|
|
#define PIN_PE11 SUNXI_GPE(11)
|
|
#define PIN_PC18 SUNXI_GPC(18)
|
|
#define PIN_PI14 SUNXI_GPI(14)
|
|
#define PIN_PC23 SUNXI_GPC(23)
|
|
#define PIN_PI15 SUNXI_GPI(15)
|
|
#define PIN_PC24 SUNXI_GPC(24)
|
|
#define PIN_PB23 SUNXI_GPB(23)
|
|
#define PIN_PB22 SUNXI_GPB(22)
|
|
*/
|
|
{"gpio2",
|
|
{
|
|
{ "PE0", SUNXI_GPE(0), 6 },
|
|
{ "PE1", SUNXI_GPE(1), 8 },
|
|
{ "PI0", SUNXI_GPI(0), 9 },
|
|
{ "PE2", SUNXI_GPE(2), 10 },
|
|
{ "PI1", SUNXI_GPI(1), 11 },
|
|
{ "PE3", SUNXI_GPE(3), 12 },
|
|
{ "PI2", SUNXI_GPI(2), 13 },
|
|
{ "PE4", SUNXI_GPE(4), 14 },
|
|
{ "PI3", SUNXI_GPI(3), 15 },
|
|
{ "PE5", SUNXI_GPE(5), 16 },
|
|
{ "PI10", SUNXI_GPI(10), 17 },
|
|
{ "PE6", SUNXI_GPE(6), 18 },
|
|
{ "PI11", SUNXI_GPI(11), 19 },
|
|
{ "PE7", SUNXI_GPE(7), 20 },
|
|
{ "PC3", SUNXI_GPC(3), 21 },
|
|
{ "PE8", SUNXI_GPE(8), 22 },
|
|
{ "PC7", SUNXI_GPC(7), 23 },
|
|
{ "PE9", SUNXI_GPE(9), 24 },
|
|
{ "PC16", SUNXI_GPC(16), 25 },
|
|
{ "PE10", SUNXI_GPE(10), 26 },
|
|
{ "PC17", SUNXI_GPC(17), 27 },
|
|
{ "PE11", SUNXI_GPE(11), 28 },
|
|
{ "PC18", SUNXI_GPC(18), 29 },
|
|
{ "PI14", SUNXI_GPI(14), 30 },
|
|
{ "PC23", SUNXI_GPC(23), 31 },
|
|
{ "PI15", SUNXI_GPI(15), 32 },
|
|
{ "PC24", SUNXI_GPC(24), 33 },
|
|
{ "PB23", SUNXI_GPB(23), 34 },
|
|
{ "PB22", SUNXI_GPB(22), 36 },
|
|
{
|
|
{ 0, 0, 0}
|
|
},
|
|
}
|
|
},
|
|
|
|
/*
|
|
//GPIO 3
|
|
#define PIN_PH0 SUNXI_GPH(0)
|
|
#define PIN_PB3 SUNXI_GPB(3)
|
|
#define PIN_PH2 SUNXI_GPH(2)
|
|
#define PIN_PB4 SUNXI_GPB(4)
|
|
#define PIN_PH7 SUNXI_GPH(7)
|
|
#define PIN_PB5 SUNXI_GPB(5)
|
|
#define PIN_PH9 SUNXI_GPH(9)
|
|
#define PIN_PB6 SUNXI_GPB(6)
|
|
#define PIN_PH10 SUNXI_GPH(10)
|
|
#define PIN_PB7 SUNXI_GPB(7)
|
|
#define PIN_PH11 SUNXI_GPH(11)
|
|
#define PIN_PB8 SUNXI_GPB(8)
|
|
#define PIN_PH12 SUNXI_GPH(12)
|
|
#define PIN_PB10 SUNXI_GPB(10)
|
|
#define PIN_PH13 SUNXI_GPH(13)
|
|
#define PIN_PB11 SUNXI_GPB(11)
|
|
#define PIN_PH14 SUNXI_GPH(14)
|
|
#define PIN_PB12 SUNXI_GPB(12)
|
|
#define PIN_PH15 SUNXI_GPH(15)
|
|
#define PIN_PB13 SUNXI_GPB(13)
|
|
#define PIN_PH16 SUNXI_GPH(16)
|
|
#define PIN_PB14 SUNXI_GPB(14)
|
|
#define PIN_PH17 SUNXI_GPH(17)
|
|
#define PIN_PB15 SUNXI_GPB(15)
|
|
#define PIN_PH18 SUNXI_GPH(18)
|
|
#define PIN_PB16 SUNXI_GPB(16)
|
|
#define PIN_PH19 SUNXI_GPH(19)
|
|
#define PIN_PB17 SUNXI_GPB(17)
|
|
#define PIN_PH20 SUNXI_GPH(20)
|
|
#define PIN_PH24 SUNXI_GPH(24)
|
|
#define PIN_PH21 SUNXI_GPH(21)
|
|
#define PIN_PH25 SUNXI_GPH(25)
|
|
#define PIN_PH22 SUNXI_GPH(22)
|
|
#define PIN_PH26 SUNXI_GPH(26)
|
|
#define PIN_PH23 SUNXI_GPH(23)
|
|
#define PIN_PH27 SUNXI_GPH(27)
|
|
*/
|
|
{"gpio3",
|
|
{
|
|
{ "PH0", SUNXI_GPH(0), 5 },
|
|
{ "PB3", SUNXI_GPB(3), 6 },
|
|
{ "PH2", SUNXI_GPH(2), 7 },
|
|
{ "PB4", SUNXI_GPB(4), 8 },
|
|
{ "PH7", SUNXI_GPH(7), 9 },
|
|
{ "PB5", SUNXI_GPB(5), 10 },
|
|
{ "PH9", SUNXI_GPH(9), 11 },
|
|
{ "PB6", SUNXI_GPB(6), 12 },
|
|
{ "PH10", SUNXI_GPH(10), 13 },
|
|
{ "PB7", SUNXI_GPB(7), 14 },
|
|
{ "PH11", SUNXI_GPH(11), 15 },
|
|
{ "PB8", SUNXI_GPB(8), 16 },
|
|
{ "PH12", SUNXI_GPH(12), 17 },
|
|
{ "PB10", SUNXI_GPB(10), 18 },
|
|
{ "PH13", SUNXI_GPH(13), 19 },
|
|
{ "PB11", SUNXI_GPB(11), 20 },
|
|
{ "PH14", SUNXI_GPH(14), 21 },
|
|
{ "PB12", SUNXI_GPB(12), 22 },
|
|
{ "PH15", SUNXI_GPH(15), 23 },
|
|
{ "PB13", SUNXI_GPB(13), 24 },
|
|
{ "PH16", SUNXI_GPH(16), 25 },
|
|
{ "PB14", SUNXI_GPB(14), 26 },
|
|
{ "PH17", SUNXI_GPH(17), 27 },
|
|
{ "PB15", SUNXI_GPB(15), 28 },
|
|
{ "PH18", SUNXI_GPH(18), 29 },
|
|
{ "PB16", SUNXI_GPB(16), 30 },
|
|
{ "PH19", SUNXI_GPH(19), 31 },
|
|
{ "PB17", SUNXI_GPB(17), 32 },
|
|
{ "PH20", SUNXI_GPH(20), 33 },
|
|
{ "PH24", SUNXI_GPH(24), 34 },
|
|
{ "PH21", SUNXI_GPH(21), 35 },
|
|
{ "PH25", SUNXI_GPH(25), 36 },
|
|
{ "PH22", SUNXI_GPH(22), 37 },
|
|
{ "PH26", SUNXI_GPH(26), 38 },
|
|
{ "PH23", SUNXI_GPH(23), 39 },
|
|
{ "PH27", SUNXI_GPH(27), 40 },
|
|
{
|
|
{ 0, 0, 0}
|
|
},
|
|
}
|
|
},
|
|
|
|
|
|
{"uext1",
|
|
{
|
|
{ "PI12", SUNXI_GPI(12), 3 },
|
|
{ "PI13", SUNXI_GPI(13), 4 },
|
|
{ "PB20", SUNXI_GPB(20), 5 },
|
|
{ "PB21", SUNXI_GPB(21), 6 },
|
|
{ "PC22", SUNXI_GPC(22), 7 },
|
|
{ "PC21", SUNXI_GPC(21), 8 },
|
|
{ "PC20", SUNXI_GPC(20), 9 },
|
|
{ "PC19", SUNXI_GPC(19), 10 },
|
|
{
|
|
{ 0, 0, 0}
|
|
},
|
|
}
|
|
},
|
|
|
|
{"uext2",
|
|
{
|
|
{ "PI20", SUNXI_GPI(20), 3 },
|
|
{ "PI21", SUNXI_GPI(21), 4 },
|
|
{ "PB18", SUNXI_GPB(18), 5 },
|
|
{ "PB19", SUNXI_GPB(19), 6 },
|
|
{ "PI19", SUNXI_GPI(19), 7 },
|
|
{ "PI18", SUNXI_GPI(18), 8 },
|
|
{ "PI17", SUNXI_GPI(17), 9 },
|
|
{ "PI16", SUNXI_GPI(16), 10 },
|
|
{
|
|
{ 0, 0, 0}
|
|
},
|
|
}
|
|
},
|
|
};
|
|
|
|
|
|
|
|
#endif |