OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [objc/] [objc-runtime-hooks.h] - Blame information for rev 749

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 717 jeremybenn
/* Hooks to abstract the runtime meta-data generation for Objective C.
2
   Copyright (C) 2011 Free Software Foundation, Inc.
3
   Contributed by Iain Sandoe
4
 
5
This file is part of GCC.
6
 
7
GCC is free software; you can redistribute it and/or modify
8
it under the terms of the GNU General Public License as published by
9
the Free Software Foundation; either version 3, or (at your option)
10
any later version.
11
 
12
GCC is distributed in the hope that it will be useful,
13
but WITHOUT ANY WARRANTY; without even the implied warranty of
14
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
GNU General Public License for more details.
16
 
17
You should have received a copy of the GNU General Public License
18
along with GCC; see the file COPYING3.  If not see
19
<http://www.gnu.org/licenses/>.  */
20
 
21
#ifndef _OBJC_RUNTIME_HOOKS_H_
22
#define _OBJC_RUNTIME_HOOKS_H_
23
 
24
/* A set of hooks for the front end to obtain runtime-specific actions.  */
25
 
26
/* Objective-C supports several runtime library variants:
27
 
28
   "GNU" runtime selected by -fgnu-runtime (currently at ABI version 8).
29
   "NeXT" runtime (selected by -fnext-runtime) and installed on OSX/Darwin
30
   systems at API version 1 (for m32 code) and version 2 (for m64 code).
31
 
32
   The runtimes require different data types/layouts, method call mechanisms
33
   and so on, and the purpose of this interface is to abstract such
34
   differences from the parser's perspective.  */
35
 
36
/* TODO: Do we want the initial underscore ? */
37
typedef struct _objc_runtime_hooks_r
38
{
39
  /* TODO: Expand comments in this file.  */
40
 
41
  /* Initialize for this runtime.  */
42
  void (*initialize) (void);
43
  const char *default_constant_string_class_name;
44
 
45
  /* FIXME: Having to check this name should not be necessary.  */
46
  const char *tag_getclass;
47
  /* id for superclass class field - named differently in the existing
48
     runtimes.  */
49
  tree (*super_superclassfield_ident) (void);
50
 
51
  /* Obtain a class decl for the identifier.  */
52
  tree (*class_decl) (tree);
53
  /* Obtain a metaclass decl for the identifier.  */
54
  tree (*metaclass_decl) (tree);
55
  /* Obtain a category decl for the identifier.  */
56
  tree (*category_decl) (tree);
57
  /* Obtain a protocol decl for the identifier.  */
58
  tree (*protocol_decl) (tree);
59
  /* Obtain a string decl, to be placed in the nominated string-section.  */
60
  tree (*string_decl) (tree, const char *, string_section);
61
 
62
  /* Obtain a class reference, generating the fwd def. if necessary.  */
63
  tree (*get_class_reference) (tree);
64
  /* build/get selector reference.  */
65
  tree (*build_selector_reference) (location_t, tree, tree);
66
  /* Get a protocol reference, generating the forward def. if necessary.  */
67
  tree (*get_protocol_reference) (location_t, tree);
68
  /* Get an ivar ref. re the base.  */
69
  tree (*build_ivar_reference) (location_t, tree, tree);
70
  /* Get a reference to {meta}class' super.  */
71
  tree (*get_class_super_ref) (location_t, struct imp_entry *, bool);
72
  /* Get a reference to Category {meta}class' super.  */
73
  tree (*get_category_super_ref) (location_t, struct imp_entry *, bool);
74
 
75
  /* Receiver is class Object, check runtime-specific.  */
76
  tree (*receiver_is_class_object) (tree);
77
  /* Get the start of a method argument type list (receiver, _cmd).  */
78
  void (*get_arg_type_list_base) (VEC(tree,gc) **, tree, int, int);
79
  /* Build method call.  */
80
  tree (*build_objc_method_call) (location_t, tree, tree, tree, tree, tree, int);
81
 
82
  /* Check for or otherwise handle a request to check that the constant
83
     string class reference is set-up & OK.  */
84
  bool (*setup_const_string_class_decl) (void);
85
  /* Return the tree reprenting a const string constructor for the arg.
86
     Most of the data are in global trees.  */
87
  tree (*build_const_string_constructor) (location_t, tree, int);
88
 
89
  /* Exceptions.  */
90
  tree (*build_throw_stmt) (location_t, tree, bool);
91
  tree (*build_exc_ptr) (struct objc_try_context **);
92
  tree (*begin_catch) (struct objc_try_context **, tree, tree, tree, bool);
93
  void (*finish_catch) (struct objc_try_context **, tree);
94
  tree (*finish_try_stmt) (struct objc_try_context **);
95
 
96
  /* Emit all the metadata required by the runtime - based on the tables built
97
     during parsing.  */
98
  void (*generate_metadata) (void);
99
 
100
} objc_runtime_hooks;
101
 
102
/* For shared support that needs to access these.  */
103
extern objc_runtime_hooks runtime;
104
 
105
/* One per runtime at present.
106
   TODO: Make into some kind of configury-generated table.  */
107
extern bool objc_gnu_runtime_abi_01_init (objc_runtime_hooks *);
108
extern bool objc_next_runtime_abi_01_init (objc_runtime_hooks *);
109
extern bool objc_next_runtime_abi_02_init (objc_runtime_hooks *);
110
 
111
#endif /* _OBJC_RUNTIME_HOOKS_H_ */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.