The DWMMC controller internally divided clock by values in CLKSEL registers, so we must adjust MMC clock for that. Added a divide function to stdlib.h which should be useful in other contexts. BUG=none TEST=emerge-peach_pit chromeos-coreboot-peach_pit # and boots successfully. Change-Id: I44f55b634cfc6fd81d76631595b6928c862a219f Signed-off-by: Hung-Te Lin <hungte@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/66657 Commit-Queue: Ronald G. Minnich <rminnich@chromium.org> Reviewed-by: Ronald G. Minnich <rminnich@chromium.org> Tested-by: Ronald G. Minnich <rminnich@chromium.org> Reviewed-by: David Hendricks <dhendrix@chromium.org>
31 lines
796 B
C
31 lines
796 B
C
#ifndef STDLIB_H
|
|
#define STDLIB_H
|
|
|
|
#include <stddef.h>
|
|
|
|
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
|
|
|
|
#define ALIGN(x,a) __ALIGN_MASK(x,(typeof(x))(a)-1UL)
|
|
#define __ALIGN_MASK(x,mask) (((x)+(mask))&~(mask))
|
|
#define ALIGN_UP(x,a) ALIGN((x),(a))
|
|
#define ALIGN_DOWN(x,a) ((x) & ~((typeof(x))(a)-1UL))
|
|
|
|
#define MIN(a,b) ((a) < (b) ? (a) : (b))
|
|
#define MAX(a,b) ((a) > (b) ? (a) : (b))
|
|
|
|
#if !defined(__PRE_RAM__)
|
|
void *memalign(size_t boundary, size_t size);
|
|
void *malloc(size_t size);
|
|
/* We never free memory */
|
|
static inline void free(void *ptr) {}
|
|
#endif
|
|
|
|
/* not sure romcc will know how to handle this. */
|
|
#ifndef __ROMCC__
|
|
static inline unsigned long div_round_up(unsigned int n, unsigned int d)
|
|
{
|
|
return (n + d - 1) / d;
|
|
}
|
|
#endif
|
|
|
|
#endif /* STDLIB_H */
|