2018-03-27 12:04:16 +13:00
|
|
|
/*
|
2018-08-05 14:40:32 +03:00
|
|
|
* Copyright (c) 2018 naehrwert
|
2022-01-20 12:36:25 +02:00
|
|
|
* Copyright (c) 2018-2022 CTCaer
|
2018-08-05 14:40:32 +03:00
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
*/
|
2018-03-27 12:04:16 +13:00
|
|
|
|
2018-03-15 12:26:19 +13:00
|
|
|
#include "btn.h"
|
2020-06-14 16:45:45 +03:00
|
|
|
#include <soc/i2c.h>
|
|
|
|
#include <soc/gpio.h>
|
2022-06-27 10:22:19 +03:00
|
|
|
#include <soc/timer.h>
|
2020-06-14 16:45:45 +03:00
|
|
|
#include <soc/t210.h>
|
|
|
|
#include <power/max77620.h>
|
2018-03-15 12:26:19 +13:00
|
|
|
|
2019-03-08 00:22:15 +02:00
|
|
|
u8 btn_read()
|
2018-03-15 12:26:19 +13:00
|
|
|
{
|
2019-03-08 00:22:15 +02:00
|
|
|
u8 res = 0;
|
2018-05-01 17:15:48 +12:00
|
|
|
if (!gpio_read(GPIO_PORT_X, GPIO_PIN_7))
|
2018-03-15 12:26:19 +13:00
|
|
|
res |= BTN_VOL_DOWN;
|
2018-05-01 17:15:48 +12:00
|
|
|
if (!gpio_read(GPIO_PORT_X, GPIO_PIN_6))
|
2018-03-15 12:26:19 +13:00
|
|
|
res |= BTN_VOL_UP;
|
2022-10-11 04:11:21 +03:00
|
|
|
// HOAG can use the GPIO. Icosa/Iowa/AULA cannot. Traces are there but they miss a resistor.
|
2021-01-11 21:30:59 +02:00
|
|
|
if (i2c_recv_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_ONOFFSTAT) & MAX77620_ONOFFSTAT_EN0)
|
2018-03-15 12:26:19 +13:00
|
|
|
res |= BTN_POWER;
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-04-14 17:51:42 +03:00
|
|
|
u8 btn_read_vol()
|
|
|
|
{
|
|
|
|
u8 res = 0;
|
|
|
|
if (!gpio_read(GPIO_PORT_X, GPIO_PIN_7))
|
|
|
|
res |= BTN_VOL_DOWN;
|
|
|
|
if (!gpio_read(GPIO_PORT_X, GPIO_PIN_6))
|
|
|
|
res |= BTN_VOL_UP;
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2022-01-16 01:05:42 +02:00
|
|
|
u8 btn_read_home()
|
|
|
|
{
|
|
|
|
return (!gpio_read(GPIO_PORT_Y, GPIO_PIN_1)) ? BTN_HOME : 0;
|
|
|
|
}
|
|
|
|
|
2019-03-08 00:22:15 +02:00
|
|
|
u8 btn_wait()
|
2018-03-15 12:26:19 +13:00
|
|
|
{
|
2019-03-08 00:22:15 +02:00
|
|
|
u8 res = 0, btn = btn_read();
|
2018-08-13 12:12:53 +03:00
|
|
|
bool pwr = false;
|
2018-05-25 00:37:30 +03:00
|
|
|
|
2018-06-15 23:28:27 +12:00
|
|
|
//Power button down, raise a filter.
|
2018-05-25 00:37:30 +03:00
|
|
|
if (btn & BTN_POWER)
|
|
|
|
{
|
2018-08-13 12:12:53 +03:00
|
|
|
pwr = true;
|
2018-06-15 23:28:27 +12:00
|
|
|
btn &= ~BTN_POWER;
|
2018-05-25 00:37:30 +03:00
|
|
|
}
|
|
|
|
|
2018-03-15 12:26:19 +13:00
|
|
|
do
|
|
|
|
{
|
|
|
|
res = btn_read();
|
2018-06-15 23:28:27 +12:00
|
|
|
//Power button up, remove filter.
|
2018-05-25 00:37:30 +03:00
|
|
|
if (!(res & BTN_POWER) && pwr)
|
2018-08-13 12:12:53 +03:00
|
|
|
pwr = false;
|
2018-06-15 23:28:27 +12:00
|
|
|
else if (pwr) //Power button still down.
|
|
|
|
res &= ~BTN_POWER;
|
2018-03-15 12:26:19 +13:00
|
|
|
} while (btn == res);
|
2018-06-13 02:34:32 +03:00
|
|
|
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2019-03-08 00:22:15 +02:00
|
|
|
u8 btn_wait_timeout(u32 time_ms, u8 mask)
|
2020-06-13 18:16:29 +03:00
|
|
|
{
|
|
|
|
u32 timeout = get_tmr_ms() + time_ms;
|
|
|
|
u8 res = btn_read() & mask;
|
|
|
|
|
|
|
|
while (get_tmr_ms() < timeout)
|
|
|
|
{
|
|
|
|
if (res == mask)
|
|
|
|
break;
|
|
|
|
else
|
|
|
|
res = btn_read() & mask;
|
|
|
|
};
|
|
|
|
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
u8 btn_wait_timeout_single(u32 time_ms, u8 mask)
|
2018-06-13 02:34:32 +03:00
|
|
|
{
|
2019-12-07 23:37:07 +02:00
|
|
|
u8 single_button = mask & BTN_SINGLE;
|
|
|
|
mask &= ~BTN_SINGLE;
|
|
|
|
|
2018-07-04 18:39:26 +03:00
|
|
|
u32 timeout = get_tmr_ms() + time_ms;
|
2019-12-07 23:37:07 +02:00
|
|
|
u8 res = btn_read();
|
2018-06-13 02:34:32 +03:00
|
|
|
|
2019-03-08 22:18:54 +02:00
|
|
|
while (get_tmr_ms() < timeout)
|
2018-06-13 02:34:32 +03:00
|
|
|
{
|
2019-12-07 23:37:07 +02:00
|
|
|
if ((res & mask) == mask)
|
|
|
|
{
|
|
|
|
if (single_button && (res & ~mask)) // Undesired button detected.
|
|
|
|
res = btn_read();
|
|
|
|
else
|
|
|
|
return (res & mask);
|
|
|
|
}
|
2019-03-08 00:22:15 +02:00
|
|
|
else
|
2019-12-07 23:37:07 +02:00
|
|
|
res = btn_read();
|
2019-03-08 22:18:54 +02:00
|
|
|
};
|
2018-06-13 02:34:32 +03:00
|
|
|
|
2019-12-07 23:37:07 +02:00
|
|
|
// Timed out.
|
2019-12-12 00:15:08 +02:00
|
|
|
if (!single_button || !time_ms)
|
2019-12-10 13:49:28 +02:00
|
|
|
return (res & mask);
|
|
|
|
else
|
|
|
|
return 0; // Return no button press if single button requested.
|
2018-03-15 12:26:19 +13:00
|
|
|
}
|