2019-11-02 11:52:26 -04:00
|
|
|
/*
|
|
|
|
* This file is part of the MicroPython project, http://micropython.org/
|
|
|
|
*
|
|
|
|
* The MIT License (MIT)
|
|
|
|
*
|
|
|
|
* Copyright (c) 2017 Dan Halbert for Adafruit Industries
|
|
|
|
* Copyright (c) 2019 Artur Pacholec
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
|
|
* in the Software without restriction, including without limitation the rights
|
|
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
* THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <math.h>
|
|
|
|
|
2022-04-14 06:45:16 -04:00
|
|
|
#include "py/runtime.h"
|
|
|
|
|
2019-11-02 11:52:26 -04:00
|
|
|
#include "common-hal/microcontroller/Processor.h"
|
2021-11-12 20:30:24 -05:00
|
|
|
#include "shared-bindings/microcontroller/Processor.h"
|
2020-11-21 23:29:52 -05:00
|
|
|
#include "shared-bindings/microcontroller/ResetReason.h"
|
2019-11-02 11:52:26 -04:00
|
|
|
|
2023-03-23 19:11:00 -04:00
|
|
|
#if CIRCUITPY_ANALOGIO
|
2023-03-21 19:21:57 -04:00
|
|
|
#include "sdk/drivers/tempmon/fsl_tempmon.h"
|
2023-03-23 19:11:00 -04:00
|
|
|
#endif
|
2023-03-21 19:21:57 -04:00
|
|
|
#include "sdk/drivers/ocotp/fsl_ocotp.h"
|
2019-11-02 11:52:26 -04:00
|
|
|
#include "clocks.h"
|
|
|
|
|
|
|
|
float common_hal_mcu_processor_get_temperature(void) {
|
2023-03-23 19:11:00 -04:00
|
|
|
#if CIRCUITPY_ANALOGIO
|
2019-11-02 11:52:26 -04:00
|
|
|
tempmon_config_t config;
|
|
|
|
TEMPMON_GetDefaultConfig(&config);
|
|
|
|
|
2020-05-18 16:29:31 -04:00
|
|
|
OCOTP_Init(OCOTP, CLOCK_GetFreq(kCLOCK_IpgClk));
|
2019-11-02 11:52:26 -04:00
|
|
|
TEMPMON_Init(TEMPMON, &config);
|
|
|
|
TEMPMON_StartMeasure(TEMPMON);
|
|
|
|
|
|
|
|
const float temp = TEMPMON_GetCurrentTemperature(TEMPMON);
|
|
|
|
TEMPMON_Deinit(TEMPMON);
|
2020-05-18 16:29:31 -04:00
|
|
|
OCOTP_Deinit(OCOTP);
|
2019-11-02 11:52:26 -04:00
|
|
|
|
|
|
|
return temp;
|
2023-03-23 19:11:00 -04:00
|
|
|
#else
|
2023-04-28 19:19:43 -04:00
|
|
|
return NAN;
|
2023-03-23 19:11:00 -04:00
|
|
|
#endif
|
2019-11-02 11:52:26 -04:00
|
|
|
}
|
|
|
|
|
2023-01-16 23:39:20 -05:00
|
|
|
void common_hal_mcu_processor_set_frequency(mcu_processor_obj_t *self,
|
2022-04-13 09:47:55 -04:00
|
|
|
uint32_t frequency) {
|
2022-04-17 15:04:16 -04:00
|
|
|
uint32_t freq = frequency / 1000000;
|
|
|
|
if (freq != 24 && freq != 150 && freq != 396 && freq != 450 && freq != 528 && freq != 600 &&
|
|
|
|
freq != 720 && freq != 816 && freq != 912 && freq != 960 && freq != 1008) {
|
|
|
|
mp_raise_ValueError(translate("Frequency must be 24, 150, 396, 450, 528, 600, 720, 816, 912, 960 or 1008 Mhz"));
|
2022-04-16 11:01:50 -04:00
|
|
|
}
|
2022-04-13 12:04:28 -04:00
|
|
|
SystemCoreClock = setarmclock(frequency);
|
2022-04-13 09:47:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-11-02 11:52:26 -04:00
|
|
|
float common_hal_mcu_processor_get_voltage(void) {
|
|
|
|
return NAN;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t common_hal_mcu_processor_get_frequency(void) {
|
|
|
|
return SystemCoreClock;
|
|
|
|
}
|
|
|
|
|
|
|
|
void common_hal_mcu_processor_get_uid(uint8_t raw_id[]) {
|
2023-03-23 19:11:00 -04:00
|
|
|
#if IMXRT11XX
|
|
|
|
OCOTP_Init(OCOTP, CLOCK_GetFreq(kCLOCK_Ocotp));
|
|
|
|
#else
|
2019-11-02 11:52:26 -04:00
|
|
|
OCOTP_Init(OCOTP, CLOCK_GetFreq(kCLOCK_IpgClk));
|
2023-03-23 19:11:00 -04:00
|
|
|
#endif
|
2019-11-02 11:52:26 -04:00
|
|
|
|
|
|
|
// Reads shadow registers 0x01 - 0x04 (Configuration and Manufacturing Info)
|
2020-02-12 17:36:34 -05:00
|
|
|
// into 8 bit wide destination, avoiding punning.
|
2020-02-14 18:02:02 -05:00
|
|
|
for (int i = 0; i < 4; ++i) {
|
|
|
|
uint32_t wr = OCOTP_ReadFuseShadowRegister(OCOTP, i + 1);
|
|
|
|
for (int j = 0; j < 4; j++) {
|
2021-03-15 09:57:36 -04:00
|
|
|
raw_id[i * 4 + j] = wr & 0xff;
|
2020-02-15 19:40:04 -05:00
|
|
|
wr >>= 8;
|
2020-02-14 18:02:02 -05:00
|
|
|
}
|
|
|
|
}
|
2019-11-02 11:52:26 -04:00
|
|
|
OCOTP_Deinit(OCOTP);
|
|
|
|
}
|
2020-11-21 23:29:52 -05:00
|
|
|
|
|
|
|
mcu_reset_reason_t common_hal_mcu_processor_get_reset_reason(void) {
|
2020-12-01 20:01:14 -05:00
|
|
|
return RESET_REASON_UNKNOWN;
|
2022-04-13 12:04:28 -04:00
|
|
|
}
|