summaryrefslogtreecommitdiff
path: root/compiler/ann-ref/src/Operand.h
blob: 870a056449329bdca57247ec4992fb7cdcf67b88 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
 * Copyright (c) 2018 Samsung Electronics Co., Ltd. All Rights Reserved
 * Copyright (C) 2017 The Android Open Source Project
 *
 * 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
 *
 *      http://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.
 */

#ifndef __OPERAND_H__
#define __OPERAND_H__

#include "OperandType.h"

#include <cstdint>
#include <vector>

enum class OperandLifeTime : int32_t {
  TEMPORARY_VARIABLE = 0,
  MODEL_INPUT = 1,
  MODEL_OUTPUT = 2,
  CONSTANT_COPY = 3,
  CONSTANT_REFERENCE = 4,
  NO_VALUE = 5,
};

struct DataLocation final {
  uint32_t poolIndex;
  uint32_t offset;
  uint32_t length;
};

struct Operand final {
  OperandType type;
  float scale;
  int32_t zeroPoint;

  std::vector<uint32_t> dimensions;

  DataLocation location;

  uint32_t numberOfConsumers;
  OperandLifeTime lifetime;
};

// Returns the amount of space needed to store a value of the dimensions and
// type of this operand.
inline uint32_t sizeOfData(const Operand &operand)
{
  return sizeOfData(operand.type, operand.dimensions);
}

#endif // __OPERAND_H__