]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/tree-streamer.h
Update copyright years.
[thirdparty/gcc.git] / gcc / tree-streamer.h
CommitLineData
2541503d 1/* Data structures and functions for streaming trees.
2
f1717362 3 Copyright (C) 2011-2016 Free Software Foundation, Inc.
2541503d 4 Contributed by Diego Novillo <dnovillo@google.com>
5
6This file is part of GCC.
7
8GCC is free software; you can redistribute it and/or modify it under
9the terms of the GNU General Public License as published by the Free
10Software Foundation; either version 3, or (at your option) any later
11version.
12
13GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14WARRANTY; without even the implied warranty of MERCHANTABILITY or
15FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16for more details.
17
18You should have received a copy of the GNU General Public License
19along with GCC; see the file COPYING3. If not see
20<http://www.gnu.org/licenses/>. */
21
22#ifndef GCC_TREE_STREAMER_H
23#define GCC_TREE_STREAMER_H
24
515cf651 25#include "streamer-hooks.h"
2e971afd 26#include "data-streamer.h"
2541503d 27
28/* Cache of pickled nodes. Used to avoid writing the same node more
29 than once. The first time a tree node is streamed out, it is
30 entered in this cache. Subsequent references to the same node are
31 resolved by looking it up in this cache.
32
33 This is used in two ways:
34
35 - On the writing side, the first time T is added to STREAMER_CACHE,
36 a new reference index is created for T and T is emitted on the
37 stream. If T needs to be emitted again to the stream, instead of
38 pickling it again, the reference index is emitted.
39
40 - On the reading side, the first time T is read from the stream, it
41 is reconstructed in memory and a new reference index created for
42 T. The reconstructed T is inserted in some array so that when
43 the reference index for T is found in the input stream, it can be
44 used to look up into the array to get the reconstructed T. */
8ceff600 45
7f385784 46struct streamer_tree_cache_d
2541503d 47{
48 /* The mapping between tree nodes and slots into the nodes array. */
d62dd039 49 hash_map<tree, unsigned> *node_map;
2541503d 50
51 /* The nodes pickled so far. */
f1f41a6c 52 vec<tree> nodes;
8ceff600 53 /* The node hashes (if available). */
54 vec<hashval_t> hashes;
b1e946ea 55
56 /* Next index to assign. */
57 unsigned next_idx;
2541503d 58};
59
515cf651 60/* Return true if tree node EXPR should be streamed as a builtin. For
61 these nodes, we just emit the class and function code. */
62static inline bool
7f385784 63streamer_handle_as_builtin_p (tree expr)
515cf651 64{
65 return (TREE_CODE (expr) == FUNCTION_DECL
66 && DECL_IS_BUILTIN (expr)
67 && (DECL_BUILT_IN_CLASS (expr) == BUILT_IN_NORMAL
68 || DECL_BUILT_IN_CLASS (expr) == BUILT_IN_MD));
69}
70
2541503d 71/* In tree-streamer-in.c. */
7f385784 72tree streamer_read_string_cst (struct data_in *, struct lto_input_block *);
73tree streamer_read_chain (struct lto_input_block *, struct data_in *);
74tree streamer_alloc_tree (struct lto_input_block *, struct data_in *,
75 enum LTO_tags);
76void streamer_read_tree_body (struct lto_input_block *, struct data_in *, tree);
77tree streamer_get_pickled_tree (struct lto_input_block *, struct data_in *);
78tree streamer_get_builtin_tree (struct lto_input_block *, struct data_in *);
205b5601 79void streamer_read_tree_bitfields (struct lto_input_block *,
80 struct data_in *, tree);
2541503d 81
82/* In tree-streamer-out.c. */
65d1b157 83void streamer_write_string_cst (struct output_block *,
84 struct lto_output_stream *, tree);
7f385784 85void streamer_write_chain (struct output_block *, tree, bool);
86void streamer_write_tree_header (struct output_block *, tree);
c76dc468 87void streamer_write_tree_bitfields (struct output_block *, tree);
7f385784 88void streamer_write_tree_body (struct output_block *, tree, bool);
89void streamer_write_integer_cst (struct output_block *, tree, bool);
90void streamer_write_builtin (struct output_block *, tree);
2541503d 91
92/* In tree-streamer.c. */
2e971afd 93extern unsigned char streamer_mode_table[1 << 8];
7f385784 94void streamer_check_handled_ts_structures (void);
95bool streamer_tree_cache_insert (struct streamer_tree_cache_d *, tree,
8ceff600 96 hashval_t, unsigned *);
97void streamer_tree_cache_replace_tree (struct streamer_tree_cache_d *, tree,
98 unsigned);
99void streamer_tree_cache_append (struct streamer_tree_cache_d *, tree,
100 hashval_t);
7f385784 101bool streamer_tree_cache_lookup (struct streamer_tree_cache_d *, tree,
102 unsigned *);
b1e946ea 103struct streamer_tree_cache_d *streamer_tree_cache_create (bool, bool, bool);
7f385784 104void streamer_tree_cache_delete (struct streamer_tree_cache_d *);
2541503d 105
23244f0b 106/* Return the tree node at slot IX in CACHE. */
107
108static inline tree
8ceff600 109streamer_tree_cache_get_tree (struct streamer_tree_cache_d *cache, unsigned ix)
23244f0b 110{
f1f41a6c 111 return cache->nodes[ix];
23244f0b 112}
113
8ceff600 114/* Return the tree hash value at slot IX in CACHE. */
115
116static inline hashval_t
117streamer_tree_cache_get_hash (struct streamer_tree_cache_d *cache, unsigned ix)
118{
119 return cache->hashes[ix];
120}
121
2e971afd 122static inline void
123bp_pack_machine_mode (struct bitpack_d *bp, machine_mode mode)
124{
125 streamer_mode_table[mode] = 1;
126 bp_pack_enum (bp, machine_mode, 1 << 8, mode);
127}
128
129static inline machine_mode
130bp_unpack_machine_mode (struct bitpack_d *bp)
131{
132 return (machine_mode)
133 ((struct lto_input_block *)
134 bp->stream)->mode_table[bp_unpack_enum (bp, machine_mode, 1 << 8)];
135}
23244f0b 136
2541503d 137#endif /* GCC_TREE_STREAMER_H */