1
Fork 0
mirror of git://git.sv.gnu.org/emacs.git synced 2025-12-31 09:20:54 -08:00
emacs/mps/code/event.h
Nick Barnes db4b3a6fa5 Remove trailing whitespace.
Copied from Perforce
 Change: 25309
 ServerID: perforce.ravenbrook.com
2001-12-17 15:18:17 +00:00

115 lines
3 KiB
C

/* impl.h.event -- Event Logging Interface
*
* Copyright (c) 2001 Ravenbrook Limited.
* $Id$
*
* READERSHIP
*
* .readership: MPS developers.
*
* DESIGN
*
* .design: design.mps.telemetry.
*/
#ifndef event_h
#define event_h
#include "eventcom.h"
#include "mpm.h"
extern Res EventSync(void);
extern Res EventInit(void);
extern void EventFinish(void);
extern Word EventControl(Word, Word);
extern Word EventInternString(const char *);
extern Word EventInternGenString(size_t, const char *);
extern void EventLabelAddr(Addr, Word);
#ifdef EVENT
extern Res EventFlush(void);
/* Event Kinds --- see design.mps.telemetry
*
* All events are classified as being of one event type.
* They are small enough to be able to be used as shifts within a word.
*/
#define EventKindArena ((EventKind)0) /* Per space or arena */
#define EventKindPool ((EventKind)1) /* Per pool */
#define EventKindTrace ((EventKind)2) /* Per trace or scan */
#define EventKindSeg ((EventKind)3) /* Per seg */
#define EventKindRef ((EventKind)4) /* Per ref or fix */
#define EventKindObject ((EventKind)5) /* Per alloc or object */
#define EventKindUser ((EventKind)6) /* User-invoked */
#define EventKindNumber ((Count)7) /* Number of event kinds */
/* Event type definitions
*
* Define various constants for each event type to describe them.
*/
/* Note that enum values can be up to fifteen bits long portably. */
#define RELATION(type, code, always, kind, format) \
enum { \
Event##type##High = ((code >> 8) & 0xFF), \
Event##type##Low = (code & 0xFF), \
Event##type##Always = always, \
Event##type##Kind = EventKind##kind, \
Event##type##Format = EventFormat##format \
};
#include "eventdef.h"
#undef RELATION
/* Event writing support */
extern EventUnion EventMould;
extern char *EventNext, *EventLimit;
extern Word EventKindControl;
#define EVENT_BEGIN(type) \
BEGIN \
if(BS_IS_MEMBER(EventKindControl, ((Index)Event##type##Kind))) { \
size_t _length;
#define EVENT_END(type, format, length) \
AVER(EventFormat##format == Event##type##Format); \
/* @@@@ As an interim measure, send the old event codes */ \
EventMould.any.code = Event##type; \
EventMould.any.clock = mps_clock(); \
AVER(EventNext <= EventLimit); \
_length = size_tAlignUp(length, sizeof(Word)); \
if(_length > (size_t)(EventLimit - EventNext)) \
EventFlush(); /* @@@@ should pass length */ \
AVER(_length <= (size_t)(EventLimit - EventNext)); \
mps_lib_memcpy(EventNext, &EventMould, _length); \
EventNext += _length; \
} \
END
#else /* EVENT not */
#define EventInit() NOOP
#define EventFinish() NOOP
#define EventControl(r, f) (UNUSED(r), UNUSED(f), (Word)0)
#define EventInternString(s) (UNUSED(s), (Word)0)
#define EventInternGenString(l, s) (UNUSED(l), UNUSED(s), (Word)0)
#define EventLabelAddr(a, i) BEGIN UNUSED(a); UNUSED(i); END
#endif /* EVENT */
#endif /* event_h */