Comments (3)
Thanks for going through the documentation, it's great to make sure the LLVM and GCC stuff match before people start really using our stuff. Looks like we're 64-bit aligned for uint64_t on rv32g. @sorear, can you document it?
palmer gamma02 ~ $ cat doublealign.c
#include <stdint.h>
struct aligntest {
uint32_t a;
uint64_t b;
uint32_t c;
};
void func(void *);
extern struct aligntest aligntest;
int main() {
func(&aligntest.a);
func(&aligntest.b);
func(&aligntest.c);
return 0;
};
palmer gamma02 ~ $ riscv64-unknown-linux-gnu-gcc doublealign.c -march=rv32g -mabi=ilp32 -O3 -S -o -
.file "doublealign.c"
.option nopic
.section .text.startup,"ax",@progbits
.align 2
.globl main
.type main, @function
main:
lui a0,%hi(aligntest)
add sp,sp,-16
add a0,a0,%lo(aligntest)
sw ra,12(sp)
call func
lui a0,%hi(aligntest+8)
add a0,a0,%lo(aligntest+8)
call func
lui a0,%hi(aligntest+16)
add a0,a0,%lo(aligntest+16)
call func
lw ra,12(sp)
li a0,0
add sp,sp,16
jr ra
.size main, .-main
.ident "GCC: (GNU) 6.1.0"
from riscv-elf-psabi-doc.
Thanks Palmer, it was actually double fp I was referring to, though I would guess these are 64-bit aligned on RV32 as well (can't ssh into my machine with riscv-gcc to verify right now).
from riscv-elf-psabi-doc.
doubles would definitely want to be 64-bit aligned, since there's a fld instruction even on RV32D.
from riscv-elf-psabi-doc.
Related Issues (20)
- Specify relocation overflow checks HOT 1
- Specify a platform reserved register HOT 20
- Should calling convention also define ptrdiff_t? HOT 1
- Should we use lw/sw in push pop when we used ILP32, whether it's RV32 or RV64 HOT 3
- Operation semantics of __bf16 datatype HOT 2
- representation of GNU C fixed-size vectors HOT 4
- Deprecate R_RISCV_RVC_LUI? HOT 4
- Define GOT-Relative data relocation HOT 8
- Embedding R_RISCV_RELAX to another relocations HOT 7
- Define gp(x3) as global VLENB HOT 4
- Bitfield integer calling convention garbled
- Calling convention uses RV64GQ without definition or reference HOT 3
- Calling convention description of va_list et al. are unclear HOT 2
- Interpretation of floating-point types
- Linux ABI for Pointer Masking HOT 19
- New ABI for stack layout and frame pointer scheme HOT 4
- Change branch from "master" to "main" HOT 1
- Add CREL support HOT 3
- Add RELR support HOT 6
- Question about medlow's single 2 GiB address range HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from riscv-elf-psabi-doc.