<?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>ColdFire/68K Microcontrollers and ProcessorsのトピックA problem with mcf52235 UART interruption.Please help me.</title>
    <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/A-problem-with-mcf52235-UART-interruption-Please-help-me/m-p/144975#M3024</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN style="color: #6633FF;"&gt;I am using a PCB made by myself.I initialize UART0 correctly.It transmit and receive well if i don't use interruption.I want to use interruption to receive data from computer.But no interruption is generated.I wrote my codes like this.Only critical parts is written .I think most registers must be initiated correctly or it can not work.&lt;/SPAN&gt;&lt;SPAN style="color: #6633FF;"&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #6633FF;"&gt;Could someone give me a hint?I really appreciate your help.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;(CodeWarrior v6.4)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;mcf5xxx_vectors.c&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;........&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;.extern _IntUART0m //Simply add a '_' before function name????&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;........&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;vector077:&amp;nbsp;&amp;nbsp;&amp;nbsp; .long&amp;nbsp;&amp;nbsp;&amp;nbsp; _IntUART0m&amp;nbsp;&amp;nbsp; /* UART0 */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;........&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;int_handler.c&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;__declspec(interrupt)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;void IntUART0m(void)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; printf("03. UART interrupt entered! \n\r"); /* The charactors can be displayed in the console window */&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;int_init()&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_IMRL &amp;amp;= ~(0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; | MCF_INTC_IMRL_INT_MASK13 | MCF_INTC_IMRL_INT_MASK14 | MCF_INTC_IMRL_INT_MASK15&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; | MCF_INTC_IMRL_MASKALL);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_ICR13 = 0b00011011; //UART0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_ICR14 = 0b00011011;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_ICR15 = 0b00011011; //level and priority&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;uart_init() //UCSR and UIMR&lt;/SPAN&gt;&lt;SPAN&gt; &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_UART_UCSR(0) = (0|MCF_UART_UCSR_RCS_SYS_CLK | MCF_UART_UCSR_TCS_SYS_CLK);&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_UART_UIMR(0) = (0 | MCF_UART_UISR_TXRDY |MCF_UART_UISR_FFULL_RXRDY );&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;main() // config SR at the beginning of main()&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; asm&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; move.l&amp;nbsp; 0x2000,D0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; move.w&amp;nbsp; D0,SR&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/SPAN&gt;&lt;BR /&gt;&lt;DIV&gt; &lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 12 Sep 2007 20:26:18 GMT</pubDate>
    <dc:creator>karonarthur</dc:creator>
    <dc:date>2007-09-12T20:26:18Z</dc:date>
    <item>
      <title>A problem with mcf52235 UART interruption.Please help me.</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/A-problem-with-mcf52235-UART-interruption-Please-help-me/m-p/144975#M3024</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN style="color: #6633FF;"&gt;I am using a PCB made by myself.I initialize UART0 correctly.It transmit and receive well if i don't use interruption.I want to use interruption to receive data from computer.But no interruption is generated.I wrote my codes like this.Only critical parts is written .I think most registers must be initiated correctly or it can not work.&lt;/SPAN&gt;&lt;SPAN style="color: #6633FF;"&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #6633FF;"&gt;Could someone give me a hint?I really appreciate your help.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;(CodeWarrior v6.4)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;mcf5xxx_vectors.c&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;........&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;.extern _IntUART0m //Simply add a '_' before function name????&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;........&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;vector077:&amp;nbsp;&amp;nbsp;&amp;nbsp; .long&amp;nbsp;&amp;nbsp;&amp;nbsp; _IntUART0m&amp;nbsp;&amp;nbsp; /* UART0 */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;........&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;int_handler.c&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;__declspec(interrupt)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;void IntUART0m(void)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; printf("03. UART interrupt entered! \n\r"); /* The charactors can be displayed in the console window */&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;int_init()&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_IMRL &amp;amp;= ~(0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; | MCF_INTC_IMRL_INT_MASK13 | MCF_INTC_IMRL_INT_MASK14 | MCF_INTC_IMRL_INT_MASK15&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; | MCF_INTC_IMRL_MASKALL);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_ICR13 = 0b00011011; //UART0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_ICR14 = 0b00011011;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_INTC0_ICR15 = 0b00011011; //level and priority&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;uart_init() //UCSR and UIMR&lt;/SPAN&gt;&lt;SPAN&gt; &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_UART_UCSR(0) = (0|MCF_UART_UCSR_RCS_SYS_CLK | MCF_UART_UCSR_TCS_SYS_CLK);&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp; MCF_UART_UIMR(0) = (0 | MCF_UART_UISR_TXRDY |MCF_UART_UISR_FFULL_RXRDY );&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN style="color: #6633FF;"&gt;main() // config SR at the beginning of main()&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; asm&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; move.l&amp;nbsp; 0x2000,D0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; move.w&amp;nbsp; D0,SR&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/SPAN&gt;&lt;BR /&gt;&lt;DIV&gt; &lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 12 Sep 2007 20:26:18 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/A-problem-with-mcf52235-UART-interruption-Please-help-me/m-p/144975#M3024</guid>
      <dc:creator>karonarthur</dc:creator>
      <dc:date>2007-09-12T20:26:18Z</dc:date>
    </item>
    <item>
      <title>Re: A problem with mcf52235 UART interruption.Please help me.</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/A-problem-with-mcf52235-UART-interruption-Please-help-me/m-p/144976#M3025</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;Hi&lt;BR /&gt;&lt;BR /&gt;One small point is that you should never use the same interrupt level and priority for multiple interrupt sources - therefore you should set different values for UART0,UART1 and UART2. This would however not stop interrupts working as far as I known.&lt;BR /&gt;&lt;BR /&gt;The initialisation of the interrupts looks correct, assuming mcf5xxx_vectors.c is really being used by your project (see&lt;BR /&gt;&lt;A href="http://forums.freescale.com/freescale/board/message?board.id=CWCFCOMM&amp;amp;thread.id=1501)" target="test_blank"&gt;http://forums.freescale.com/freescale/board/message?board.id=CWCFCOMM&amp;amp;thread.id=1501)&lt;/A&gt;.&lt;BR /&gt;&lt;BR /&gt;What is not visible in the code snippets is where the RX in enabled. When the TX is enabled you would normally immediately get an interrupt due to the fact that the tx bufer is emply (since you are setting interrupts on TXRDY).&lt;BR /&gt;&lt;BR /&gt;The best way to find out what is happening is to monitor the interrupt flags in the UART status register. If the interrupt is getting set, then check whether it is propogating through to the interrupt controller (where you can check that the corresponding mask has really been removed).&lt;BR /&gt;&lt;BR /&gt;If you don't make any progress, look at the uTasker project at &lt;A href="http://www.uTasker.com" rel="nofollow" target="_blank"&gt;www.uTasker.com&lt;/A&gt; (users' forum at &lt;A href="http://www.uTasker.com/forum/%20" rel="nofollow" target="_blank"&gt;&lt;/A&gt;&lt;A href="http://www.uTasker.com/forum/" target="test_blank"&gt;http://www.uTasker.com/forum/&lt;/A&gt; )&lt;BR /&gt;The project contains support of UART in interrupt and DMA modes as well as lots more too. It is possible to simulate the operation of the UARTs (including their interrupts and interrupt routines) and map the simulated UARTs to COM ports on the PC to test a complete project on a simulated M5223X.&lt;BR /&gt;&lt;BR /&gt;Good luck&lt;BR /&gt;&lt;BR /&gt;Regards&lt;BR /&gt;&lt;BR /&gt;Mark&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;DIV&gt;&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 13 Sep 2007 19:29:05 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/A-problem-with-mcf52235-UART-interruption-Please-help-me/m-p/144976#M3025</guid>
      <dc:creator>mjbcswitzerland</dc:creator>
      <dc:date>2007-09-13T19:29:05Z</dc:date>
    </item>
  </channel>
</rss>

