<html>

<head>
<meta http-equiv=Content-Type content="text/html; charset=us-ascii">
<meta name=Generator content="Microsoft Word 11 (filtered)">
<style>
<!--
 /* Font Definitions */
 @font-face
        {font-family:Tahoma;
        panose-1:2 11 6 4 3 5 4 4 2 4;}
 /* Style Definitions */
 p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman";}
a:link, span.MsoHyperlink
        {color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {color:purple;
        text-decoration:underline;}
span.EmailStyle17
        {font-family:Arial;
        color:navy;}
@page Section1
        {size:8.5in 11.0in;
        margin:1.0in 1.25in 1.0in 1.25in;}
div.Section1
        {page:Section1;}
-->
</style>

</head>

<body lang=EN-US link=blue vlink=purple>

<div class=Section1>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'>Our 8-bit port for PIC16 has taken roughly
about 18 months to get to where we are now. Our instruction set is not
orthogonal, data memory is banked, program memory is paged, there is only one
accumulator and two pointer registers, and the use of indirect memory access is
really expensive. So we had to implement some non conventional approaches to
get the model working.</span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'>For the most part, LLVM generic optimizations
(except for mem2reg kind of optimizations) reduce the code size pretty good and
typical applications that we use for PIC16 fit in the memory without problem. </span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'>We use clang and LLVM just to generate assembly
output. We have our own assembler, linker and debugger. In fact we have to
implement some of our tricks in the linker and assembler in order to allow mix
of C and assembly projects. If your users only want to use C, then you can
probably use a lot more of the analysis capabilities of LLVM than what we use. </span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'>Our ABI and model of code generation is
probably far from what you need, but you may find some tricks in our port that
can be useful to you as well.</span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'> </span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'>Regards</span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'>Ali</span></font></p>

<p class=MsoNormal><font size=2 color=navy face=Arial><span style='font-size:
10.0pt;font-family:Arial;color:navy'> </span></font></p>

<div>

<div class=MsoNormal align=center style='text-align:center'><font size=3
face="Times New Roman"><span style='font-size:12.0pt'>

<hr size=2 width="100%" align=center tabindex=-1>

</span></font></div>

<p class=MsoNormal><b><font size=2 face=Tahoma><span style='font-size:10.0pt;
font-family:Tahoma;font-weight:bold'>From:</span></font></b><font size=2
face=Tahoma><span style='font-size:10.0pt;font-family:Tahoma'>
llvmdev-bounces@cs.uiuc.edu [mailto:llvmdev-bounces@cs.uiuc.edu] <b><span
style='font-weight:bold'>On Behalf Of </span></b>Guillaume Deroire<br>
<b><span style='font-weight:bold'>Sent:</span></b> Monday, November 23, 2009
6:46 AM<br>
<b><span style='font-weight:bold'>To:</span></b> LLVM Developers Mailing List<br>
<b><span style='font-weight:bold'>Subject:</span></b> [LLVMdev] New 8bit micro
controller back-end</span></font></p>

</div>

<p class=MsoNormal><font size=3 face="Times New Roman"><span style='font-size:
12.0pt'> </span></font></p>

<p class=MsoNormal style='margin-bottom:12.0pt'><font size=3
face="Times New Roman"><span style='font-size:12.0pt'>Hi all,<br>
<br>
I'm new to LLVM dev mailling list and I'm starting to discover some aspects of
LLVM.<br>
<br>
Actually I'm looking for a solution to create a tool chain for my own chip (a
8bit micro controller processor) that include a compiler/linker/assembler
toolset and a simulator/debugger.<br>
<br>
>From what I've read, LLVM is a good tool to implement a compiler for this
proprietary platform, but I have the following questions:<br>
- Is there estimation (from your experiences) of the work required to implement
a backend for a simple 8bits micro controller architecture (1 men-month, 10 or
100 ?)<br>
- Is it possible to create a debugger/simulator (at C and assembler level) with
LLVM ?<br>
<br>
Thanks for your help and advices<br>
<br>
Regards<br>
<br>
Guillaume</span></font></p>

</div>

</body>

</html>