<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>S32K中的主题 NXP: S32k144: LPUART: RX upon interrupt does not work</title>
    <link>https://community.nxp.com/t5/S32K/NXP-S32k144-LPUART-RX-upon-interrupt-does-not-work/m-p/1190638#M9037</link>
    <description>&lt;PRE&gt;&lt;FONT size="2"&gt;Hello NXP,&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;I am having an issue with LPUART Rx via interrupt,&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;BR /&gt;I have used following code using the macros from library header file s32K144.h,&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;BR /&gt;The Tx works perfectly fine, But Rx is recieved with garbage. There is an obeservation &lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;that RDRF bit gets disables before we read DATA register. I am not sure how this is related to&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;my issue but It seems incorrect for me though(as per RM Page 1707).&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;Please let help me in debugging the issue...&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/************CODE STARTS HERE**********************/&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Global static character */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;uint8 static u8TxChar&amp;nbsp;= 0u;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;uint8 static u8RxChar&amp;nbsp;= 0u;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;void LPUART1_Init(void)&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;DISABLE_INTERRUPTS();&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Step 1 : Enable Clock : 8Mhz Clk Init is used from the example project*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;PCC-&amp;gt;PCCn[PCC_LPUART1_INDEX] &amp;amp;= ~PCC_PCCn_CGC_MASK; /* Ensure clk disabled for config */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;PCC-&amp;gt;PCCn[PCC_LPUART1_INDEX] |= PCC_PCCn_PCS(0b010) /* Clock src=2 (SIRCDIV2_CLK) */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;| PCC_PCCn_CGC_MASK; /* Enable clock for LPUART1 regs */&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Step 2 Initialize the Baud and CTRL, with SBR 0x11, and OSR 0x03000011&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;Tx Enable Rx Enable, RIE Enable*/&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; BAUD = 0x03000011; /* 115200 Baud rate */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; CTRL = 0x002C0000;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Initialize interrupt */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;S32_NVIC-&amp;gt;ICPR[1u] = 1 &amp;lt;&amp;lt; (LPUART1_RxTx_IRQn % 32); /* IRQ99 - FTM1 ch0,1: clear any pending IRQ*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;S32_NVIC-&amp;gt;ISER[1u] = 1 &amp;lt;&amp;lt; (LPUART1_RxTx_IRQn % 32); /* IRQ99 - FTM1 ch0,1: enable IRQ */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;S32_NVIC-&amp;gt;IP[LPUART1_RxTx_IRQn] = 0x00; /* IRQ99 - FTM1 ch0,1: priority 0 of 0-15*/&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;ENABLE_INTERRUPTS();&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;void LPUART1_TxChar(sint8 u8Char)&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;u8TxChar = u8Char;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; CTRL |= LPUART_CTRL_TIE(1u);&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;void LPUART1_RxTx_IRQHandler(void)&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Tx Data */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;if( TRUE == (((LPAURT1 -&amp;gt; STAT) &amp;amp; LPUART_STAT_TC_MASK ) &amp;gt;&amp;gt; LPUART_STAT_TC_SHIFT) )&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Write into the Data register*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPUART1 -&amp;gt; DATA = u8TxChar;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Disable interrupt*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; CTRL &amp;amp;= ~LPUART_CTRL_TIE_MASK;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Rx Data */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;if(TRUE == (((LPAURT1 -&amp;gt; STAT) &amp;amp; LPUART_STAT_RDRF_MASK ) &amp;gt;&amp;gt; LPUART_STAT_RDRF_SHIFT ))&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Write into the Data register*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;u8RxChar = LPUART1 -&amp;gt; DATA ;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/*****************CODE ENDS HERE***************************/&lt;/FONT&gt;&lt;/PRE&gt;</description>
    <pubDate>Mon, 30 Nov 2020 05:38:16 GMT</pubDate>
    <dc:creator>ArSa</dc:creator>
    <dc:date>2020-11-30T05:38:16Z</dc:date>
    <item>
      <title>NXP: S32k144: LPUART: RX upon interrupt does not work</title>
      <link>https://community.nxp.com/t5/S32K/NXP-S32k144-LPUART-RX-upon-interrupt-does-not-work/m-p/1190638#M9037</link>
      <description>&lt;PRE&gt;&lt;FONT size="2"&gt;Hello NXP,&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;I am having an issue with LPUART Rx via interrupt,&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;BR /&gt;I have used following code using the macros from library header file s32K144.h,&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;BR /&gt;The Tx works perfectly fine, But Rx is recieved with garbage. There is an obeservation &lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;that RDRF bit gets disables before we read DATA register. I am not sure how this is related to&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;my issue but It seems incorrect for me though(as per RM Page 1707).&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;Please let help me in debugging the issue...&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/************CODE STARTS HERE**********************/&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Global static character */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;uint8 static u8TxChar&amp;nbsp;= 0u;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;uint8 static u8RxChar&amp;nbsp;= 0u;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;void LPUART1_Init(void)&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;DISABLE_INTERRUPTS();&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Step 1 : Enable Clock : 8Mhz Clk Init is used from the example project*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;PCC-&amp;gt;PCCn[PCC_LPUART1_INDEX] &amp;amp;= ~PCC_PCCn_CGC_MASK; /* Ensure clk disabled for config */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;PCC-&amp;gt;PCCn[PCC_LPUART1_INDEX] |= PCC_PCCn_PCS(0b010) /* Clock src=2 (SIRCDIV2_CLK) */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;| PCC_PCCn_CGC_MASK; /* Enable clock for LPUART1 regs */&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Step 2 Initialize the Baud and CTRL, with SBR 0x11, and OSR 0x03000011&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;Tx Enable Rx Enable, RIE Enable*/&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; BAUD = 0x03000011; /* 115200 Baud rate */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; CTRL = 0x002C0000;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Initialize interrupt */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;S32_NVIC-&amp;gt;ICPR[1u] = 1 &amp;lt;&amp;lt; (LPUART1_RxTx_IRQn % 32); /* IRQ99 - FTM1 ch0,1: clear any pending IRQ*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;S32_NVIC-&amp;gt;ISER[1u] = 1 &amp;lt;&amp;lt; (LPUART1_RxTx_IRQn % 32); /* IRQ99 - FTM1 ch0,1: enable IRQ */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;S32_NVIC-&amp;gt;IP[LPUART1_RxTx_IRQn] = 0x00; /* IRQ99 - FTM1 ch0,1: priority 0 of 0-15*/&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;ENABLE_INTERRUPTS();&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;void LPUART1_TxChar(sint8 u8Char)&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;u8TxChar = u8Char;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; CTRL |= LPUART_CTRL_TIE(1u);&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;void LPUART1_RxTx_IRQHandler(void)&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Tx Data */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;if( TRUE == (((LPAURT1 -&amp;gt; STAT) &amp;amp; LPUART_STAT_TC_MASK ) &amp;gt;&amp;gt; LPUART_STAT_TC_SHIFT) )&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Write into the Data register*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPUART1 -&amp;gt; DATA = u8TxChar;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Disable interrupt*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;LPAURT1 -&amp;gt; CTRL &amp;amp;= ~LPUART_CTRL_TIE_MASK;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Rx Data */&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;if(TRUE == (((LPAURT1 -&amp;gt; STAT) &amp;amp; LPUART_STAT_RDRF_MASK ) &amp;gt;&amp;gt; LPUART_STAT_RDRF_SHIFT ))&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;{&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/* Write into the Data register*/&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;u8RxChar = LPUART1 -&amp;gt; DATA ;&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;}&lt;/FONT&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;/*****************CODE ENDS HERE***************************/&lt;/FONT&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 30 Nov 2020 05:38:16 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32K/NXP-S32k144-LPUART-RX-upon-interrupt-does-not-work/m-p/1190638#M9037</guid>
      <dc:creator>ArSa</dc:creator>
      <dc:date>2020-11-30T05:38:16Z</dc:date>
    </item>
    <item>
      <title>Re: NXP: S32k144: LPUART: RX upon interrupt does not work</title>
      <link>https://community.nxp.com/t5/S32K/NXP-S32k144-LPUART-RX-upon-interrupt-does-not-work/m-p/1191160#M9056</link>
      <description>&lt;P&gt;Hi FrustatedEngineer,&lt;/P&gt;
&lt;P&gt;Please refer the &lt;A href="https://community.nxp.com/t5/S32K-Knowledge-Base/Example-S32K144-LPUART-RXEDGIF-VLPS/ta-p/1183234" target="_self"&gt;Example S32K144 LPUART RXEDGIF VLPS&lt;/A&gt;.&lt;BR /&gt;Hope it helps!&lt;/P&gt;
&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Example_S32K144_LPUART_RXEDGIF_VLPS.png" style="width: 999px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/131376i7C08050E81828F2E/image-size/large?v=v2&amp;amp;px=999" role="button" title="Example_S32K144_LPUART_RXEDGIF_VLPS.png" alt="Example_S32K144_LPUART_RXEDGIF_VLPS.png" /&gt;&lt;/span&gt;&lt;/P&gt;
&lt;P&gt;Best Regards,&lt;BR /&gt;Robin&lt;BR /&gt;-------------------------------------------------------------------------------&lt;BR /&gt;Note:&lt;BR /&gt;- If this post answers your question, please click the "Mark Correct" button. Thank you!&lt;/P&gt;
&lt;P&gt;- We are following threads for 7 weeks after the last post, later replies are ignored&lt;BR /&gt;Please open a new thread and refer to the closed one, if you have a related question at a later point in time.&lt;BR /&gt;-------------------------------------------------------------------------------&lt;/P&gt;</description>
      <pubDate>Tue, 01 Dec 2020 01:02:46 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32K/NXP-S32k144-LPUART-RX-upon-interrupt-does-not-work/m-p/1191160#M9056</guid>
      <dc:creator>Robin_Shen</dc:creator>
      <dc:date>2020-12-01T01:02:46Z</dc:date>
    </item>
  </channel>
</rss>

