(j3.2006) (SC22WG5.3637) [ukfortran] N1751
N.M. Maclaren
nmm1
Thu Nov 6 15:07:40 EST 2008
On Nov 6 2008, Michael Ingrassia wrote:
>
>>Can you point me at anything in the standard that states that principle?
>
> 2.4.2p1 says that Execution of a program consists of the asynchronous
> execution of a fixed number of images. Chapter 8 describes the control
> flow within an image. Failure to execute image P is a failure to execute
> the program. Progress in image P can be paused at PAUSE statements or at
> image control statements, but as you say I think that failure to advance
> otherwise might be considered "gratuitously perverse".
Yes, but the problem is that the program IS "advancing" as fast as it can!
What the processor can't tell is that it is merely running on the spot.
Note that I am not saying that Fortran should specify fairness in scheduling
(no other language does that I know of), but that NOTE 8.38 relies on it,
and it is therefore undefined whether that code will ever complete.
>Yes, anyone can write non-halting programs and a processor can't weed
>them out a priori. That doesn't mean that users must always despair; by
>use of discipline they can write programs which they can prove
>will in fact halt. I've seen lots of such proofs.
Oh, yes, I could give you a delightful probabilistic example that I gave
to someone talking on this in 1972 :-) My point is that you CAN'T do it
with current VOLATILE coarrays, without specifying 'fairness'.
> The question is whether the (implied) proof that this program in NOTE
> 8.38 halts can be supplied based on our standard or whether it requires
> extra assumptions. I think we have to assume that the system scheduler
> respects the Fortran concept of image control statements. My claim is
> that a scheduler consistent with the execution rules in the standard
> can't permanently swap out an image which is not suspended at an image
> control statement. Or so I thought. Maybe that means existing thread
> schedulers would need to learn a wee bit of Fortran to become image
> schedulers ?
That is a vain hope. Many people have been trying to get general-purpose
schedulers to support gang-scheduling and similar 'HPC' models for decades,
with virtually no progress.
>BTW your mail headers included
>
>>To: sc22wg5 at open-std.org
>>Reply-to: fortran standards email list for J3 <j3 at j3-fortran.org>
>
>which seems odd to me. I don't understand why replies aren't directed
>to sc22wg5.
Bloody Webmail. I have been inflicted with a new system for mail, and it is
<expletive deleted, to avoid system meltdown>. Sorry.
Regards,
Nick Maclaren,
University of Cambridge Computing Service,
New Museums Site, Pembroke Street, Cambridge CB2 3QH, England.
Email: nmm1 at cam.ac.uk
Tel.: +44 1223 334761 Fax: +44 1223 334679
More information about the J3
mailing list