org.nd4j.jita.allocator.concurrency.Lock Maven / Gradle / Ivy
/*
* ******************************************************************************
* *
* *
* * This program and the accompanying materials are made available under the
* * terms of the Apache License, Version 2.0 which is available at
* * https://www.apache.org/licenses/LICENSE-2.0.
* *
* * See the NOTICE file distributed with this work for additional
* * information regarding copyright ownership.
* * 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.
* *
* * SPDX-License-Identifier: Apache-2.0
* *****************************************************************************
*/
package org.nd4j.jita.allocator.concurrency;
import org.nd4j.jita.allocator.impl.AllocationShape;
/**
* Collection of multilevel locks for JITA
*
* @author [email protected]
*/
public interface Lock {
/**
* This method notifies locker, that specific object was added to tracking list
* @param object
*/
void attachObject(Object object);
/**
* This method notifies locker that specific object was removed from tracking list
* @param object
*/
void detachObject(Object object);
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//// Global-level locks
/**
* This method acquires global-level read lock
*/
void globalReadLock();
/**
* This method releases global-level read lock
*/
void globalReadUnlock();
/**
* This method acquires global-level write lock
*/
void globalWriteLock();
/**
* This method releases global-level write lock
*/
void globalWriteUnlock();
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//// Object-level locks
/**
* This method acquires object-level read lock, and global-level read lock
* @param object
*/
void objectReadLock(Object object);
/**
* This method releases object-level read lock, and global-level read lock
* @param object
*/
void objectReadUnlock(Object object);
/**
* This method acquires object-level write lock, and global-level read lock
* @param object
*/
void objectWriteLock(Object object);
/**
* This method releases object-level read lock, and global-level read lock
* @param object
*/
void objectWriteUnlock(Object object);
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//// Shape-level locks
/**
* This method acquires shape-level read lock, and read locks for object and global
* @param object
* @param shape
*/
void shapeReadLock(Object object, AllocationShape shape);
/**
* This method releases shape-level read lock, and read locks for object and global
* @param object
* @param shape
*/
void shapeReadUnlock(Object object, AllocationShape shape);
/**
* This method acquires shape-level write lock, and read locks for object and global
* @param object
* @param shape
*/
void shapeWriteLock(Object object, AllocationShape shape);
/**
* This method releases shape-level write lock, and read locks for object and global
* @param object
* @param shape
*/
void shapeWriteUnlock(Object object, AllocationShape shape);
/**
* This methods acquires read-lock on externals, and read-lock on global
*/
void externalsReadLock();
/**
* This methods releases read-lock on externals, and read-lock on global
*/
void externalsReadUnlock();
/**
* This methods acquires write-lock on externals, and read-lock on global
*/
void externalsWriteLock();
/**
* This methods releases write-lock on externals, and read-lock on global
*/
void externalsWriteUnlock();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy