Age | Commit message (Collapse) | Author |
|
- Add support for architecure sections that can be handled by the
architecture back end.
- Add trampoline/fixup support for PowerPC. This means the PowerPC
now supports large memory loading of applications.
- Add a bit allocator to manage small block based regions of memory.
- Add small data (sdata/sbss) support for the PowerPC. The support
makes the linker allocated small data region of memory a global
resource available to libdl loaded object files.
Updates #3687
Updates #3685
|
|
- Add trampolines to support relocs that are out of range on
support architectures.
- Support not loading separate text/data sections in an object
file if the symbol provided in the section is a duplicate.
A base image may have pulled in part of an object and another
part needs to be dynamically loaded.
- Refactor the unresolved handling to scale to hundreds of
unresolved symbols when loading large number of files.
Updates #3685
|
|
- Trampolines or fixups for veneers provide long jump support
for instruciton sets that implement short relative address
branches. The linker provides trampolines when creating a
static image. This patch adds trampoline support to libdl
and the ARM architecture.
- The dl09 test requires enough memory so modules are outside
the relative branch instruction ranges for the architecture.
Updates #3685
|
|
- Fix the handling of pending objects.
- Add a constructor flags in objects to track then being called.
Closes #2921
|
|
- Create 2 archives.
- Load 1 object file which loads 6 object files from the libraries.
Updates #3686
|
|
Updates #3686
|
|
Updates #3686
|
|
- Load archive symbol tables to support searching of archives
for symbols.
- Search archive symbols and load the object file that contains
the symbol.
- Search the global and archives until all remaining unresolved symbols
are not found. Group the loaded object files in the pending queue.
- Run the object file and loaded dependents as a group before adding to the
main object list.
- Remove orphaned object files after references are removed.
Updates #3686
|
|
This allows test dl09 to run and test PowePC backend trampoline support.
Updates #3685
|
|
Closes #3298
|
|
Closes #3684
|
|
|
|
Update #3665.
|
|
Add low level event recording infrastructure for system and user
defined events. The infrastructure is able to record high frequency
events such as
* SMP lock acquire/release,
* interrupt entry/exit,
* thread switches,
* UMA zone allocate/free, and
* Ethernet packet input/output, etc.
It allows post-mortem analysis in fatal error handlers, e.g. the last
events are in the record buffer, the newest event overwrites the oldest
event. It is possible to detect record buffer overflows for consumers
that expect a continuous stream of events, e.g. to display the system
state in real-time.
The implementation supports high-end SMP machines (more than 1GHz
processor frequency, more than four processors).
Add a new API instead. The implementation uses per-processor data
structures and no atomic read-modify-write operations. It is uses
per-processor ring buffers to record the events.
The CPU counter is used to get the time of events. It is combined with
periodic uptime events to synchronize it with CLOCK_REALTIME.
The existing capture engine tries to solve this problem also, but its
performance is not good enough for high-end production systems. The
main issues are the variable-size buffers and the use of SMP locks for
synchronization. To fix this, the API would change significantly.
Update #3665.
|
|
This prevents a cyclic dependency between <rtems/score/cpu.h> and
<rtems/score/address.h>.
|
|
This avoids link-time failures on some low memory BSPs.
|
|
Update #3384.
|
|
|
|
We have to be careful with instructions which operate explicitly on
words or doublewords.
Update #3082.
|
|
|
|
Update #3678.
|
|
Update #3678.
|
|
Update #3678.
|
|
Update #3678.
|
|
Update #3678.
|
|
Update #3678.
|
|
Update #3678.
|
|
Update #3459.
|
|
|
|
Ensure that interrupts are disabled while acquiring an ISR lock.
|
|
|
|
The CPU_ALIGNMENT must not be zero, this is also checked via a static
assertion. Fix formatting.
|
|
|
|
|
|
|
|
|
|
|
|
Update #3666.
|
|
|
|
Do not rely on compiler optimizations to throw away empty loops.
Close #3673.
|
|
Update #3667.
Close #3674.
|
|
Update #3667.
|
|
It must be enabled, since the context switch code does not save/restore
the interrupt status.
Update #3433.
|
|
In case the robust thread dispatch is enabled by the CPU port, then the
interrupt level must not be changed through the task mode.
Update #3000.
|
|
Update #3000.
|
|
Update #3000.
|
|
It is unnecessary to run these test cases with interrupts disabled.
|
|
|
|
|
|
|