OSDN Git Service

PR ada/24533
authordanglin <danglin@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 20 Jan 2006 14:30:33 +0000 (14:30 +0000)
committerdanglin <danglin@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 20 Jan 2006 14:30:33 +0000 (14:30 +0000)
* s-osinte-linux-hppa.ads: Reduce alignment of atomic_lock_t to 8.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@110025 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ada/ChangeLog
gcc/ada/s-osinte-linux-hppa.ads

index 8257e42..bc2e38c 100644 (file)
@@ -1,3 +1,8 @@
+2006-01-20  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR ada/24533
+       * s-osinte-linux-hppa.ads: Reduce alignment of atomic_lock_t to 8.
+
 2005-12-28  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
 
        * s-osinte-linux-hppa.ads: Correct alignment of atomic_lock_t.
index ec7efd2..40f0d07 100644 (file)
@@ -508,7 +508,10 @@ private
       lock : lock_array;
    end record;
    pragma Convention (C, atomic_lock_t);
-   for atomic_lock_t'Alignment use 16;
+   --  ??? Alignment should be 16 but this is larger than BIGGEST_ALIGNMENT.
+   --  This causes an erroneous pointer value to sometimes be passed to free
+   --  during deallocation.  See PR ada/24533 for more details.
+   for atomic_lock_t'Alignment use 8;
 
    type struct_pthread_fast_lock is record
       spinlock : atomic_lock_t;