<?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>LPC MicrocontrollersのトピックLPC4350 - DAC problem</title>
    <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556496#M15178</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by Antony on Fri Oct 05 07:15:54 MST 2012&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Hi,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I have some problem with DAC.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;After configuring using driver lpc43xx_dac and selecting analog function in ENAIO2 the E3 pin (analog pin ADC0_0/ADC1_0/DAC in LPC4350FET256) remains stable and have 3.0V voltage level.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;How do I configure DAC (from lpc43xx_dac driver):&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;/* Set default clock divider for DAC */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;CGU_EntityConnect(CGU_CLKSRC_PLL1, CGU_BASE_APB3);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;//Set maximum current output&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;DAC_SetBias(LPC_DAC,DAC_MAX_CURRENT_700uA);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;//Select pin function - DAC&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;p-&amp;gt;ENAIO2 |= (1&amp;lt;&amp;lt;(0));// At that stage pin E3 goes to 3.0V&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;After configuring I am trying to set some voltages on the DAC output, but the voltage remains the same (3.0V).&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;tmp = DACx-&amp;gt;CR &amp;amp; DAC_BIAS_EN;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;tmp |= DAC_VALUE(dac_value);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;// Update value&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;DACx-&amp;gt;CR = tmp;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Looks like I have missed something.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Also looks like I stuck:)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I will kindly appreciate any help.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Thanks in advance.&lt;/SPAN&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 15 Jun 2016 18:41:42 GMT</pubDate>
    <dc:creator>lpcware</dc:creator>
    <dc:date>2016-06-15T18:41:42Z</dc:date>
    <item>
      <title>LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556496#M15178</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by Antony on Fri Oct 05 07:15:54 MST 2012&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Hi,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I have some problem with DAC.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;After configuring using driver lpc43xx_dac and selecting analog function in ENAIO2 the E3 pin (analog pin ADC0_0/ADC1_0/DAC in LPC4350FET256) remains stable and have 3.0V voltage level.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;How do I configure DAC (from lpc43xx_dac driver):&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;/* Set default clock divider for DAC */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;CGU_EntityConnect(CGU_CLKSRC_PLL1, CGU_BASE_APB3);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;//Set maximum current output&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;DAC_SetBias(LPC_DAC,DAC_MAX_CURRENT_700uA);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;//Select pin function - DAC&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;p-&amp;gt;ENAIO2 |= (1&amp;lt;&amp;lt;(0));// At that stage pin E3 goes to 3.0V&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;After configuring I am trying to set some voltages on the DAC output, but the voltage remains the same (3.0V).&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;tmp = DACx-&amp;gt;CR &amp;amp; DAC_BIAS_EN;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;tmp |= DAC_VALUE(dac_value);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;// Update value&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;DACx-&amp;gt;CR = tmp;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Looks like I have missed something.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Also looks like I stuck:)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I will kindly appreciate any help.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Thanks in advance.&lt;/SPAN&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:42 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556496#M15178</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:42Z</dc:date>
    </item>
    <item>
      <title>Re: LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556497#M15179</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by NXP_Paul on Fri Oct 05 14:39:18 MST 2012&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Antony&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&lt;SPAN&gt;Have you fully configured the pin to function as a DAC?&amp;nbsp; Here's an example taken from the LPC18xx example code (available at &lt;/SPAN&gt;&lt;A class="jive-link-external-small" href="https://community.nxp.com/external-link.jspa?url=http%3A%2F%2Fwww.lpcware.com%2Fgfiles%2Fdevper%2Flpc18xx" rel="nofollow" target="_blank"&gt;http://www.lpcware.com/gfiles/devper/lpc18xx&lt;/A&gt;&lt;SPAN&gt;) to configure P4_4 as a DAC.&amp;nbsp; I tested it on a Hitex evaluation board and it works as expected.&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;scu_pinmux(0x4 ,4 , MD_PLN, FUNC8);&amp;nbsp; // DAC is function 8&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;GPIO_SetDir(0x4, 4, 0);// input mode&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_SCU-&amp;gt;ENAIO2 |= 1;// Enable analog function&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;DAC_Init(LPC_DAC);&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Regards&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;NXP Technical Support&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:43 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556497#M15179</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:43Z</dc:date>
    </item>
    <item>
      <title>Re: LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556498#M15180</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by capiman on Sun Oct 07 12:00:23 MST 2012&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;@pboogaards&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Is it correct, that you use FUNC8?&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;scu_pinmux(0x4 ,4 , MD_PLN, FUNC8); // DAC is function 8&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I find only FUNC0 to FUNC7, no FUNC8 and according to user manual UM10503 page 292 (Rev 1.4 from Sep 2012)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;the bit field MODE goes only from bit 0 to 2 and function 0 to 7?&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Perhaps this is different in LPC18xx compared to LPC43xx?&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Best regards,&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp; Martin&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:44 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556498#M15180</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:44Z</dc:date>
    </item>
    <item>
      <title>Re: LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556499#M15181</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by DF9DQ on Sun Oct 07 15:13:00 MST 2012&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Hi Martin,&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I'm sure that's a typo. It's the ninth entry in a list where your choice is one out of eight. Correct is FUNC0, as that is the GPIO function, which you should make an input. As a matter of fact, the selection in the MODE field is only secondary. The choice for DAC in the ENAIO2 multiplex register gives DAC precedence over the digital function selected via MODE.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;However, that fight is a sideshow...&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;The original question wasn't for P4_4, to which those settings apply! Antony rather uses the ADC0_0/ADC1_0/DAC signal (pin E3 of the LBGA256 package). For that pure analog pin the settings of the P4_4 config register and the ENAIO2 multiplexer are completely irrelevant. Pin ADC0_0/ADC1_0/DAC will always show the DAC output as soon as the DAC is enabled.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;The missing point is probably the DMA_ENA bit in the DAC CTRL register. Despite its name this bit must be set to get a DAC output, whether you use DMA or not.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Regards,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Rolf&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Edit: I should have mentioned that the existing library requires you to call DAC_ConfigDAConverterControl() in addition to DAC_Init() for the DAC to operate.&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:44 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556499#M15181</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:44Z</dc:date>
    </item>
    <item>
      <title>Re: LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556500#M15182</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by Antony on Mon Oct 08 02:55:28 MST 2012&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Hi DF9DQ,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Thanks a lot for such detailed explanation and your help.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;It works now, after setting DMA_ENA bit.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Thanks you one more time.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Your help is invaluable.&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:45 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556500#M15182</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:45Z</dc:date>
    </item>
    <item>
      <title>Re: LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556501#M15183</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by adi nata on Fri May 02 07:22:58 MST 2014&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;thanks for the information&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;but for newbie like me, it takes hours to understand...&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;let make it easier&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;SystemInit();&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;CGU_Init();&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;scu_pinmux(0x4 ,4 , MD_PLN, 0); // set pin configuration register&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;GPIO_SetDir(0x4, 4, 0); // set GPIO port direction register&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_SCU-&amp;gt;ENAIO2 |= 1; // set analog function select register&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;DAC_Init(LPC_DAC);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_DAC-&amp;gt;CTRL |= DAC_DMA_ENA;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;int32_t iLop;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;while(1)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;for (iLop = 0; iLop &amp;lt; 1023; iLop++)DAC_UpdateValue(LPC_DAC, iLop);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;for (iLop = 1023; iLop &amp;gt; 0; iLop--)DAC_UpdateValue(LPC_DAC, iLop);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:46 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556501#M15183</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:46Z</dc:date>
    </item>
    <item>
      <title>Re: LPC4350 - DAC problem</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556502#M15184</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by briching on Fri Dec 04 14:24:51 MST 2015&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Many thanks for all this good information that was mysteriously absent from the user manual.&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:41:46 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/LPC4350-DAC-problem/m-p/556502#M15184</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:41:46Z</dc:date>
    </item>
  </channel>
</rss>

