mirror of https://github.com/ARMmbed/mbed-os.git
Added reset_reason feature for TMPM3H6 & TMPM4G9
parent
f6fcabb9b8
commit
5fc77d3c4a
|
|
@ -0,0 +1,120 @@
|
|||
/* mbed Microcontroller Library
|
||||
* (C)Copyright TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION 2018 All rights reserved
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include <stdbool.h>
|
||||
#include "reset_reason_api.h"
|
||||
#include "TMPM3H6.h"
|
||||
|
||||
static uint8_t set_bit_count(uint32_t reg);
|
||||
static uint8_t bit_pos(uint32_t reg);
|
||||
static bool bit_status(uint32_t reg, uint8_t bit_no);
|
||||
|
||||
static reset_reason_t reset_reason1[6] = {
|
||||
RESET_REASON_POWER_ON,
|
||||
RESET_REASON_UNKNOWN,
|
||||
RESET_REASON_UNKNOWN,
|
||||
RESET_REASON_PIN_RESET,
|
||||
RESET_REASON_WAKE_LOW_POWER,
|
||||
RESET_REASON_BROWN_OUT
|
||||
};
|
||||
|
||||
static reset_reason_t reset_reason2[4] = {
|
||||
RESET_REASON_SOFTWARE,
|
||||
RESET_REASON_LOCKUP,
|
||||
RESET_REASON_WATCHDOG,
|
||||
RESET_REASON_PLATFORM
|
||||
};
|
||||
|
||||
void hal_reset_reason_clear(void)
|
||||
{
|
||||
TSB_RLM->RSTFLG0 = 0;
|
||||
TSB_RLM->RSTFLG1 = 0;
|
||||
}
|
||||
|
||||
uint32_t hal_reset_reason_get_raw(void)
|
||||
{
|
||||
uint32_t ret = (((TSB_RLM->RSTFLG1 & 0xFF) << 8) | (TSB_RLM->RSTFLG0 & 0xFF));
|
||||
return ret;
|
||||
}
|
||||
|
||||
reset_reason_t hal_reset_reason_get(void)
|
||||
{
|
||||
char multi_flag = 0;
|
||||
reset_reason_t ret;
|
||||
|
||||
uint8_t NoOfSetBitCountReg1 = set_bit_count(TSB_RLM->RSTFLG0);
|
||||
uint8_t NoOfSetBitCountReg2 = set_bit_count(TSB_RLM->RSTFLG1);
|
||||
|
||||
if (NoOfSetBitCountReg1 != 0x00) {
|
||||
if (NoOfSetBitCountReg1 > 0x01) {
|
||||
if (bit_status(TSB_RLM->RSTFLG0, 3)) {
|
||||
ret = RESET_REASON_POWER_ON;
|
||||
} else {
|
||||
ret = RESET_REASON_MULTIPLE;
|
||||
}
|
||||
} else {
|
||||
ret = reset_reason1[bit_pos(TSB_RLM->RSTFLG0)];
|
||||
}
|
||||
} else if (NoOfSetBitCountReg2 != 0x00) {
|
||||
if (NoOfSetBitCountReg2 > 0x01) {
|
||||
ret = RESET_REASON_MULTIPLE;
|
||||
} else {
|
||||
ret = reset_reason2[bit_pos(TSB_RLM->RSTFLG1)];
|
||||
}
|
||||
} else {
|
||||
ret = RESET_REASON_UNKNOWN;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static bool bit_status(uint32_t reg, uint8_t bit_no)
|
||||
{
|
||||
bool status = false;
|
||||
|
||||
if (reg & (1 << bit_no)) {
|
||||
status = true;
|
||||
}
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
static uint8_t set_bit_count(uint32_t reg)
|
||||
{
|
||||
uint8_t count = 0;
|
||||
int8_t index = 0;
|
||||
|
||||
for (index = 0; index < (sizeof(uint32_t) * 8); index++) {
|
||||
if (reg & (1 << index)) {
|
||||
count++;
|
||||
if (count > 0x01) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
static uint8_t bit_pos(uint32_t reg)
|
||||
{
|
||||
uint8_t bit_no = 0;
|
||||
|
||||
for (bit_no = 0; bit_no < (sizeof(uint32_t) * 8); bit_no++) {
|
||||
if (reg & (1 << bit_no)) {
|
||||
return bit_no;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,123 @@
|
|||
/* mbed Microcontroller Library
|
||||
* (C)Copyright TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION 2018 All rights reserved
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include <stdbool.h>
|
||||
#include "reset_reason_api.h"
|
||||
#include "TMPM4G9.h"
|
||||
|
||||
static uint8_t set_bit_count(uint32_t reg);
|
||||
static uint8_t bit_pos(uint32_t reg);
|
||||
static bool bit_status(uint32_t reg, uint8_t bit_no);
|
||||
|
||||
static reset_reason_t reset_reason1[6] = {
|
||||
RESET_REASON_POWER_ON,
|
||||
RESET_REASON_UNKNOWN,
|
||||
RESET_REASON_UNKNOWN,
|
||||
RESET_REASON_PIN_RESET,
|
||||
RESET_REASON_WAKE_LOW_POWER,
|
||||
RESET_REASON_BROWN_OUT
|
||||
};
|
||||
|
||||
static reset_reason_t reset_reason2[4] = {
|
||||
RESET_REASON_SOFTWARE,
|
||||
RESET_REASON_LOCKUP,
|
||||
RESET_REASON_WATCHDOG,
|
||||
RESET_REASON_PLATFORM
|
||||
};
|
||||
|
||||
void hal_reset_reason_clear(void)
|
||||
{
|
||||
TSB_RLM->RSTFLG0 = 0;
|
||||
TSB_RLM->RSTFLG1 = 0;
|
||||
}
|
||||
|
||||
uint32_t hal_reset_reason_get_raw(void)
|
||||
{
|
||||
uint32_t ret = 0;
|
||||
|
||||
ret = (((TSB_RLM->RSTFLG1 & 0xFF) << 8) | (TSB_RLM->RSTFLG0 & 0xFF));
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
reset_reason_t hal_reset_reason_get(void)
|
||||
{
|
||||
char multi_flag = 0;
|
||||
reset_reason_t ret;
|
||||
|
||||
uint8_t NoOfSetBitCountReg1 = set_bit_count(TSB_RLM->RSTFLG0);
|
||||
uint8_t NoOfSetBitCountReg2 = set_bit_count(TSB_RLM->RSTFLG1);
|
||||
|
||||
if (NoOfSetBitCountReg1 != 0x00) {
|
||||
if (NoOfSetBitCountReg1 > 0x01) {
|
||||
if (bit_status(TSB_RLM->RSTFLG0, 3)) {
|
||||
ret = RESET_REASON_POWER_ON;
|
||||
} else {
|
||||
ret = RESET_REASON_MULTIPLE;
|
||||
}
|
||||
} else {
|
||||
ret = reset_reason1[bit_pos(TSB_RLM->RSTFLG0)];
|
||||
}
|
||||
} else if (NoOfSetBitCountReg2 != 0x00) {
|
||||
if (NoOfSetBitCountReg2 > 0x01) {
|
||||
ret = RESET_REASON_MULTIPLE;
|
||||
} else {
|
||||
ret = reset_reason2[bit_pos(TSB_RLM->RSTFLG1)];
|
||||
}
|
||||
} else {
|
||||
ret = RESET_REASON_UNKNOWN;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static bool bit_status(uint32_t reg, uint8_t bit_no)
|
||||
{
|
||||
bool status = false;
|
||||
|
||||
if (reg & (1 << bit_no)) {
|
||||
status = true;
|
||||
}
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
static uint8_t set_bit_count(uint32_t reg)
|
||||
{
|
||||
uint8_t count = 0;
|
||||
int8_t index = 0;
|
||||
|
||||
for (index = 0; index < (sizeof(uint32_t) * 8); index++) {
|
||||
if (reg & (1 << index)) {
|
||||
count++;
|
||||
if (count > 0x01) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
static uint8_t bit_pos(uint32_t reg)
|
||||
{
|
||||
uint8_t bit_no = 0;
|
||||
|
||||
for (bit_no = 0; bit_no < (sizeof(uint32_t) * 8); bit_no++) {
|
||||
if (reg & (1 << bit_no)) {
|
||||
return bit_no;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -8018,6 +8018,7 @@
|
|||
"PORTINOUT",
|
||||
"PORTOUT",
|
||||
"PWMOUT",
|
||||
"RESET_REASON",
|
||||
"SERIAL",
|
||||
"SLEEP",
|
||||
"SPI",
|
||||
|
|
@ -8256,6 +8257,7 @@
|
|||
"PORTINOUT",
|
||||
"PORTOUT",
|
||||
"PWMOUT",
|
||||
"RESET_REASON",
|
||||
"SERIAL",
|
||||
"SPI",
|
||||
"I2C",
|
||||
|
|
|
|||
Loading…
Reference in New Issue