2014-02-20 11:27:26 +01:00
|
|
|
/*
|
|
|
|
* \brief Constants definitions for the ARM architecture.
|
|
|
|
* \author Sebastian Sumpf
|
|
|
|
* \date 2014-02-20
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2011-2017 Genode Labs GmbH
|
2014-02-20 11:27:26 +01:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 13:23:52 +01:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2014-02-20 11:27:26 +01:00
|
|
|
*/
|
|
|
|
|
2015-09-03 14:55:05 +02:00
|
|
|
#ifndef _INCLUDE__SPEC__ARM__CPU__CONSTS_H_
|
|
|
|
#define _INCLUDE__SPEC__ARM__CPU__CONSTS_H_
|
2014-02-20 11:27:26 +01:00
|
|
|
|
|
|
|
#include <base/stdint.h>
|
|
|
|
|
|
|
|
namespace Abi {
|
2014-02-21 10:59:39 +01:00
|
|
|
|
2016-01-15 15:48:20 +01:00
|
|
|
/*
|
|
|
|
* On ARM we align the stack top to 16-byte. As a call (or branch) will not
|
|
|
|
* change the stack pointer, we need no further stack adjustment.
|
2014-02-20 11:27:26 +01:00
|
|
|
*/
|
2016-04-21 09:10:44 +02:00
|
|
|
inline Genode::addr_t stack_align(Genode::addr_t addr) {
|
2016-01-15 15:48:20 +01:00
|
|
|
return (addr & ~0xf); }
|
2014-02-21 10:59:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Do ABI specific initialization to a freshly created stack
|
|
|
|
*/
|
|
|
|
inline void init_stack(Genode::addr_t) { }
|
2014-02-20 11:27:26 +01:00
|
|
|
}
|
|
|
|
|
2015-09-03 14:55:05 +02:00
|
|
|
#endif /* _INCLUDE__SPEC__ARM__CPU__CONSTS_H_ */
|