TWCOS Kernel

Hex Artifact Content
Login

Artifact de3b19ccbb2c27cd3f3f86f35174426f81702618:


0000: 23 69 6e 63 6c 75 64 65 20 22 63 6f 6d 2e 68 22  #include "com.h"
0010: 0a 0a 23 69 66 20 49 4e 54 45 52 46 41 43 45 0a  ..#if INTERFACE.
0020: 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 64 65  .#include <stdde
0030: 66 2e 68 3e 0a 0a 74 79 70 65 64 65 66 20 76 6f  f.h>..typedef vo
0040: 69 64 20 2a 20 28 2a 69 6e 74 65 72 66 61 63 65  id * (*interface
0050: 5f 71 75 65 72 79 5f 74 29 28 76 6f 69 64 20 2a  _query_t)(void *
0060: 2c 20 69 69 64 5f 74 20 69 69 64 29 3b 0a 0a 23  , iid_t iid);..#
0070: 64 65 66 69 6e 65 20 49 4e 54 45 52 46 41 43 45  define INTERFACE
0080: 5f 49 4d 50 4c 5f 51 55 45 52 59 28 69 66 61 63  _IMPL_QUERY(ifac
0090: 65 2c 20 63 6f 6e 74 61 69 6e 65 72 2c 20 6d 65  e, container, me
00a0: 6d 62 65 72 29 20 5c 0a 76 6f 69 64 20 2a 20 49  mber) \.void * I
00b0: 4e 54 45 52 46 41 43 45 5f 49 4d 50 4c 5f 51 55  NTERFACE_IMPL_QU
00c0: 45 52 59 5f 4e 41 4d 45 28 69 66 61 63 65 2c 20  ERY_NAME(iface, 
00d0: 63 6f 6e 74 61 69 6e 65 72 29 28 76 6f 69 64 20  container)(void 
00e0: 2a 20 69 2c 20 69 69 64 5f 74 20 69 64 29 20 5c  * i, iid_t id) \
00f0: 0a 7b 20 5c 0a 09 72 65 74 75 72 6e 20 63 6f 6d  .{ \..return com
0100: 5f 71 75 65 72 79 28 49 4e 54 45 52 46 41 43 45  _query(INTERFACE
0110: 5f 4d 41 50 5f 4e 41 4d 45 28 63 6f 6e 74 61 69  _MAP_NAME(contai
0120: 6e 65 72 29 2c 20 63 6f 75 6e 74 6f 66 28 49 4e  ner), countof(IN
0130: 54 45 52 46 41 43 45 5f 4d 41 50 5f 4e 41 4d 45  TERFACE_MAP_NAME
0140: 28 63 6f 6e 74 61 69 6e 65 72 29 29 2c 20 69 64  (container)), id
0150: 2c 20 63 6f 6e 74 61 69 6e 65 72 5f 6f 66 28 69  , container_of(i
0160: 2c 20 63 6f 6e 74 61 69 6e 65 72 2c 20 6d 65 6d  , container, mem
0170: 62 65 72 29 29 3b 20 5c 0a 7d 0a 23 64 65 66 69  ber)); \.}.#defi
0180: 6e 65 20 49 4e 54 45 52 46 41 43 45 5f 4f 50 53  ne INTERFACE_OPS
0190: 5f 54 59 50 45 28 69 66 61 63 65 29 20 69 66 61  _TYPE(iface) ifa
01a0: 63 65 20 23 23 20 5f 6f 70 73 0a 73 74 61 74 69  ce ## _ops.stati
01b0: 63 20 69 66 61 63 65 20 23 23 20 5f 6f 70 73 20  c iface ## _ops 
01c0: 63 6f 6e 74 61 69 6e 65 72 20 23 23 20 5f 20 23  container ## _ #
01d0: 23 20 69 66 61 63 65 20 0a 23 64 65 66 69 6e 65  # iface .#define
01e0: 20 49 4e 54 45 52 46 41 43 45 5f 49 4d 50 4c 5f   INTERFACE_IMPL_
01f0: 51 55 45 52 59 5f 4d 45 54 48 4f 44 28 69 66 61  QUERY_METHOD(ifa
0200: 63 65 2c 20 63 6f 6e 74 61 69 6e 65 72 29 20 2e  ce, container) .
0210: 71 75 65 72 79 20 3d 20 49 4e 54 45 52 46 41 43  query = INTERFAC
0220: 45 5f 49 4d 50 4c 5f 51 55 45 52 59 5f 4e 41 4d  E_IMPL_QUERY_NAM
0230: 45 28 69 66 61 63 65 2c 20 63 6f 6e 74 61 69 6e  E(iface, contain
0240: 65 72 29 0a 0a 23 64 65 66 69 6e 65 20 49 4e 54  er)..#define INT
0250: 45 52 46 41 43 45 5f 49 4d 50 4c 5f 4d 45 54 48  ERFACE_IMPL_METH
0260: 4f 44 28 6d 65 74 68 6f 64 2c 20 6d 65 74 68 6f  OD(method, metho
0270: 64 5f 69 6d 70 6c 29 20 2c 20 2e 6d 65 74 68 6f  d_impl) , .metho
0280: 64 20 3d 20 6d 65 74 68 6f 64 5f 69 6d 70 6c 0a  d = method_impl.
0290: 0a 0a 23 64 65 66 69 6e 65 20 49 4e 54 45 52 46  ..#define INTERF
02a0: 41 43 45 5f 49 4d 50 4c 5f 4e 41 4d 45 28 69 66  ACE_IMPL_NAME(if
02b0: 61 63 65 2c 20 63 6f 6e 74 61 69 6e 65 72 29 20  ace, container) 
02c0: 63 6f 6e 74 61 69 6e 65 72 20 23 23 20 5f 20 23  container ## _ #
02d0: 23 20 69 66 61 63 65 0a 23 64 65 66 69 6e 65 20  # iface.#define 
02e0: 49 4e 54 45 52 46 41 43 45 5f 49 4d 50 4c 5f 51  INTERFACE_IMPL_Q
02f0: 55 45 52 59 5f 4e 41 4d 45 28 69 66 61 63 65 2c  UERY_NAME(iface,
0300: 20 63 6f 6e 74 61 69 6e 65 72 29 20 63 6f 6e 74   container) cont
0310: 61 69 6e 65 72 20 23 23 20 5f 20 23 23 20 69 66  ainer ## _ ## if
0320: 61 63 65 20 23 23 20 5f 20 23 23 20 71 75 65 72  ace ## _ ## quer
0330: 79 0a 0a 73 74 72 75 63 74 20 69 6e 74 65 72 66  y..struct interf
0340: 61 63 65 5f 6d 61 70 5f 74 20 7b 0a 09 69 69 64  ace_map_t {..iid
0350: 5f 74 20 69 64 3b 0a 09 69 6e 74 20 6f 66 66 73  _t id;..int offs
0360: 65 74 3b 0a 7d 3b 0a 0a 23 64 65 66 69 6e 65 20  et;.};..#define 
0370: 4d 45 54 48 4f 44 5f 50 52 4f 4c 4f 47 28 69 66  METHOD_PROLOG(if
0380: 61 63 65 2c 20 63 6f 6e 74 61 69 6e 65 72 2c 20  ace, container, 
0390: 6d 65 6d 62 65 72 29 20 63 6f 6e 74 61 69 6e 65  member) containe
03a0: 72 20 2a 20 70 54 68 69 73 20 3d 20 63 6f 6e 74  r * pThis = cont
03b0: 61 69 6e 65 72 5f 6f 66 28 69 66 61 63 65 2c 20  ainer_of(iface, 
03c0: 63 6f 6e 74 61 69 6e 65 72 2c 20 6d 65 6d 62 65  container, membe
03d0: 72 29 0a 0a 23 64 65 66 69 6e 65 20 49 4e 54 45  r)..#define INTE
03e0: 52 46 41 43 45 5f 4d 41 50 5f 4e 41 4d 45 28 63  RFACE_MAP_NAME(c
03f0: 6f 6e 74 61 69 6e 65 72 29 20 63 6f 6e 74 61 69  ontainer) contai
0400: 6e 65 72 20 23 23 20 5f 6d 61 70 0a 0a 23 64 65  ner ## _map..#de
0410: 66 69 6e 65 20 49 4e 54 45 52 46 41 43 45 5f 4d  fine INTERFACE_M
0420: 41 50 5f 45 4e 54 52 59 28 63 6f 6e 74 61 69 6e  AP_ENTRY(contain
0430: 65 72 2c 20 69 69 64 2c 20 6d 65 6d 62 65 72 29  er, iid, member)
0440: 20 7b 20 69 69 64 2c 20 6f 66 66 73 65 74 6f 66   { iid, offsetof
0450: 28 63 6f 6e 74 61 69 6e 65 72 2c 20 6d 65 6d 62  (container, memb
0460: 65 72 29 20 7d 0a 0a 23 64 65 66 69 6e 65 20 49  er) }..#define I
0470: 4e 54 45 52 46 41 43 45 5f 4d 41 50 5f 45 4e 44  NTERFACE_MAP_END
0480: 28 63 6f 6e 74 61 69 6e 65 72 29 20 7b 30 2c 30  (container) {0,0
0490: 7d 20 7d 3b 0a 0a 74 79 70 65 64 65 66 20 63 6f  } };..typedef co
04a0: 6e 73 74 20 63 68 61 72 20 2a 20 63 6f 6e 73 74  nst char * const
04b0: 20 69 69 64 5f 74 3b 0a 0a 23 69 66 20 30 0a 73   iid_t;..#if 0.s
04c0: 74 72 75 63 74 20 71 75 65 72 79 5f 74 20 7b 0a  truct query_t {.
04d0: 09 71 75 65 72 79 5f 74 5f 6f 70 73 20 2a 20 6f  .query_t_ops * o
04e0: 70 73 3b 0a 7d 3b 0a 0a 73 74 72 75 63 74 20 71  ps;.};..struct q
04f0: 75 65 72 79 5f 74 5f 6f 70 73 20 7b 0a 09 76 6f  uery_t_ops {..vo
0500: 69 64 20 2a 20 28 2a 71 75 65 72 79 29 28 76 6f  id * (*query)(vo
0510: 69 64 20 2a 2c 20 69 69 64 5f 74 20 2a 20 69 69  id *, iid_t * ii
0520: 64 29 3b 0a 7d 3b 0a 0a 73 74 72 75 63 74 20 61  d);.};..struct a
0530: 6e 6f 6e 5f 74 65 73 74 5f 74 20 7b 0a 09 61 6e  non_test_t {..an
0540: 6f 6e 5f 74 65 73 74 5f 74 5f 6f 70 73 20 2a 20  on_test_t_ops * 
0550: 6f 70 73 3b 0a 7d 3b 0a 0a 73 74 72 75 63 74 20  ops;.};..struct 
0560: 61 6e 6f 6e 5f 74 65 73 74 5f 74 5f 6f 70 73 20  anon_test_t_ops 
0570: 3a 20 71 75 65 72 79 5f 74 5f 6f 70 73 20 7b 0a  : query_t_ops {.
0580: 09 76 6f 69 64 20 28 2a 66 6f 6f 29 28 29 3b 0a  .void (*foo)();.
0590: 7d 3b 0a 23 65 6e 64 69 66 0a 0a 23 65 6e 64 69  };.#endif..#endi
05a0: 66 0a 0a 65 78 63 65 70 74 69 6f 6e 5f 64 65 66  f..exception_def
05b0: 20 49 6e 74 65 72 66 61 63 65 4e 6f 74 46 6f 75   InterfaceNotFou
05c0: 6e 64 45 78 63 65 70 74 69 6f 6e 20 3d 20 7b 22  ndException = {"
05d0: 49 6e 74 65 72 66 61 63 65 4e 6f 74 46 6f 75 6e  InterfaceNotFoun
05e0: 64 45 78 63 65 70 74 69 6f 6e 22 2c 20 26 45 78  dException", &Ex
05f0: 63 65 70 74 69 6f 6e 7d 3b 0a 0a 76 6f 69 64 20  ception};..void 
0600: 2a 20 63 6f 6d 5f 71 75 65 72 79 28 69 6e 74 65  * com_query(inte
0610: 72 66 61 63 65 5f 6d 61 70 5f 74 20 2a 20 6d 61  rface_map_t * ma
0620: 70 2c 20 69 6e 74 20 6d 61 70 6e 75 6d 2c 20 69  p, int mapnum, i
0630: 69 64 5f 74 20 69 64 2c 20 76 6f 69 64 20 2a 20  id_t id, void * 
0640: 62 61 73 65 29 0a 7b 0a 09 66 6f 72 28 69 6e 74  base).{..for(int
0650: 20 69 3d 30 3b 20 69 3c 6d 61 70 6e 75 6d 3b 20   i=0; i<mapnum; 
0660: 69 2b 2b 29 20 7b 0a 09 09 69 66 20 28 69 64 20  i++) {...if (id 
0670: 3d 3d 20 6d 61 70 5b 69 5d 2e 69 64 29 20 7b 0a  == map[i].id) {.
0680: 09 09 09 72 65 74 75 72 6e 20 50 54 52 5f 42 59  ...return PTR_BY
0690: 54 45 5f 41 44 44 52 45 53 53 28 62 61 73 65 2c  TE_ADDRESS(base,
06a0: 20 6d 61 70 5b 69 5d 2e 6f 66 66 73 65 74 29 3b   map[i].offset);
06b0: 0a 09 09 7d 0a 09 7d 0a 09 4b 54 48 52 4f 57 46  ...}..}..KTHROWF
06c0: 28 49 6e 74 65 72 66 61 63 65 4e 6f 74 46 6f 75  (InterfaceNotFou
06d0: 6e 64 45 78 63 65 70 74 69 6f 6e 2c 20 22 49 6e  ndException, "In
06e0: 74 65 72 66 61 63 65 20 6e 6f 74 20 66 6f 75 6e  terface not foun
06f0: 64 3a 20 25 73 22 2c 20 69 64 29 3b 0a 7d 20 0a  d: %s", id);.} .
0700: 0a 23 69 66 20 30 0a 0a 73 74 61 74 69 63 20 76  .#if 0..static v
0710: 6f 69 64 20 61 6e 6f 6e 5f 74 65 73 74 5f 66 6f  oid anon_test_fo
0720: 6f 28 76 6f 69 64 20 2a 20 69 29 0a 7b 0a 7d 0a  o(void * i).{.}.
0730: 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20  .typedef struct 
0740: 66 6f 6f 5f 74 20 66 6f 6f 5f 74 3b 0a 73 74 72  foo_t foo_t;.str
0750: 75 63 74 20 66 6f 6f 5f 74 20 7b 0a 09 61 6e 6f  uct foo_t {..ano
0760: 6e 5f 74 65 73 74 5f 74 20 61 6e 6f 6e 5f 74 65  n_test_t anon_te
0770: 73 74 3b 0a 7d 3b 0a 0a 63 6f 6e 73 74 20 69 69  st;.};..const ii
0780: 64 5f 74 20 69 69 64 5f 61 6e 6f 6e 5f 74 65 73  d_t iid_anon_tes
0790: 74 5f 74 20 3d 20 22 22 3b 0a 0a 73 74 61 74 69  t_t = "";..stati
07a0: 63 20 69 6e 74 65 72 66 61 63 65 5f 6d 61 70 5f  c interface_map_
07b0: 74 20 66 6f 6f 5f 74 5f 6d 61 70 20 5b 5d 20 3d  t foo_t_map [] =
07c0: 0a 7b 0a 20 20 20 20 20 20 20 20 49 4e 54 45 52  .{.        INTER
07d0: 46 41 43 45 5f 4d 41 50 5f 45 4e 54 52 59 28 66  FACE_MAP_ENTRY(f
07e0: 6f 6f 5f 74 2c 20 69 69 64 5f 61 6e 6f 6e 5f 74  oo_t, iid_anon_t
07f0: 65 73 74 5f 74 2c 20 61 6e 6f 6e 5f 74 65 73 74  est_t, anon_test
0800: 29 2c 0a 7d 3b 0a 73 74 61 74 69 63 20 49 4e 54  ),.};.static INT
0810: 45 52 46 41 43 45 5f 49 4d 50 4c 5f 51 55 45 52  ERFACE_IMPL_QUER
0820: 59 28 61 6e 6f 6e 5f 74 65 73 74 5f 74 2c 20 66  Y(anon_test_t, f
0830: 6f 6f 5f 74 2c 20 61 6e 6f 6e 5f 74 65 73 74 29  oo_t, anon_test)
0840: 0a 73 74 61 74 69 63 20 49 4e 54 45 52 46 41 43  .static INTERFAC
0850: 45 5f 4f 50 53 5f 54 59 50 45 28 61 6e 6f 6e 5f  E_OPS_TYPE(anon_
0860: 74 65 73 74 5f 74 29 20 49 4e 54 45 52 46 41 43  test_t) INTERFAC
0870: 45 5f 49 4d 50 4c 5f 4e 41 4d 45 28 61 6e 6f 6e  E_IMPL_NAME(anon
0880: 5f 74 65 73 74 5f 74 2c 20 66 6f 6f 5f 74 29 20  _test_t, foo_t) 
0890: 3d 20 7b 0a 20 20 20 20 20 20 20 20 49 4e 54 45  = {.        INTE
08a0: 52 46 41 43 45 5f 49 4d 50 4c 5f 51 55 45 52 59  RFACE_IMPL_QUERY
08b0: 5f 4d 45 54 48 4f 44 28 61 6e 6f 6e 5f 74 65 73  _METHOD(anon_tes
08c0: 74 5f 74 2c 20 66 6f 6f 5f 74 29 0a 20 20 20 20  t_t, foo_t).    
08d0: 20 20 20 20 49 4e 54 45 52 46 41 43 45 5f 49 4d      INTERFACE_IM
08e0: 50 4c 5f 4d 45 54 48 4f 44 28 66 6f 6f 2c 20 61  PL_METHOD(foo, a
08f0: 6e 6f 6e 5f 74 65 73 74 5f 66 6f 6f 29 0a 7d 3b  non_test_foo).};
0900: 0a 0a 23 65 6e 64 69 66 0a                       ..#endif.