summaryrefslogtreecommitdiff
path: root/gcc/ada/sem_prag.adb
diff options
context:
space:
mode:
authorcharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2003-11-04 12:51:47 +0000
committercharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2003-11-04 12:51:47 +0000
commitcafd02b3e86511710dff2234a989975336909601 (patch)
tree8a2906f87ff8dae462187a72710b5203b22a6c1b /gcc/ada/sem_prag.adb
parent3f26eaa9e3a48823a83959fbd9fbabc64a7b55aa (diff)
downloadgcc-cafd02b3e86511710dff2234a989975336909601.tar.gz
* sysdep.c: Problem discovered during IA64 VMS port.
[VMS] #include <unixio.h> to get proper prototypes. * adaint.c: Issues discovered/problems fixed during IA64 VMS port. [VMS] #define _POSIX_EXIT for proper semantics. [VMS] #include <unixio.h> for proper prototypes. [VMS] (fork): #define IA64 version. (__gnat_os_exit): Remove unnecessary VMS specific code. * 3vtrasym.adb: Minor reformatting Use terminology encoded/decoded name, rather than C++ specific notion of mangling (this is the terminology used throughout GNAT). * einfo.h: Regenerated * einfo.ads, einfo.adb: Add new flag Is_Thread_Body * exp_ch6.adb: (Expand_N_Subprogram_Body): Handle expansion of thread body procedure * par-prag.adb: Add dummy entry for Thread_Body pragma * rtsfind.ads: Add entries for System.Threads entities for thread body processing * sem_attr.adb: (Analyze_Pragma, Access attributes): Check these are not applied to a thread body, since this is not permitted * sem_prag.adb: Add processing for Thread_Body pragma. Minor comment fix. * sem_res.adb: (Resolve_Call): Check for incorrect attempt to call a thread body procedure with a direct call. * snames.ads, snames.adb: Add entry for Thread_Body pragma Add names associated with thread body expansion * snames.h: Add entry for Thread_Body pragma * s-thread.adb: Add entries for thread body processing These are dummy bodies so far * s-thread.ads: Add documentation on thread body handling. Add entries for thread body processing. * sem_ch10.adb: (Build_Limited_Views): Return after posting an error in case of limited with_clause on subprograms, generics, instances or generic renamings (Install_Limited_Withed_Unit): Do nothing in case of limited with_clause on subprograms, generics, instances or generic renamings * raise.c (setup_to_install): Correct mistake in last revision; two arguments out of order. * trans.c, cuintp.c, argv.c, aux-io.c, cal.c, errno.c, exit.c, gnatbl.c, init.c, stringt.h, utils.c, utils2.c: Update copyright notice, missed in previous change. Remove trailing blanks and other style errors introduced in previous change. * decl.c (gnat_to_gnu_field): Adjust the conditions under which we get rid of the wrapper for a LJM type, ensuring we don't do that if the field is addressable. This avoids potential low level type view mismatches later on, for instance in a by-reference argument passing process. * decl.c (gnat_to_gnu_field): No longer check for BLKmode being aligned at byte boundary. * decl.c (components_to_record): Do not delete the empty variants from the end of the union type. * exp_ch4.adb (Expand_N_Op_Eq): Use base type when locating primitive operation for a derived type, an explicit declaration may use a local subtype of Boolean. * make.adb (Gnatmake): Allow main sources on the command line with a library project when it is only for compilation (no binding or linking). Part of PR ada/12806: * ada-tree.h (TYPE_DIGITS_VALUE, SET_TYPE_DIGITS_VALUE): Save count as tree, not integer. * decl.c: (gnat_to_gnu_entity, case E_Floating_Point_Type): Save count as tree, not integer. * targtyps.c, decl.c, misc.c, gigi.h (fp_prec_to_size, fp_size_to_prec): Temporary routines to work around change in FP sizing semantics in GCC. * utils.c: (build_vms_descriptor): TYPE_DIGITS_VALUE is tree, not integer. * gigi.h: (enumerate_modes): New function. * Make-lang.in: (ada/misc.o): Add real.h. * misc.c: (enumerate_modes): New function. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@73250 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ada/sem_prag.adb')
-rw-r--r--gcc/ada/sem_prag.adb75
1 files changed, 75 insertions, 0 deletions
diff --git a/gcc/ada/sem_prag.adb b/gcc/ada/sem_prag.adb
index d5d82b2e33d..037650fa10c 100644
--- a/gcc/ada/sem_prag.adb
+++ b/gcc/ada/sem_prag.adb
@@ -9082,6 +9082,80 @@ package body Sem_Prag is
end if;
end Task_Storage;
+ -----------------
+ -- Thread_Body --
+ -----------------
+
+ -- pragma Thread_Body
+ -- ( [Entity =>] LOCAL_NAME
+ -- [,[Secondary_Stack_Size =>] static_integer_EXPRESSION]);
+
+ when Pragma_Thread_Body => Thread_Body : declare
+ Id : Node_Id;
+ SS : Node_Id;
+ E : Entity_Id;
+
+ begin
+ GNAT_Pragma;
+ Check_At_Least_N_Arguments (1);
+ Check_At_Most_N_Arguments (2);
+ Check_Optional_Identifier (Arg1, Name_Entity);
+ Check_Arg_Is_Local_Name (Arg1);
+
+ Id := Expression (Arg1);
+
+ if not Is_Entity_Name (Id)
+ or else not Is_Subprogram (Entity (Id))
+ then
+ Error_Pragma_Arg ("subprogram name required", Arg1);
+ end if;
+
+ E := Entity (Id);
+
+ -- Go to renamed subprogram if present, since Thread_Body applies
+ -- to the actual renamed entity, not to the renaming entity.
+
+ if Present (Alias (E))
+ and then Nkind (Parent (Declaration_Node (E))) =
+ N_Subprogram_Renaming_Declaration
+ then
+ E := Alias (E);
+ end if;
+
+ -- Various error checks
+
+ if Nkind (Parent (Declaration_Node (E))) = N_Subprogram_Body then
+ Error_Pragma
+ ("pragma% requires separate spec and must come before body");
+
+ elsif Rep_Item_Too_Early (E, N)
+ or else
+ Rep_Item_Too_Late (E, N)
+ then
+ raise Pragma_Exit;
+
+ elsif Is_Thread_Body (E) then
+ Error_Pragma_Arg
+ ("only one thread body pragma allowed", Arg1);
+
+ elsif Present (Homonym (E))
+ and then Scope (Homonym (E)) = Current_Scope
+ then
+ Error_Pragma_Arg
+ ("thread body subprogram must not be overloaded", Arg1);
+ end if;
+
+ Set_Is_Thread_Body (E);
+
+ -- Deal with secondary stack argument
+
+ if Arg_Count = 2 then
+ Check_Optional_Identifier (Arg2, Name_Secondary_Stack_Size);
+ SS := Expression (Arg2);
+ Analyze_And_Resolve (SS, Any_Integer);
+ end if;
+ end Thread_Body;
+
----------------
-- Time_Slice --
----------------
@@ -9812,6 +9886,7 @@ package body Sem_Prag is
Pragma_Task_Info => -1,
Pragma_Task_Name => -1,
Pragma_Task_Storage => 0,
+ Pragma_Thread_Body => +2,
Pragma_Time_Slice => -1,
Pragma_Title => -1,
Pragma_Unchecked_Union => -1,