• Jens Wiklander's avatar
    tee: simplify shm pool handling · d88e0493
    Jens Wiklander authored
    Replaces the shared memory pool based on two pools with a single pool.
    The alloc() function pointer in struct tee_shm_pool_ops gets another
    parameter, align. This makes it possible to make less than page aligned
    allocations from the optional reserved shared memory pool while still
    making user space allocations page aligned. With in practice unchanged
    behaviour using only a single pool for bookkeeping.
    
    The allocation algorithm in the static OP-TEE shared memory pool is
    changed from best-fit to first-fit since only the latter supports an
    alignment parameter. The best-fit algorithm was previously the default
    choice and not a conscious one.
    
    The optee and amdtee drivers are updated as needed to work with this
    changed pool handling.
    
    This also removes OPTEE_SHM_NUM_PRIV_PAGES which becomes obsolete with
    this change as the private pages can be mixed with the payload pages.
    
    The OP-TEE driver changes minimum alignment for argument struct from 8
    bytes to 512 bytes. A typical OP-TEE private shm allocation is 224 bytes
    (argument struct with 6 parameters, needed for open session). So with an
    alignment of 512 well waste a bit more than 50%. Before this we had a
    single page reserved for this so worst case usage compared to that would
    be 3 pages instead of 1 page. However, this worst case only occurs if
    there is a high pressure from multiple threads on secure world. All in
    all this should scale up and down better than fixed boundaries.
    Reviewed-by: default avatarSumit Garg <sumit.garg@linaro.org>
    Signed-off-by: default avatarJens Wiklander <jens.wiklander@linaro.org>
    d88e0493
Kconfig 251 Bytes