AP_HAL_Linux: Raspberry 64OS Address fix
This commit is contained in:
parent
5a429a9a79
commit
feece150c6
@ -167,6 +167,7 @@ Memory_table::Memory_table(uint32_t page_count, int version)
|
|||||||
|
|
||||||
if ((fdMem = open("/dev/mem", O_RDWR | O_SYNC | O_CLOEXEC)) < 0) {
|
if ((fdMem = open("/dev/mem", O_RDWR | O_SYNC | O_CLOEXEC)) < 0) {
|
||||||
fprintf(stderr, "Failed to open /dev/mem\n");
|
fprintf(stderr, "Failed to open /dev/mem\n");
|
||||||
|
printf("Make sure that CONFIG_STRICT_DEVMEM is disabled\n");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -192,7 +193,7 @@ Memory_table::Memory_table(uint32_t page_count, int version)
|
|||||||
// Map physical addresses to virtual memory
|
// Map physical addresses to virtual memory
|
||||||
for (i = 0; i < _page_count; i++) {
|
for (i = 0; i < _page_count; i++) {
|
||||||
munmap(_virt_pages[i], PAGE_SIZE);
|
munmap(_virt_pages[i], PAGE_SIZE);
|
||||||
_virt_pages[i] = mmap(_virt_pages[i], PAGE_SIZE, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_FIXED | MAP_NORESERVE | MAP_LOCKED, fdMem, ((uintptr_t)_phys_pages[i] & (version == 1 ? 0xFFFFFFFF : ~bus)));
|
_virt_pages[i] = mmap(_virt_pages[i], PAGE_SIZE, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_FIXED | MAP_NORESERVE | MAP_LOCKED, fdMem, ((uintptr_t)_phys_pages[i] & (version == 1 ? 0xFFFFFFFFFFFFFFFF : ~bus)));
|
||||||
memset(_virt_pages[i], 0xee, PAGE_SIZE);
|
memset(_virt_pages[i], 0xee, PAGE_SIZE);
|
||||||
}
|
}
|
||||||
close(file);
|
close(file);
|
||||||
@ -232,11 +233,11 @@ void *Memory_table::get_virt_addr(const uint32_t phys_addr) const
|
|||||||
|
|
||||||
// This function returns offset from the beginning of the buffer using virtual
|
// This function returns offset from the beginning of the buffer using virtual
|
||||||
// address and memory_table.
|
// address and memory_table.
|
||||||
uint32_t Memory_table::get_offset(void ** const pages, const uint32_t addr) const
|
uint32_t Memory_table::get_offset(void ** const pages, const uint64_t addr) const
|
||||||
{
|
{
|
||||||
uint32_t i = 0;
|
uint32_t i = 0;
|
||||||
for (; i < _page_count; i++) {
|
for (; i < _page_count; i++) {
|
||||||
if ((uintptr_t) pages[i] == (addr & 0xFFFFF000) ) {
|
if ((uintptr_t) pages[i] == (addr & 0xFFFFFFFFFFFFF000) ) {
|
||||||
return (i*PAGE_SIZE + (addr & 0xFFF));
|
return (i*PAGE_SIZE + (addr & 0xFFF));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -286,6 +287,7 @@ void *RCInput_RPI::map_peripheral(uint32_t base, uint32_t len)
|
|||||||
|
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
printf("Failed to open /dev/mem: %m\n");
|
printf("Failed to open /dev/mem: %m\n");
|
||||||
|
printf("Make sure that CONFIG_STRICT_DEVMEM is disabled\n");
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
vaddr = mmap(nullptr, len, PROT_READ | PROT_WRITE, MAP_SHARED, fd, base);
|
vaddr = mmap(nullptr, len, PROT_READ | PROT_WRITE, MAP_SHARED, fd, base);
|
||||||
|
@ -71,7 +71,7 @@ public:
|
|||||||
void* get_page(void **pages, const uint32_t addr) const;
|
void* get_page(void **pages, const uint32_t addr) const;
|
||||||
|
|
||||||
// This function returns offset from the beginning of the buffer using (virtual) address in 'pages' and memory_table.
|
// This function returns offset from the beginning of the buffer using (virtual) address in 'pages' and memory_table.
|
||||||
uint32_t get_offset(void **pages, const uint32_t addr) const;
|
uint32_t get_offset(void **pages, const uint64_t addr) const;
|
||||||
|
|
||||||
//How many bytes are available for reading in circle buffer?
|
//How many bytes are available for reading in circle buffer?
|
||||||
uint32_t bytes_available(const uint32_t read_addr, const uint32_t write_addr) const;
|
uint32_t bytes_available(const uint32_t read_addr, const uint32_t write_addr) const;
|
||||||
|
Loading…
Reference in New Issue
Block a user