Skip to content

Commit

Permalink
riscv_pmp.c: Revert LOG2_CEIL back to run-time log2ceil function
Browse files Browse the repository at this point in the history
The macro LOG2_CEIL is intended to be used in the pre-processor phase. If
used run-time it will generate a massive amount of extra code (~3.5K) which
is a problem, as the PMP configuration is quite often executed from a first
stage bootloader with a limited amount of code memory.

Code size differences pre- and post:

Memory region         Used Size  Region Size  %age Used
            envm:      112064 B     112384 B     99.72%

Memory region         Used Size  Region Size  %age Used
            envm:      108952 B     112384 B     96.95%
  • Loading branch information
pussuw committed Dec 13, 2023
1 parent 8e170d2 commit f41bf81
Showing 1 changed file with 27 additions and 2 deletions.
29 changes: 27 additions & 2 deletions arch/risc-v/src/common/riscv_pmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@
#include <nuttx/compiler.h>
#include <nuttx/arch.h>
#include <nuttx/irq.h>
#include <nuttx/lib/math32.h>

#include "riscv_internal.h"

Expand Down Expand Up @@ -89,6 +88,32 @@ typedef struct pmp_entry_s pmp_entry_t;
* Private Functions
****************************************************************************/

/****************************************************************************
* Name: log2ceil
*
* Description:
* Calculate the up-rounded power-of-two for input.
*
* Input Parameters:
* x - Argument to calculate the power-of-two from.
*
* Returned Value:
* Power-of-two for argument, rounded up.
*
****************************************************************************/

static uintptr_t log2ceil(uintptr_t x)
{
uintptr_t pot = 0;

for (x = x - 1; x; x >>= 1)
{
pot++;
}

return pot;
}

/****************************************************************************
* Name: pmp_check_region_attrs
*
Expand Down Expand Up @@ -143,7 +168,7 @@ static bool pmp_check_region_attrs(uintptr_t base, uintptr_t size,

/* Get the power-of-two for size, rounded up */

if ((base & ((UINT64_C(1) << LOG2_CEIL(size)) - 1)) != 0)
if ((base & ((UINT64_C(1) << log2ceil(size)) - 1)) != 0)
{
/* The start address is not properly aligned with size */

Expand Down

0 comments on commit f41bf81

Please sign in to comment.