blob: d51bfa89915b0f37abdd51f1397509a1cb7e28fa [file] [log] [blame]
Yaowu Xuc27fc142016-08-22 16:08:15 -07001/*
Yaowu Xu9c01aa12016-09-01 14:32:49 -07002 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
Yaowu Xuc27fc142016-08-22 16:08:15 -07003 *
Yaowu Xu9c01aa12016-09-01 14:32:49 -07004 * This source code is subject to the terms of the BSD 2 Clause License and
5 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6 * was not distributed with this source code in the LICENSE file, you can
7 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8 * Media Patent License 1.0 was not distributed with this source code in the
9 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
Yaowu Xuc27fc142016-08-22 16:08:15 -070010 */
11
Yaowu Xuf883b422016-08-30 14:01:10 -070012#ifndef AOM_COMMON_MIPS_DSPR2_H_
13#define AOM_COMMON_MIPS_DSPR2_H_
Yaowu Xuc27fc142016-08-22 16:08:15 -070014
15#include <assert.h>
Tom Finegan60e653d2018-05-22 11:34:58 -070016
17#include "config/aom_config.h"
18
Yaowu Xuf883b422016-08-30 14:01:10 -070019#include "aom/aom_integer.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070020
21#ifdef __cplusplus
22extern "C" {
23#endif
24#if HAVE_DSPR2
25#define CROP_WIDTH 512
26
Yaowu Xuf883b422016-08-30 14:01:10 -070027extern uint8_t *aom_ff_cropTbl; // From "aom_dsp/mips/intrapred4_dspr2.c"
Yaowu Xuc27fc142016-08-22 16:08:15 -070028
29static INLINE void prefetch_load(const unsigned char *src) {
30 __asm__ __volatile__("pref 0, 0(%[src]) \n\t" : : [src] "r"(src));
31}
32
33/* prefetch data for store */
34static INLINE void prefetch_store(unsigned char *dst) {
35 __asm__ __volatile__("pref 1, 0(%[dst]) \n\t" : : [dst] "r"(dst));
36}
37
38static INLINE void prefetch_load_streamed(const unsigned char *src) {
39 __asm__ __volatile__("pref 4, 0(%[src]) \n\t" : : [src] "r"(src));
40}
41
42/* prefetch data for store */
43static INLINE void prefetch_store_streamed(unsigned char *dst) {
44 __asm__ __volatile__("pref 5, 0(%[dst]) \n\t" : : [dst] "r"(dst));
45}
46#endif // #if HAVE_DSPR2
47#ifdef __cplusplus
48} // extern "C"
49#endif
50
Yaowu Xuf883b422016-08-30 14:01:10 -070051#endif // AOM_COMMON_MIPS_DSPR2_H_