summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Sandiford <rsandifo@nildram.co.uk>2004-01-23 12:52:20 +0000
committerRichard Sandiford <rsandifo@nildram.co.uk>2004-01-23 12:52:20 +0000
commitb36f8369a88b36c6974db6d1fc0c5a03fb0dfe0f (patch)
tree8594e28ebd144e6ae51eeea73ff74c2af6ffb1e7
parent56390e271e3b672981529f2fe10d681076a41d1a (diff)
downloadbinutils-redhat-b36f8369a88b36c6974db6d1fc0c5a03fb0dfe0f.tar.gz
* frags.h (frag_room): Declare.
* frags.c (frag_room): New function. * doc/internals.texi: Document it.
-rw-r--r--gas/ChangeLog6
-rw-r--r--gas/doc/internals.texi7
-rw-r--r--gas/frags.c8
-rw-r--r--gas/frags.h1
4 files changed, 19 insertions, 3 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 438ea36765..9133f7c21f 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,9 @@
+2004-01-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * frags.h (frag_room): Declare.
+ * frags.c (frag_room): New function.
+ * doc/internals.texi: Document it.
+
2004-01-22 Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
* config/tc-mips.c (append_insn): Don't do r3900 interlock
diff --git a/gas/doc/internals.texi b/gas/doc/internals.texi
index 3d94f43b10..c62f8298c3 100644
--- a/gas/doc/internals.texi
+++ b/gas/doc/internals.texi
@@ -704,9 +704,10 @@ processing. After this point, it is safe to operate on one chain per section.
The assembler always has a current frag, named @code{frag_now}. More space is
allocated for the current frag using the @code{frag_more} function; this
-returns a pointer to the amount of requested space. Relaxing is done using
-variant frags allocated by @code{frag_var} or @code{frag_variant}
-(@pxref{Relaxation}).
+returns a pointer to the amount of requested space. The function
+@code{frag_room} says by how much the current frag can be extended.
+Relaxing is done using variant frags allocated by @code{frag_var}
+or @code{frag_variant} (@pxref{Relaxation}).
@node GAS processing
@section What GAS does when it runs
diff --git a/gas/frags.c b/gas/frags.c
index 1521d4bf01..83625d7fbf 100644
--- a/gas/frags.c
+++ b/gas/frags.c
@@ -262,6 +262,14 @@ frag_wane (register fragS *fragP)
fragP->fr_var = 0;
}
+/* Return the number of bytes by which the current frag can be grown. */
+
+int
+frag_room (void)
+{
+ return obstack_room (&frchain_now->frch_obstack);
+}
+
/* Make an alignment frag. The size of this frag will be adjusted to
force the next frag to have the appropriate alignment. ALIGNMENT
is the power of two to which to align. FILL_CHARACTER is the
diff --git a/gas/frags.h b/gas/frags.h
index 73b71821b9..52a6cfeb4b 100644
--- a/gas/frags.h
+++ b/gas/frags.h
@@ -141,6 +141,7 @@ void frag_align_pattern (int alignment, const char *fill_pattern,
void frag_align_code (int alignment, int max);
void frag_new (int old_frags_var_max_size);
void frag_wane (fragS * fragP);
+int frag_room (void);
char *frag_variant (relax_stateT type,
int max_chars,