/* * Copyright 2013-2019 Software Radio Systems Limited * * This file is part of srsLTE. * * srsLTE is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * srsLTE is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * A copy of the GNU Affero General Public License can be found in * the LICENSE file in the top-level directory of this distribution * and at http://www.gnu.org/licenses/. * */ #ifndef SRSLTE_TTI_POINT_H #define SRSLTE_TTI_POINT_H #include "logmap.h" #include #include namespace srslte { struct tti_point { constexpr tti_point() = default; explicit tti_point(uint32_t tti_val_) : tti_val(tti_val_ % 10240) { if (tti_val_ > std::numeric_limits::max() / 2) { // there was a overflow at tti initialization uint32_t diff = std::numeric_limits::max() - tti_val_; if (diff < 10240) { tti_val = 10240 - diff - 1; } else { srslte::logmap::get("COMMON")->error("Invalid TTI point assigned\n"); } } } void reset() { tti_val = std::numeric_limits::max(); } uint32_t sf_idx() const { return tti_val % 10; } uint32_t sfn() const { return tti_val / 10; } // comparison operators bool operator==(const tti_point& other) const { return tti_val == other.tti_val; } bool operator!=(const tti_point& other) const { return tti_val != other.tti_val; } bool operator<(const tti_point& other) const { bool lower_val = tti_val < other.tti_val; bool wrap_flag = (lower_val ? other.tti_val - tti_val : tti_val - other.tti_val) > 10240 / 2; return (lower_val != wrap_flag); } bool operator<=(const tti_point& other) const { return *this == other or *this < other; } bool operator>(const tti_point& other) const { return not(*this <= other); } bool operator>=(const tti_point& other) const { return not(*this < other); } // add/subtract int operator-(const tti_point& other) const { int diff = static_cast(tti_val) - static_cast(other.tti_val); if (diff > 10240 / 2) { return diff - 10240; } if (diff < -10240 / 2) { return diff + 10240; } return diff; } tti_point& operator+=(uint32_t jump) { tti_val = (tti_val + jump) % 10240; return *this; } tti_point& operator-=(uint32_t jump) { tti_val -= jump - ((tti_val < jump) ? 10240 : 0); return *this; } tti_point& operator++() { return this->operator+=(1); } tti_point operator++(int) { tti_point ret{tti_val}; this-> operator+=(1); return ret; } bool is_valid() const { return tti_val < 10240; } explicit operator uint32_t() const { return tti_val; } uint32_t to_uint() const { return tti_val; } bool is_in_interval(tti_point l, tti_point u) const { return (*this >= l and *this <= u); } private: uint32_t tti_val = std::numeric_limits::max(); }; inline tti_point operator+(tti_point tti, uint32_t jump) { return tti_point{(uint32_t)tti + jump}; } inline tti_point operator+(uint32_t jump, tti_point tti) { return tti_point{(uint32_t)tti + jump}; } inline tti_point operator-(tti_point tti, uint32_t jump) { return tti_point{(uint32_t)tti + 10240 - jump}; } inline tti_point max(tti_point tti1, tti_point tti2) { return tti1 > tti2 ? tti1 : tti2; } inline tti_point min(tti_point tti1, tti_point tti2) { return tti1 < tti2 ? tti1 : tti2; } } // namespace srslte #endif // SRSLTE_TTI_POINT_H