1
1

Partially restore the iof changes - this repairs the initial observation of inconsistent and incomplete output

This commit was SVN r19999.
Этот коммит содержится в:
Ralph Castain 2008-11-14 20:36:18 +00:00
родитель 586334d1c8
Коммит 68423f7544
3 изменённых файлов: 51 добавлений и 53 удалений

Просмотреть файл

@ -271,35 +271,33 @@ static int hnp_close(const orte_process_name_t* peer,
orte_iof_tag_t source_tag)
{
opal_list_item_t *item, *next_item;
if( ORTE_IOF_STDIN & source_tag ) {
orte_iof_read_event_t* rev;
int rev_fd;
for( item = opal_list_get_first(&mca_iof_hnp_component.read_events);
item != opal_list_get_end(&mca_iof_hnp_component.read_events);
item = next_item ) {
rev = (orte_iof_read_event_t*)item;
next_item = opal_list_get_next(item);
if( (rev->name.jobid == peer->jobid) &&
(rev->name.vpid == peer->vpid) ) {
/* Dont close if it's the main stdin. This will get closed
* in component close.
*/
if( mca_iof_hnp_component.stdinev == rev ) continue;
opal_list_remove_item(&mca_iof_hnp_component.read_events,
item);
/* No need to delete the event, the destructor will automatically
* do it for us.
*/
rev_fd = rev->ev.ev_fd;
OBJ_RELEASE(item);
close(rev_fd);
}
orte_iof_read_event_t* rev;
int rev_fd;
for( item = opal_list_get_first(&mca_iof_hnp_component.read_events);
item != opal_list_get_end(&mca_iof_hnp_component.read_events);
item = next_item ) {
rev = (orte_iof_read_event_t*)item;
next_item = opal_list_get_next(item);
if ((rev->name.jobid == peer->jobid) &&
(rev->name.vpid == peer->vpid) &&
(source_tag & rev->tag) ) {
/* Dont close if it's the main stdin. This will get closed
* in component close.
*/
if( mca_iof_hnp_component.stdinev == rev ) continue;
opal_list_remove_item(&mca_iof_hnp_component.read_events, item);
/* No need to delete the event, the destructor will automatically
* do it for us.
*/
rev_fd = rev->ev.ev_fd;
OBJ_RELEASE(item);
close(rev_fd);
}
}
return ORTE_SUCCESS;
}
@ -370,6 +368,8 @@ static void stdin_write_handler(int fd, short event, void *cbdata)
}
OBJ_RELEASE(output);
}
goto CHECK;
ABORT:
close(wev->fd);
opal_event_del(&wev->ev);

Просмотреть файл

@ -160,36 +160,35 @@ static int orted_pull(const orte_process_name_t* dst_name,
static int orted_close(const orte_process_name_t* peer,
orte_iof_tag_t source_tag)
{
OPAL_THREAD_LOCK(&mca_iof_orted_component.lock);
/* The STDIN have a read event attached, while everything else
* have a sink. We don't have to do anything special for sinks,
* they will dissapear when the output queue is empty.
*/
if( ORTE_IOF_STDIN & source_tag ) {
opal_list_item_t *item, *next_item;
orte_iof_read_event_t* rev;
int rev_fd;
for( item = opal_list_get_first(&mca_iof_orted_component.read_events);
item != opal_list_get_end(&mca_iof_orted_component.read_events);
item = next_item ) {
rev = (orte_iof_read_event_t*)item;
next_item = opal_list_get_next(item);
if( (rev->name.jobid == peer->jobid) &&
(rev->name.vpid == peer->vpid) ) {
opal_list_remove_item(&mca_iof_orted_component.read_events,
item);
/* No need to delete the event, the destructor will automatically
* do it for us.
*/
rev_fd = rev->ev.ev_fd;
OBJ_RELEASE(item);
close(rev_fd);
}
opal_list_item_t *item, *next_item;
orte_iof_read_event_t* rev;
int rev_fd;
OPAL_THREAD_LOCK(&mca_iof_orted_component.lock);
for( item = opal_list_get_first(&mca_iof_orted_component.read_events);
item != opal_list_get_end(&mca_iof_orted_component.read_events);
item = next_item ) {
rev = (orte_iof_read_event_t*)item;
next_item = opal_list_get_next(item);
if ((rev->name.jobid == peer->jobid) &&
(rev->name.vpid == peer->vpid) &&
(source_tag & rev->tag)) {
opal_list_remove_item(&mca_iof_orted_component.read_events, item);
/* No need to delete the event, the destructor will automatically
* do it for us.
*/
rev_fd = rev->ev.ev_fd;
OBJ_RELEASE(item);
close(rev_fd);
}
}
OPAL_THREAD_UNLOCK(&mca_iof_orted_component.lock);
return ORTE_SUCCESS;

Просмотреть файл

@ -1859,8 +1859,7 @@ MOVEON:
child->alive = false;
/* Release the IOF resources related to this child */
orte_iof.close(child->name, (ORTE_IOF_STDIN | ORTE_IOF_STDOUT |
ORTE_IOF_STDERR | ORTE_IOF_STDDIAG) );
orte_iof.close(child->name, ORTE_IOF_STDIN);
/* Clean up the session directory as if we were the process
* itself. This covers the case where the process died abnormally