move container_of to types.h
The container_of macro is useful as a general solution. It belongs in types.h, rather than target.h where it was introduced. Requires the offsetof macro, which comes from <stddef.h> (moved as well).__archive__
parent
cbc0578372
commit
f0ce88b3af
|
@ -23,6 +23,7 @@
|
||||||
#ifndef TYPES_H
|
#ifndef TYPES_H
|
||||||
#define TYPES_H
|
#define TYPES_H
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
#ifdef HAVE_SYS_TYPES_H
|
#ifdef HAVE_SYS_TYPES_H
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -58,6 +59,20 @@ typedef bool _Bool;
|
||||||
#define stringify(s) __stringify(s)
|
#define stringify(s) __stringify(s)
|
||||||
#define __stringify(s) #s
|
#define __stringify(s) #s
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cast a member of a structure out to the containing structure.
|
||||||
|
* @param ptr The pointer to the member.
|
||||||
|
* @param type The type of the container struct this is embedded in.
|
||||||
|
* @param member The name of the member within the struct.
|
||||||
|
*
|
||||||
|
* This is a mechanism which is used throughout the Linux kernel.
|
||||||
|
*/
|
||||||
|
#define container_of(ptr, type, member) ({ \
|
||||||
|
const typeof( ((type *)0)->member ) *__mptr = (ptr); \
|
||||||
|
(type *)( (char *)__mptr - offsetof(type,member) );})
|
||||||
|
|
||||||
|
|
||||||
/* DANGER!!!! here be dragons!
|
/* DANGER!!!! here be dragons!
|
||||||
*
|
*
|
||||||
* Leave these fn's as byte accesses because it is safe
|
* Leave these fn's as byte accesses because it is safe
|
||||||
|
|
|
@ -26,7 +26,6 @@
|
||||||
#ifndef TARGET_H
|
#ifndef TARGET_H
|
||||||
#define TARGET_H
|
#define TARGET_H
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include "jim.h"
|
#include "jim.h"
|
||||||
|
|
||||||
|
@ -39,18 +38,6 @@ struct mem_param;
|
||||||
struct reg_param;
|
struct reg_param;
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cast a member of a structure out to the containing structure.
|
|
||||||
* @param ptr The pointer to the member.
|
|
||||||
* @param type The type of the container struct this is embedded in.
|
|
||||||
* @param member The name of the member within the struct.
|
|
||||||
*
|
|
||||||
* This is a mechanism which is used throughout the Linux kernel.
|
|
||||||
*/
|
|
||||||
#define container_of(ptr, type, member) ({ \
|
|
||||||
const typeof( ((type *)0)->member ) *__mptr = (ptr); \
|
|
||||||
(type *)( (char *)__mptr - offsetof(type,member) );})
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* TARGET_UNKNOWN = 0: we don't know anything about the target yet
|
* TARGET_UNKNOWN = 0: we don't know anything about the target yet
|
||||||
* TARGET_RUNNING = 1: the target is executing user code
|
* TARGET_RUNNING = 1: the target is executing user code
|
||||||
|
|
Loading…
Reference in New Issue