<?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>topic Re: [S12ZVC] Making PWM with higher resolution in S12 / MagniV Microcontrollers</title>
    <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659949#M13930</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;you can concatenate two 8-bit PWM channels into one 16-bit channel.&lt;/P&gt;&lt;P&gt;Please refer to the description of PWMCTL (specifically: the CONxx fields) in the RM for details.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;HTH,&lt;/P&gt;&lt;P&gt;MJW&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 23 Feb 2017 13:21:43 GMT</pubDate>
    <dc:creator>MJW</dc:creator>
    <dc:date>2017-02-23T13:21:43Z</dc:date>
    <item>
      <title>[S12ZVC] Making PWM with higher resolution</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659948#M13929</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I just wonder&amp;nbsp;how to make&amp;nbsp;PWM signal that much higher than 1/255 resolution.&lt;/P&gt;&lt;P&gt;it is&amp;nbsp;mentioned in the datasheet, PWM duty cycle = [&amp;nbsp;(PWMPER - PWMDTY) / PWMPER ]&amp;nbsp;* 100%&lt;/P&gt;&lt;P&gt;but both of the register value is 8-bits sized, so that the max duty resolution can be 1/255.&lt;/P&gt;&lt;P&gt;I&amp;nbsp;need to control&amp;nbsp;at least 0.1% of duty or more. do you have any idea?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 23 Feb 2017 01:58:48 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659948#M13929</guid>
      <dc:creator>daehyeonkim</dc:creator>
      <dc:date>2017-02-23T01:58:48Z</dc:date>
    </item>
    <item>
      <title>Re: [S12ZVC] Making PWM with higher resolution</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659949#M13930</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;you can concatenate two 8-bit PWM channels into one 16-bit channel.&lt;/P&gt;&lt;P&gt;Please refer to the description of PWMCTL (specifically: the CONxx fields) in the RM for details.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;HTH,&lt;/P&gt;&lt;P&gt;MJW&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 23 Feb 2017 13:21:43 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659949#M13930</guid>
      <dc:creator>MJW</dc:creator>
      <dc:date>2017-02-23T13:21:43Z</dc:date>
    </item>
    <item>
      <title>Re: [S12ZVC] Making PWM with higher resolution</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659950#M13931</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;SPAN&gt;Hi Daehyeon,&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;MJW is right. You should concatenate two 8bit PWM counters into one 16bit.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Example of 16bit PWM initialization: &lt;/SPAN&gt;&lt;/P&gt;&lt;PRE class="language-c line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="comment token"&gt;//==============================================================================&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;// PWM_Init&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;//==============================================================================&lt;/SPAN&gt;
&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;PWM0_Init&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp; &lt;SPAN class="comment token"&gt;//8MHz bus clock&lt;/SPAN&gt;
&amp;nbsp; &lt;SPAN class="comment token"&gt;//for example we want to generate initial PWM wave on PWM01 channel 1kHz with 50% duty cycle&lt;/SPAN&gt;
&amp;nbsp; &lt;SPAN class="comment token"&gt;//two 8bit channels 6 and 7 are concatenated to one 16bit channel&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;
&amp;nbsp; PWM0POL &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0xC0&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;SPAN class="comment token"&gt;//polarity - PWM channel 67 is high at the beginning of period, then low&lt;/SPAN&gt;
&amp;nbsp; PWM0CLK &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0x00&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;SPAN class="comment token"&gt;//select clock source A for channel 6-7&lt;/SPAN&gt;
&amp;nbsp; PWM0PRCLK &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0x01&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp; &lt;SPAN class="comment token"&gt;//prescaler for clock A -&amp;gt; BusClock/2 = 8MHz/2 = 4MHz&lt;/SPAN&gt;
&amp;nbsp; PWM0CAE &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0x00&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;SPAN class="comment token"&gt;//channel 67 operate in left aligned output mode&lt;/SPAN&gt;
&amp;nbsp; PWM0CTL &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0x8C&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;SPAN class="comment token"&gt;//we use 16bit PWM 67, disable clock in wait and freeze mode&lt;/SPAN&gt;
&amp;nbsp; PWM0CNT67 &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0x0000&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&lt;SPAN class="comment token"&gt;//reset the counter of PWM67&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;
&amp;nbsp; PWM0PER67 &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;4000&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp; &lt;SPAN class="comment token"&gt;//PWMPER67 = clock / PWM7frek = 4000000 / 1000 = 4000&lt;/SPAN&gt;
&amp;nbsp; PWM0DTY67 &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; PWMPER67&lt;SPAN class="operator token"&gt;/&lt;/SPAN&gt;&lt;SPAN class="number token"&gt;2&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;SPAN class="comment token"&gt;//ensure duty cycle 50% &lt;/SPAN&gt;
&amp;nbsp; PWM0E &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt;&amp;nbsp; &lt;SPAN class="number token"&gt;0x80&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;SPAN class="comment token"&gt;//enable PWM67&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍&lt;SPAN class="line-numbers-rows"&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Per RM, the S12ZVC contain two 4-channel 16-bit PWM modules - PWM0 gated from bus clock and PWM1 gated from core clock.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;In fact, both modules are 8-channel 8-bit PWM modules, but only odd channels are routed to the external pins. Therefore, we may use only 4 channels from each module configured either as 8bit or 16bit.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I hope it helps you.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Have a great day,&lt;BR /&gt;Radek&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 28 Feb 2017 15:58:26 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12ZVC-Making-PWM-with-higher-resolution/m-p/659950#M13931</guid>
      <dc:creator>RadekS</dc:creator>
      <dc:date>2017-02-28T15:58:26Z</dc:date>
    </item>
  </channel>
</rss>

