Source code for spinnman.spalloc.machine_allocation_controller

# Copyright (c) 2017 The University of Manchester
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import logging
import sys
from threading import Thread
from typing import Tuple
from spinn_utilities.log import FormatAdapter
from spinn_utilities.abstract_base import AbstractBase, abstractmethod
logger = FormatAdapter(logging.getLogger(__name__))


class MachineAllocationController(object, metaclass=AbstractBase):
    """
    How to manage the allocation of a machine so that it gets cleaned up
    neatly when the script dies.
    """
    __slots__ = (
        #: Boolean flag for telling this thread when the system has ended
        "_exited",)

    def __init__(self, thread_name: str):
        """
        :param thread_name:
        """
        thread = Thread(name=thread_name, target=self.__manage_allocation)
        thread.daemon = True
        self._exited = False
        thread.start()

[docs] @abstractmethod def extend_allocation(self, new_total_run_time: float) -> None: """ Extend the allocation of the machine from the original run time. :param new_total_run_time: The total run time that is now required starting from when the machine was first allocated """ raise NotImplementedError
[docs] def close(self) -> None: """ Indicate that the use of the machine is complete. """ self._exited = True
@abstractmethod def _wait(self) -> bool: """ Wait for some bounded amount of time for a change in the status of the machine allocation. :return: Whether the machine is still (believed to be) allocated. """ raise NotImplementedError
[docs] @abstractmethod def where_is_machine( self, chip_x: int, chip_y: int) -> Tuple[int, int, int]: """ Locates and returns cabinet, frame, board for a given chip in a machine allocated to this job. :param chip_x: chip x location :param chip_y: chip y location :return: (cabinet, frame, board) """ raise NotImplementedError
def _teardown(self) -> None: """ Perform any extra tear-down that the thread requires. Does not need to be overridden if no action is desired. """ def __manage_allocation(self) -> None: machine_still_allocated = True while machine_still_allocated and not self._exited: machine_still_allocated = self._wait() self._teardown() if not self._exited: logger.error( "The allocated machine has been released before the end of" " the script; this script will now exit") sys.exit(1) @property def proxying(self) -> bool: """ Whether this is a proxying connection. False unless overridden. """ return False