LLVM backend for 6502
Go to file
Evan Cheng c60e76d139 - Fix codegen for pc relative constant (e.g. JT) in thumb mode:
.set PCRELV0, (LJTI1_0_0-(LPCRELL0+4))
LPCRELL0:
        add r1, pc, #PCRELV0
This is not legal since add r1, pc, #c requires the constant be a multiple of 4.
Do the following instead:
        .set PCRELV0, (LJTI1_0_0-(LPCRELL0+4))
LPCRELL0:
        mov r1, #PCRELV0
        add r1, pc

- In thumb mode, it's not possible to use .set generate a pc relative stub
  address. The stub is ARM code which is in a different section from the thumb
  code. Load the value from a constpool instead.
- Some asm printing clean up.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33664 91177308-0d34-0410-b5e6-96231b3b80d8
2007-01-30 20:37:08 +00:00
autoconf Fix the TARGET_HAS_JIT settings. Sparc doesn't, x86_64 does, ARM doesn't. 2007-01-21 06:41:11 +00:00
docs Grammar fix 2007-01-28 15:27:21 +00:00
examples Fix a #include to resolve IntegerType class. 2007-01-19 22:45:50 +00:00
include For PR1136: Rename GlobalVariable::isExternal as isDeclaration to avoid 2007-01-30 20:08:39 +00:00
lib - Fix codegen for pc relative constant (e.g. JT) in thumb mode: 2007-01-30 20:37:08 +00:00
projects remove obsolete comment 2007-01-17 05:26:57 +00:00
runtime the old trace values pass has been removed, remove its runtime library. 2007-01-07 18:13:48 +00:00
test For PR411: 2007-01-30 16:16:01 +00:00
tools For PR1136: Rename GlobalVariable::isExternal as isDeclaration to avoid 2007-01-30 20:08:39 +00:00
utils Make the constant honest. 2007-01-26 23:00:54 +00:00
win32 Unbreak VC++ build. 2007-01-15 20:27:18 +00:00
Xcode Update project 2007-01-29 18:45:08 +00:00
.cvsignore
configure Regenerate. 2007-01-21 06:42:03 +00:00
CREDITS.TXT Testing commit, and adding an entry to CREDITS.TXT 2007-01-08 03:10:00 +00:00
LICENSE.TXT Welcome 2007. 2007-01-18 21:22:36 +00:00
llvm.spec.in
Makefile
Makefile.common
Makefile.config.in For PR739: 2007-01-17 20:24:45 +00:00
Makefile.rules Work around broken binutils on alpha 2007-01-26 13:34:50 +00:00
README.txt

Low Level Virtual Machine (LLVM)
================================

This directory and its subdirectories contain source code for the Low Level 
Virtual Machine, a toolkit for the construction of highly optimized compilers,
optimizers, and runtime environments. 

LLVM is open source software. You may freely distribute it under the terms of
the license agreement found in LICENSE.txt.

Please see the HTML documentation provided in docs/index.html for further
assistance with LLVM.