<?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: Configure lcd controller into 8080 mode in i.MX Processors</title>
    <link>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844658#M129462</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Could anyone offer some help ? thanks a lot.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 07 Dec 2018 05:14:59 GMT</pubDate>
    <dc:creator>alvenwu</dc:creator>
    <dc:date>2018-12-07T05:14:59Z</dc:date>
    <item>
      <title>Configure lcd controller into 8080 mode</title>
      <link>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844656#M129460</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;nbsp;I am using the i.MX 6ULL Applications Processor, seems on this chip , we don't need to use the flexbus to communicate with the oled controller. and we can just configure LCD controller into 8080 to control the SSD1322 controller.&lt;/P&gt;&lt;P&gt;Here is my configuration:&amp;nbsp;&lt;/P&gt;&lt;P&gt;1. Enable the pix-clock bit in CCM regiseter and reset the clock&lt;/P&gt;&lt;DIV&gt;static void Oled_ControllerReset(void)&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; volatile uint32_t i = 0x100;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Disable the clock gate. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL_CLR = LCDIF_CTRL_CLKGATE_MASK;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Confirm the clock gate is disabled. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (gsOledReg-&amp;gt;CTRL &amp;amp; LCDIF_CTRL_CLKGATE_MASK);&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Reset the block. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL_SET = LCDIF_CTRL_SFTRST_MASK;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Confirm the reset bit is set. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (!(gsOledReg-&amp;gt;CTRL &amp;amp; LCDIF_CTRL_SFTRST_MASK));&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Delay for the reset. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (i--);&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Bring the module out of reset. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL_CLR = LCDIF_CTRL_SFTRST_MASK;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Disable the clock gate. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL_CLR = LCDIF_CTRL_CLKGATE_MASK;&lt;BR /&gt;}&lt;/DIV&gt;&lt;DIV&gt; &lt;/DIV&gt;&lt;P&gt;2. Configure the LCD ctrl register&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp;/* CTRL DATA SELECT CONFIG*/&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* CTRL READ_WRITE SELECT */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* CTRL BYPASS COUNT SELECT */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* CTRL BUSY PIN DISABLE*/&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL = (LCDIF_CTRL_READ_WRITEB(0)) | (LCDIF_CTRL_BYPASS_COUNT(0))&lt;BR /&gt;&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; |(LCDIF_CTRL_DATA_SELECT(0)) | (LCDIF_CTRL_LCD_DATABUS_WIDTH(0x1U))&lt;BR /&gt;&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; |(LCDIF_CTRL_WORD_LENGTH(0x1U)) | (LCDIF_CTRL_MASTER(0x1U))&lt;BR /&gt;&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; | (LCDIF_CTRL_RUN_MASK);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* CTRL1 8080 MODE SELECT */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL1_CLR = LCDIF_CTRL1_MODE86_MASK;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; /* LCD TIMING REGISTER CONFIG*/&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; gsOledReg-&amp;gt;TIMING = LCDIF_TIMING_DATA_SETUP(0x1U) | LCDIF_TIMING_DATA_HOLD(0x1U)&lt;BR /&gt;&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; | LCDIF_TIMING_CMD_SETUP(0x1U) | LCDIF_TIMING_CMD_HOLD(0x1U);&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;3. write data function:&amp;nbsp;&lt;/P&gt;&lt;DIV&gt;void Oled_WriteData(uint8_t data)&lt;BR /&gt;{ &amp;nbsp; &amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*output cs signal*/&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; GPIO_WritePinOutput(OLED_CS_GPIO_PORT, OLED_CS_GPIO_PIN, kGPIO_Low);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;CTRL_SET = LCDIF_CTRL_DATA_SELECT_MASK;&lt;/DIV&gt;&lt;DIV&gt; &lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*send data to LCDIF_DATA register*/&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; gsOledReg-&amp;gt;DATA = LCDIF_DATA_DATA_ZERO(data);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp; &amp;nbsp;&amp;nbsp; /*output cs signal*/&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; GPIO_WritePinOutput(OLED_CS_GPIO_PORT, OLED_CS_GPIO_PIN, kGPIO_High); &amp;nbsp; &amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;}&lt;/DIV&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;However , could anyone check if it is correct? &amp;nbsp;&lt;/P&gt;&lt;P&gt;And I am rather confusing about the description on reference manual. Do we need to set "run" bit and "master" bit in&amp;nbsp; 8080 mode ? &amp;nbsp; &amp;nbsp; what about set the DATA_SHIFT_DIR and SHIFT_NUM_BITS ??&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 06 Dec 2018 23:37:13 GMT</pubDate>
      <guid>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844656#M129460</guid>
      <dc:creator>alvenwu</dc:creator>
      <dc:date>2018-12-06T23:37:13Z</dc:date>
    </item>
    <item>
      <title>Re: Configure lcd controller into 8080 mode</title>
      <link>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844657#M129461</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Could anyone give me any suggestion ? &amp;nbsp;&lt;/P&gt;&lt;P&gt;how to configure the display clock?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Dec 2018 02:41:01 GMT</pubDate>
      <guid>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844657#M129461</guid>
      <dc:creator>alvenwu</dc:creator>
      <dc:date>2018-12-07T02:41:01Z</dc:date>
    </item>
    <item>
      <title>Re: Configure lcd controller into 8080 mode</title>
      <link>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844658#M129462</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Could anyone offer some help ? thanks a lot.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Dec 2018 05:14:59 GMT</pubDate>
      <guid>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844658#M129462</guid>
      <dc:creator>alvenwu</dc:creator>
      <dc:date>2018-12-07T05:14:59Z</dc:date>
    </item>
    <item>
      <title>Re: Configure lcd controller into 8080 mode</title>
      <link>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844659#M129463</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;A href="https://community.nxp.com/docs/DOC-331754"&gt;https://community.nxp.com/docs/DOC-331754&lt;/A&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Hope this can help you.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 17 Dec 2018 07:35:37 GMT</pubDate>
      <guid>https://community.nxp.com/t5/i-MX-Processors/Configure-lcd-controller-into-8080-mode/m-p/844659#M129463</guid>
      <dc:creator>jimmychan</dc:creator>
      <dc:date>2018-12-17T07:35:37Z</dc:date>
    </item>
  </channel>
</rss>

