<div dir="ltr">Sorry, Neglect the question.<div style>i am using a readl() which reads 4 bytes at a time. In the last iteration, it is trying to read next 4 unmapped locations.</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">

On Thu, Feb 28, 2013 at 4:06 PM, sandeep kumar <span dir="ltr">&lt;<a href="mailto:coolsandyforyou@gmail.com" target="_blank">coolsandyforyou@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

<div dir="ltr"><br clear="all"><div>Hi All</div><div>Please find a piece of code that i wrote in my driver,</div><div><div> </div><div><font face="courier new, monospace">void __iomem *tcpm_base = ioremap_nocache(0x03900000, SZ_16KB);</font></div>


<div><font face="courier new, monospace">            printk(&quot;Virtual addresss %x\n&quot;,tcpm_base);</font></div><div><font face="courier new, monospace">            if(tcpm_base!=NULL)</font></div><div><font face="courier new, monospace">            {</font></div>


<div><font face="courier new, monospace">            printk(&quot;Jiffies %x %ld\n\n\n\n&quot;, jiffies, jiffies);</font></div><div><font face="courier new, monospace">            for(i=0;i&lt;(SZ_16KB-1);i++)</font></div>


<div><font face="courier new, monospace">            src = readl(tcpm_base+i);</font></div><div><font face="courier new, monospace">            printk(&quot;%d\n&quot;,src);</font></div><div><font face="courier new, monospace">            printk(&quot;Jiffies %x %ld\n\n\n\n&quot;, jiffies, jiffies);</font></div>


<div><font face="courier new, monospace">            }</font></div><div><font face="courier new, monospace">            else</font></div><div><font face="courier new, monospace">                printk(&quot;unable to map \n&quot;);</font></div>


<div><br></div><div><br></div><div>When i execute this code, i am seeing a kernel panic telling</div><div>----- LOG --------</div><div><div><font face="verdana, sans-serif">&quot;Virtual addresss ea880000&quot;</font></div>


<div><font face="verdana, sans-serif">&quot;Unable to handle kernel paging request at virtual address ea890000&quot;</font><br></div><div><font face="verdana, sans-serif">-----LOG-----</font></div><div><font face="verdana, sans-serif"><br>


</font></div><div>If you observe,</div><div>virtual address of  <span style="font-family:&#39;courier new&#39;,monospace">tcpm_base is </span><span style="font-family:verdana,sans-serif">ea880000.</span></div>
<div><span style="font-family:verdana,sans-serif">if ioremap() returns all contigious memory, There should be no dereferencing of &quot;</span><span style="font-family:verdana,sans-serif">ea890000&quot;(the max address should be ea88fffe)</span></div>


<div><span style="font-family:verdana,sans-serif"><br></span></div><div><span style="font-family:verdana,sans-serif">But in kernel logs show, it is dereferencing that address.</span></div><div><span style="font-family:verdana,sans-serif"><br>


</span></div><div><span style="font-family:verdana,sans-serif">My question now is...</span></div><div><span style="font-family:verdana,sans-serif">doesn&#39;t ioremap() returns contigious address space?</span></div>
<div><br></div><div><br></div></div></div>With regards,<br>Sandeep Kumar Anantapalli,<br>
</div>
</blockquote></div><br><br clear="all"><div><br></div>-- <br>With regards,<br>Sandeep Kumar Anantapalli,<br>
</div>