こんにちは、友人の皆さん。私は MKE06Z128VQH4 マイクロコントローラを使用して設計したボードを持っており、その中でいくつかの出力と入力を使用しています。私は KBI 入力を 1 つ、タイマーを 3 つ、カウンターを 1 つ使用しています。SO、問題はありません。すでに設定を行っており、動作しています。
現在、UART0 シリアル ポートに取り組んでおり、USB-TTL シリアル アダプターを PC に接続してデータを受信または送信しています。SDKs ライブラリを使用して情報を送受信することができませんでした。MCUXpresso を使用した私の構成は画像のとおりです。
ピン:
時計には外部水晶12MHZがあります。
FLL にエラーがあるため、FEE オプションをCANません。FBELP を使用して設定を行っています。
UART0 では、割り込み受信および送信ポーリングを使用して構成を行っています。
インストールされている SDK は次のとおりです。
サンプルの SDK があります:
これらの例を使用しても、UART0 を動作させることができません。何らかのガイダンスが必要です。UART0 を動作させるために数日間試行しています。
こんにちは@Iotelctronic
デモ版は変更せずにそのままご利用ください。
私の側でテストしましたが、問題は見つかりませんでした
BR
アリス
こんにちは、アリス!ポーリングを使用してデモでテストしましたが、機能しません。
codigo main.c:
#include "pin_mux.h"
#include "board.h"
#include "fsl_uart.h"
/*******************************************************************************
* Definitions
******************************************************************************/
/* UART instance and clock */
#define DEMO_UART UART1
#define DEMO_UART_CLK_FREQ CLOCK_GetFreq(kCLOCK_BusClk)
/*******************************************************************************
* Prototypes
******************************************************************************/
/*******************************************************************************
* Variables
******************************************************************************/
uint8_t txbuff[] = "Uart polling example\r\nBoard will send back received characters\r\n";
uint8_t rxbuff[20] = {0};
/*******************************************************************************
* Code
******************************************************************************/
/*!
* @brief Main function
*/
int main(void)
{
uint8_t ch;
uart_config_t config;
BOARD_InitBootPins();
BOARD_InitBootClocks();
config.baudRate_Bps = 115200U;
config.parityMode = kUART_ParityDisabled;
config.stopBitCount = kUART_OneStopBit;
//config.txFifoWatermark = 0;
//config.rxFifoWatermark = 1;
config.enableTx = false;
config.enableRx = false;
// UART_GetDefaultConfig(&config);
// config.baudRate_Bps = BOARD_DEBUG_UART_BAUDRATE;
// config.enableTx = true;
//config.enableRx = true;
UART_Init(DEMO_UART, &config, DEMO_UART_CLK_FREQ);
UART_WriteBlocking(DEMO_UART, txbuff, sizeof(txbuff) - 1);
while (1)
{
UART_ReadBlocking(DEMO_UART, &ch, 1);
UART_WriteBlocking(DEMO_UART, &ch, 1);
}
}こんにちは@Iotelctronic
1) クロックに関しては、12 MHz 水晶が正常に機能しているかどうかを確認し、構成を確認してください。
2) KE06 は DMA をサポートしていません。
よろしくお願いします。
BR
アリス
こんにちは。問題を見つけました。レジスターを使用していた SDK の例やその他のプロジェクトは機能せず、常に間違ったデータと間違った文字が送信されました。私は外部の 12 MHz 水晶を使用していますが、その水晶では正確に 115200 のボー レートを生成できません。ただし、 12 MHz 水晶をはんだ付けせずに構成を 8 MHz に変更すると、正常に動作します。私の大きな疑問は、構成を 8 MHz に変更しても 12 MHz の水晶を変更しないとなぜ機能するのかということです。私が示しているコードは.freqで行った変更です= 8000000U。これについて説明はありますか?また、MKE06Z128VQH4 マイクロコントローラには UART で使用するための DMA があるかどうかもお聞きしたいです。
/***********************************************************************************************************************
* This file was generated by the MCUXpresso Config Tools. Any manual edits made to this file
* will be overwritten if the respective MCUXpresso Config Tools is used to update this file.
**********************************************************************************************************************/
/*
* How to setup clock using clock driver functions:
*
* 1. call CLOCK_SetSimSafeDivs() to set the system clock dividers in SIM to safe value.
*
* 2. If external oscillator is used Call CLOCK_SetXtal0Freq() to set XTAL0 frequency based on board settings and
* call CLOCK_InitOsc0() to init the OSC.
*
* 3. Call CLOCK_BootToXxxMode()/CLOCK_SetXxxMode() to set ICS run at the target mode.
*
* 4. If ICSIRCLK is needed, call CLOCK_SetInternalRefClkConfig() to enable the clock.
*
* 5. call CLOCK_SetSimConfig() to configure the divider in sim.
*/
/* clang-format off */
/* TEXT BELOW IS USED AS SETTING FOR TOOLS *************************************
!!GlobalInfo
product: Clocks v7.0
processor: MKE06Z128xxx4
package_id: MKE06Z128VLK4
mcu_data: ksdk2_0
processor_version: 9.0.0
* BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/
/* clang-format on */
#include "clock_config.h"
/*******************************************************************************
* Definitions
******************************************************************************/
/*******************************************************************************
* Variables
******************************************************************************/
/* System clock frequency. */
extern uint32_t SystemCoreClock;
/*******************************************************************************
************************ BOARD_InitBootClocks function ************************
******************************************************************************/
void BOARD_InitBootClocks(void)
{
BOARD_BootClockRUN();
}
/*******************************************************************************
********************** Configuration BOARD_BootClockRUN ***********************
******************************************************************************/
/* clang-format off */
/* TEXT BELOW IS USED AS SETTING FOR TOOLS *************************************
!!Configuration
name: BOARD_BootClockRUN
called_from_default_init: true
outputs:
- {id: Bus_clock.outFreq, value: 20 MHz}
- {id: Core_clock.outFreq, value: 40 MHz}
- {id: Flash_clock.outFreq, value: 20 MHz}
- {id: ICSFF_clock.outFreq, value: 31.25 kHz}
- {id: ICSIR_clock.outFreq, value: 37.5 kHz}
- {id: LPO_clock.outFreq, value: 1 kHz}
- {id: OSCER_clock.outFreq, value: 8 MHz}
- {id: Plat_clock.outFreq, value: 40 MHz}
- {id: System_clock.outFreq, value: 40 MHz}
- {id: Timer_clock.outFreq, value: 20 MHz}
settings:
- {id: ICSMode, value: FEE}
- {id: ICS.BDIV.scale, value: '1', locked: true}
- {id: ICS.IREFS.sel, value: ICS.RDIV}
- {id: ICS.RDIV.scale, value: '256'}
- {id: ICS_C1_IRCLKEN_CFG, value: Enabled}
- {id: OSC_CR_OSCEN_CFG, value: Enabled}
- {id: OSC_CR_OSC_MODE_CFG, value: ModeOscLowPower}
- {id: OSC_CR_RANGE_CFG, value: High}
- {id: OSC_CR_RANGE_RDIV_CFG, value: High}
- {id: SIM.DIV2.scale, value: '2'}
- {id: SIM.DIV3.scale, value: '2', locked: true}
sources:
- {id: OSC.OSC.outFreq, value: 8 MHz, enabled: true}
* BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/
/* clang-format on */
/*******************************************************************************
* Variables for BOARD_BootClockRUN configuration
******************************************************************************/
const ics_config_t icsConfig_BOARD_BootClockRUN =
{
.icsMode = kICS_ModeFEE, /* FEE - FLL Engaged External */
.irClkEnableMode = kICS_IrclkEnable, /* ICSIRCLK enabled, ICSIRCLK disabled in STOP mode */
.bDiv = 0x0U, /* Bus clock divider: divided by 1 */
.rDiv = 0x3U, /* FLL external reference clock divider: divided by 256 */
};
const sim_clock_config_t simConfig_BOARD_BootClockRUN =
{
.outDiv1 = 0x0U, /* DIV1 clock divider: divided by 1 */
.outDiv2 = 0x1U, /* DIV2 clock divider: divided by 2 */
.outDiv3 = 0x1U, /* DIV3 clock divider: divided by 2 */
.busClkPrescaler = 0x0U, /* bus clock optional prescaler */
};
const osc_config_t oscConfig_BOARD_BootClockRUN =
{
.freq = 8000000U, /* Oscillator frequency: 12000000Hz */
.workMode = kOSC_ModeOscLowPower, /* Oscillator low power */
.enableMode = kOSC_Enable, /* Enable external reference clock, disable external reference clock in STOP mode */
};
/*******************************************************************************
* Code for BOARD_BootClockRUN configuration
******************************************************************************/
void BOARD_BootClockRUN(void)
{
/* Set the system clock dividers in SIM to safe value. */
CLOCK_SetSimSafeDivs();
/* Initializes OSC0 according to board configuration. */
CLOCK_InitOsc0(&oscConfig_BOARD_BootClockRUN);
CLOCK_SetXtal0Freq(oscConfig_BOARD_BootClockRUN.freq);
/* Set ICS to FEE mode. */
CLOCK_BootToFeeMode(icsConfig_BOARD_BootClockRUN.bDiv,
icsConfig_BOARD_BootClockRUN.rDiv);
/* Configure the Internal Reference clock (ICSIRCLK). */
CLOCK_SetInternalRefClkConfig(icsConfig_BOARD_BootClockRUN.irClkEnableMode);
/* Set the clock configuration in SIM module. */
CLOCK_SetSimConfig(&simConfig_BOARD_BootClockRUN);
/* Set SystemCoreClock variable. */
SystemCoreClock = BOARD_BOOTCLOCKRUN_CORE_CLOCK;
}ありがとう、クロックの問題は水晶のはんだが12MHZではなく8MHZであることです