android13/u-boot/cmd/ddr_tool/stressapptest/stressapptest.h

71 lines
1.8 KiB
C

/* Copyright 2006 Google Inc. All Rights Reserved. */
/* 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.
*/
/* This is stressapptest for Rockchip platform in U-Boot, the design idea and
* the patterns are from code.google.com/p/stressapptest.
*/
#ifndef __CMD_DDR_TOOL_STRESSAPPTEST_STRESSAPPTEST_H
#define __CMD_DDR_TOOL_STRESSAPPTEST_STRESSAPPTEST_H
struct stressapptest_params {
ulong total_start_addr;
ulong total_test_size_mb;
/* total_test_size = page_size * page_num */
ulong page_size_byte;
u32 page_num;
/* page_size = block_size * block_num */
u32 block_size_byte;
u32 block_num;
u32 weight_count;
u8 cpu_num;
} sat;
struct pat {
const char *name;
const unsigned int *data_array;
/* mask = size - 1, So data_array[index & mask] is always valid. */
const unsigned int mask;
const unsigned int weight[4]; /* Weighted frequency of this pattern. */
};
struct adler_sum {
u64 a1;
u64 b1;
u64 a2;
u64 b2;
};
struct pattern {
struct pat *pat;
bool inv;
u32 repeat;
u32 weight;
struct adler_sum adler_sum;
};
struct page {
void *base_addr;
struct pattern *pattern;
bool valid; /* 1: valid, 0: empty */
} *page_list;
extern void secondary_init(void);
extern void lock_byte_mutex(u32 *flag);
extern u32 unlock_byte_mutex(u32 *flag);
#endif /* __CMD_DDR_TOOL_STRESSAPPTEST_STRESSAPPTEST_H */