mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-12 16:02:57 +00:00
66fbea127b
The following fixes partly solve the problems triggered by the noux stress test introduced by nfeske in issue #208. * The check whether a capability exists in the Cap_map, and its insertion, has to be done atomically * While removing a capability it is looked up in the Cap_map via its id, check whether the found capability pointer is the same like the looked up, otherwise the wrong capability gets freed * When a local capability is un- resp. marshalled, only the local pointer gets transfered, not the redundant capability id * Introduce several assertions and warnings to facilitate debugging
38 lines
819 B
C++
38 lines
819 B
C++
/*
|
|
* \brief Assertion macros for Fiasco.OC
|
|
* \author Stefan Kalkowski
|
|
* \date 2012-05-25
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2006-2012 Genode Labs GmbH
|
|
*
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
* under the terms of the GNU General Public License version 2.
|
|
*/
|
|
|
|
#ifndef _INCLUDE__UTIL__ASSERT_H_
|
|
#define _INCLUDE__UTIL__ASSERT_H_
|
|
|
|
#include <base/printf.h>
|
|
|
|
namespace Fiasco {
|
|
#include <l4/sys/kdebug.h>
|
|
}
|
|
|
|
#if 1
|
|
#define ASSERT(e, s) \
|
|
do { if (!(e)) { \
|
|
Fiasco::outstring(ESC_ERR s ESC_END "\n"); \
|
|
Fiasco::outstring(__FILE__ ":"); \
|
|
Fiasco::outhex32((int)__LINE__); \
|
|
Fiasco::outstring("\n"); \
|
|
enter_kdebug("ASSERT"); \
|
|
} \
|
|
} while(0)
|
|
#else
|
|
#define ASSERT(e, s) do { } while (0)
|
|
#endif
|
|
|
|
#endif /* _INCLUDE__UTIL__ASSERT_H_ */
|