blob: a3a5911e36409ad84b8bf7fedcb5e1c1b07576be [file] [log] [blame]
andrew@webrtc.org325cff02014-10-01 17:42:18 +00001/*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef WEBRTC_SYSTEM_WRAPPERS_INTERFACE_ALIGNED_ARRAY_
12#define WEBRTC_SYSTEM_WRAPPERS_INTERFACE_ALIGNED_ARRAY_
13
14#include "webrtc/base/checks.h"
Henrik Kjellander98f53512015-10-28 18:17:40 +010015#include "webrtc/system_wrappers/include/aligned_malloc.h"
andrew@webrtc.org325cff02014-10-01 17:42:18 +000016
17namespace webrtc {
18
19// Wrapper class for aligned arrays. Every row (and the first dimension) are
20// aligned to the given byte alignment.
21template<typename T> class AlignedArray {
22 public:
Peter Kastingdce40cf2015-08-24 14:52:23 -070023 AlignedArray(int rows, size_t cols, int alignment)
andrew@webrtc.org325cff02014-10-01 17:42:18 +000024 : rows_(rows),
25 cols_(cols),
26 alignment_(alignment) {
henrikg91d6ede2015-09-17 00:24:34 -070027 RTC_CHECK_GT(alignment_, 0);
andrew@webrtc.org325cff02014-10-01 17:42:18 +000028 head_row_ = static_cast<T**>(AlignedMalloc(rows_ * sizeof(*head_row_),
29 alignment_));
30 for (int i = 0; i < rows_; ++i) {
31 head_row_[i] = static_cast<T*>(AlignedMalloc(cols_ * sizeof(**head_row_),
32 alignment_));
33 }
34 }
35
36 ~AlignedArray() {
37 for (int i = 0; i < rows_; ++i) {
38 AlignedFree(head_row_[i]);
39 }
40 AlignedFree(head_row_);
41 }
42
43 T* const* Array() {
44 return head_row_;
45 }
46
47 const T* const* Array() const {
48 return head_row_;
49 }
50
51 T* Row(int row) {
henrikg91d6ede2015-09-17 00:24:34 -070052 RTC_CHECK_LE(row, rows_);
andrew@webrtc.org325cff02014-10-01 17:42:18 +000053 return head_row_[row];
54 }
55
56 const T* Row(int row) const {
henrikg91d6ede2015-09-17 00:24:34 -070057 RTC_CHECK_LE(row, rows_);
andrew@webrtc.org325cff02014-10-01 17:42:18 +000058 return head_row_[row];
59 }
60
Peter Kastingdce40cf2015-08-24 14:52:23 -070061 T& At(int row, size_t col) {
henrikg91d6ede2015-09-17 00:24:34 -070062 RTC_CHECK_LE(col, cols_);
andrew@webrtc.org325cff02014-10-01 17:42:18 +000063 return Row(row)[col];
64 }
65
Peter Kastingdce40cf2015-08-24 14:52:23 -070066 const T& At(int row, size_t col) const {
henrikg91d6ede2015-09-17 00:24:34 -070067 RTC_CHECK_LE(col, cols_);
andrew@webrtc.org325cff02014-10-01 17:42:18 +000068 return Row(row)[col];
69 }
70
Henrik Kjellandere8d191f2015-06-20 20:10:57 +020071 int rows() const {
72 return rows_;
73 }
74
Peter Kastingdce40cf2015-08-24 14:52:23 -070075 size_t cols() const {
Henrik Kjellandere8d191f2015-06-20 20:10:57 +020076 return cols_;
77 }
78
andrew@webrtc.org325cff02014-10-01 17:42:18 +000079 private:
80 int rows_;
Peter Kastingdce40cf2015-08-24 14:52:23 -070081 size_t cols_;
andrew@webrtc.org325cff02014-10-01 17:42:18 +000082 int alignment_;
83 T** head_row_;
84};
85
86} // namespace webrtc
87
88#endif // WEBRTC_SYSTEM_WRAPPERS_INTERFACE_ALIGNED_ARRAY_