mirror of
https://github.com/CTCaer/hekate
synced 2025-01-18 11:06:12 +00:00
94 lines
2.3 KiB
C
94 lines
2.3 KiB
C
/*
|
|
* Copyright (c) 2018 naehrwert
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "../soc/gpio.h"
|
|
#include "../soc/t210.h"
|
|
|
|
static const u16 _gpio_cnf[31] = {
|
|
0x000, 0x004, 0x008, 0x00C,
|
|
0x100, 0x104, 0x108, 0x10C,
|
|
0x200, 0x204, 0x208, 0x20C,
|
|
0x300, 0x304, 0x308, 0x30C,
|
|
0x400, 0x404, 0x408, 0x40C,
|
|
0x500, 0x504, 0x508, 0x50C,
|
|
0x600, 0x604, 0x608, 0x60C,
|
|
0x700, 0x704, 0x708
|
|
};
|
|
|
|
static const u16 _gpio_oe[31] = {
|
|
0x010, 0x014, 0x018, 0x01C,
|
|
0x110, 0x114, 0x118, 0x11C,
|
|
0x210, 0x214, 0x218, 0x21C,
|
|
0x310, 0x314, 0x318, 0x31C,
|
|
0x410, 0x414, 0x418, 0x41C,
|
|
0x510, 0x514, 0x518, 0x51C,
|
|
0x610, 0x614, 0x618, 0x61C,
|
|
0x710, 0x714, 0x718
|
|
};
|
|
|
|
static const u16 _gpio_out[31] = {
|
|
0x020, 0x024, 0x028, 0x02C,
|
|
0x120, 0x124, 0x128, 0x12C,
|
|
0x220, 0x224, 0x228, 0x22C,
|
|
0x320, 0x324, 0x328, 0x32C,
|
|
0x420, 0x424, 0x428, 0x42C,
|
|
0x520, 0x524, 0x528, 0x52C,
|
|
0x620, 0x624, 0x628, 0x62C,
|
|
0x720, 0x724, 0x728
|
|
};
|
|
|
|
static const u16 _gpio_in[31] = {
|
|
0x030, 0x034, 0x038, 0x03C,
|
|
0x130, 0x134, 0x138, 0x13C,
|
|
0x230, 0x234, 0x238, 0x23C,
|
|
0x330, 0x334, 0x338, 0x33C,
|
|
0x430, 0x434, 0x438, 0x43C,
|
|
0x530, 0x534, 0x538, 0x53C,
|
|
0x630, 0x634, 0x638, 0x63C,
|
|
0x730, 0x734, 0x738
|
|
};
|
|
|
|
void gpio_config(u32 port, u32 pins, int mode)
|
|
{
|
|
if (mode)
|
|
GPIO(_gpio_cnf[port]) |= pins;
|
|
else
|
|
GPIO(_gpio_cnf[port]) &= ~pins;
|
|
(void)GPIO(_gpio_cnf[port]);
|
|
}
|
|
|
|
void gpio_output_enable(u32 port, u32 pins, int enable)
|
|
{
|
|
if (enable)
|
|
GPIO(_gpio_oe[port]) |= pins;
|
|
else
|
|
GPIO(_gpio_oe[port]) &= ~pins;
|
|
(void)GPIO(_gpio_oe[port]);
|
|
}
|
|
|
|
void gpio_write(u32 port, u32 pins, int high)
|
|
{
|
|
if (high)
|
|
GPIO(_gpio_out[port]) |= pins;
|
|
else
|
|
GPIO(_gpio_out[port]) &= ~pins;
|
|
(void)GPIO(_gpio_out[port]);
|
|
}
|
|
|
|
int gpio_read(u32 port, u32 pins)
|
|
{
|
|
return (GPIO(_gpio_in[port]) & pins) ? 1 : 0;
|
|
}
|