Changeset a1b9f63 in mainline for kernel/generic/src/mm/km.c


Ignore:
Timestamp:
2018-08-31T10:32:40Z (7 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
6bf5b8c
Parents:
b1834a01
git-author:
Jakub Jermar <jakub@…> (2018-08-31 09:54:11)
git-committer:
Jakub Jermar <jakub@…> (2018-08-31 10:32:40)
Message:

Add alignment argument to km_map()

km_map() currently always applies alignment requirement equal to the
size of the mapped region. Most of the time, the natural alignment is
unnecessarily strong and especially on 32-bit systems may contribute to
km_map() failures for regions with size in the order of several hundred
megabytes.

This change adds an extra argument to km_map() which allows the caller
to indicate the desired alignment. The old behaviour can be specified
by passing KM_NATURAL_ALIGNMENT as alignment.

This change only adds the alignment argument, but does not change the
alignment requirement anywhere.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • kernel/generic/src/mm/km.c

    rb1834a01 ra1b9f63  
    130130
    131131static uintptr_t
    132 km_map_aligned(uintptr_t paddr, size_t size, unsigned int flags)
     132km_map_aligned(uintptr_t paddr, size_t size, size_t align, unsigned int flags)
    133133{
    134134        uintptr_t vaddr;
    135         size_t align;
    136135        uintptr_t offs;
     136
     137        if (align == KM_NATURAL_ALIGNMENT)
     138                align = ispwr2(size) ? size : (1U << (fnzb(size) + 1));
    137139
    138140        assert(ALIGN_DOWN(paddr, FRAME_SIZE) == paddr);
    139141        assert(ALIGN_UP(size, FRAME_SIZE) == size);
    140 
    141         /* Enforce natural or at least PAGE_SIZE alignment. */
    142         align = ispwr2(size) ? size : (1U << (fnzb(size) + 1));
     142        assert(ispwr2(align));
     143
     144        /* Enforce at least PAGE_SIZE alignment. */
    143145        vaddr = km_page_alloc(size, max(PAGE_SIZE, align));
    144146
     
    185187 * @return New virtual address mapped to paddr.
    186188 */
    187 uintptr_t km_map(uintptr_t paddr, size_t size, unsigned int flags)
     189uintptr_t km_map(uintptr_t paddr, size_t size, size_t align, unsigned int flags)
    188190{
    189191        uintptr_t page;
     
    192194        offs = paddr - ALIGN_DOWN(paddr, FRAME_SIZE);
    193195        page = km_map_aligned(ALIGN_DOWN(paddr, FRAME_SIZE),
    194             ALIGN_UP(size + offs, FRAME_SIZE), flags);
     196            ALIGN_UP(size + offs, FRAME_SIZE), align, flags);
    195197
    196198        return page + offs;
     
    256258        frame = frame_alloc(1, FRAME_HIGHMEM | FRAME_ATOMIC | flags, 0);
    257259        if (frame) {
    258                 page = km_map(frame, PAGE_SIZE,
     260                page = km_map(frame, PAGE_SIZE, PAGE_SIZE,
    259261                    PAGE_READ | PAGE_WRITE | PAGE_CACHEABLE);
    260262                if (!page) {
Note: See TracChangeset for help on using the changeset viewer.