/*
* Copyright (c) 2016, Oracle and/or its affiliates.
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are
* permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or other materials provided
* with the distribution.
*
* 3. Neither the name of the copyright holder nor the names of its contributors may be used to
* endorse or promote products derived from this software without specific prior written
* permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package com.oracle.truffle.llvm.parser.model.enums;
public enum AtomicOrdering {
NOT_ATOMIC(0L, ""),
UNORDERED(1L, "unordered"),
MONOTONIC(2L, "monotonic"),
ACQUIRE(3L, "acquire"),
RELEASE(4L, "release"),
ACQUIRE_RELEASE(5L, "acq_rel"),
SEQUENTIALLY_CONSISTENT(6L, "seq_cst");
private final long encodedValue;
private final String irString;
AtomicOrdering(long encodeValue, String irString) {
this.encodedValue = encodeValue;
this.irString = irString;
}
public long getEncodedValue() {
return encodedValue;
}
/**
* Useful to get the llvm ir equivalent string of the enum.
*/
public String getIrString() {
return irString;
}
public static AtomicOrdering decode(long id) {
for (AtomicOrdering atomicOrdering : values()) {
if (atomicOrdering.getEncodedValue() == id) {
return atomicOrdering;
}
}
return SEQUENTIALLY_CONSISTENT;
}
public static AtomicOrdering getOrStrongestFailureOrdering(long id, AtomicOrdering successOrdering) {
for (AtomicOrdering atomicOrdering : values()) {
if (atomicOrdering.getEncodedValue() == id) {
return atomicOrdering;
}
}
switch (successOrdering) {
case RELEASE:
case MONOTONIC:
return MONOTONIC;
case ACQUIRE_RELEASE:
case ACQUIRE:
return ACQUIRE;
case SEQUENTIALLY_CONSISTENT:
return SEQUENTIALLY_CONSISTENT;
default:
throw new AssertionError("Invalid SuccessOrdering: " + successOrdering);
}
}
}