Comments (2)
Unless you have a strong reason to use the "riscv-next" branch, I'd recommend using the "riscv-binutils-2.28" branch. That is based on the stable binutils 2.28 release branch, which is a bit more suitable for distributions. We maintain this branch with all the RISC-V patches that make sense (which we also submit upstream once they're ready). There's a similar release branch for GCC, and there will be one for Linux and glibc once they've released upstream.
I'm going to leave this open, as it's probably a real bug.
from riscv-binutils-gdb.
Reproduced, and verified that this is fixed by issue #84. So closing.
There is a misunderstanding here about address sizes. Dwarf makes a distinction between program addresses whose size is determined by the ABI, and dwarf internal references, which are section relative offsets, fixed in size at 32-bits or 64-bits. GCC emits 32-bit dwarf for all targets except IBM AIX which chose to standardize on 64-bit dwarf for 64-bit ABIs. There is no need to move from 32-bit dwarf to 64-bti dwarf unless you have a single dwarf section which exceeds 4GB in size. Since dwarf is split across multiple sections, you would need about 8GB of dwarf info total before 64-bit dwarf becomes necessary.
Also, since 64-bit dwarf is larger than 32-bit dwarf, it should not be used unless you actually require it. So, since we have 32-bit dwarf here with a lp64 ABI, it is still only a 32-bit reloc fix that we need, which is what is in issue #84.
This does bring up an interesting point though. If a new reloc had to be added to the ABI to make 32-bit dwarf work correctly, then we probably need a new reloc to make 64-bit dwarf work correctly too. We may want to fix the ABI long before we actually need 64-bit dwarf. So this should be checked, but this should be a different issue that the one reported here.
from riscv-binutils-gdb.
Related Issues (20)
- How gdb register csr HOT 2
- riscv64 gdb doesn't recognize riscv32 symbol tables: "Sorry, Dave" HOT 1
- GDB internal error HOT 1
- About the opcode constraints documentation. HOT 3
- What is the expected behavior upon hitting a EBREAK? HOT 3
- riscv-binutils-2.35-rvb: `_`instead of `.` ? HOT 2
- How to add a new custom instruction? HOT 6
- riscv-binutils-2.35-rvb: wrong match for xperm.h HOT 2
- a tricky one about gdb HOT 5
- Overlappings on the operand name for p ext
- Registers are interpreted as 64-bit when architecture is set to rv32 HOT 2
- ld: cannot find default versions of the ISA extension `i', when linking rv32e HOT 5
- GDB build fails on CentOS 7.9.2009 HOT 1
- Is there a way to let gdbserver instruct gdb client to use compressed breakpoints? HOT 2
- objdump cant correctly dissemble instructions that reuse other's encoding
- right way to compress branching instuction (decbnez from ZCE extension)
- Objdump and auipc: the immediate value should be displayed shifted HOT 2
- Does anyone know the status about zfh support of binutils? HOT 5
- GDB Single Step fails on RISCV, EL2 with ICCM HOT 1
- continue function not working??? HOT 10
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-binutils-gdb.