1ad30f8e7SGabor Kovesdan /* $NetBSD: citrus_mapper_std_file.h,v 1.3 2006/09/09 14:35:17 tnozaki Exp $ */ 2ad30f8e7SGabor Kovesdan 3ad30f8e7SGabor Kovesdan /*- 4*5e53a4f9SPedro F. Giffuni * SPDX-License-Identifier: BSD-2-Clause 5*5e53a4f9SPedro F. Giffuni * 6ad30f8e7SGabor Kovesdan * Copyright (c)2003, 2006 Citrus Project, 7ad30f8e7SGabor Kovesdan * All rights reserved. 8ad30f8e7SGabor Kovesdan * 9ad30f8e7SGabor Kovesdan * Redistribution and use in source and binary forms, with or without 10ad30f8e7SGabor Kovesdan * modification, are permitted provided that the following conditions 11ad30f8e7SGabor Kovesdan * are met: 12ad30f8e7SGabor Kovesdan * 1. Redistributions of source code must retain the above copyright 13ad30f8e7SGabor Kovesdan * notice, this list of conditions and the following disclaimer. 14ad30f8e7SGabor Kovesdan * 2. Redistributions in binary form must reproduce the above copyright 15ad30f8e7SGabor Kovesdan * notice, this list of conditions and the following disclaimer in the 16ad30f8e7SGabor Kovesdan * documentation and/or other materials provided with the distribution. 17ad30f8e7SGabor Kovesdan * 18ad30f8e7SGabor Kovesdan * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 19ad30f8e7SGabor Kovesdan * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20ad30f8e7SGabor Kovesdan * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21ad30f8e7SGabor Kovesdan * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 22ad30f8e7SGabor Kovesdan * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 23ad30f8e7SGabor Kovesdan * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 24ad30f8e7SGabor Kovesdan * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 25ad30f8e7SGabor Kovesdan * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26ad30f8e7SGabor Kovesdan * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27ad30f8e7SGabor Kovesdan * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28ad30f8e7SGabor Kovesdan * SUCH DAMAGE. 29ad30f8e7SGabor Kovesdan */ 30ad30f8e7SGabor Kovesdan 31ad30f8e7SGabor Kovesdan #ifndef _CITRUS_MAPPER_STD_FILE_H_ 32ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_FILE_H_ 33ad30f8e7SGabor Kovesdan 34ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_MAGIC "MAPPER\0\0" 35ad30f8e7SGabor Kovesdan 36ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_SYM_TYPE "type" 37ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_SYM_INFO "info" 38ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_SYM_TABLE "table" 39ad30f8e7SGabor Kovesdan 40ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_TYPE_ROWCOL "rowcol" 41ad30f8e7SGabor Kovesdan struct _citrus_mapper_std_rowcol_info_x { 42ad30f8e7SGabor Kovesdan uint32_t rcx_src_rowcol_bits; 43ad30f8e7SGabor Kovesdan uint32_t rcx_dst_invalid; 44ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_ROWCOL_MAX 4 45ad30f8e7SGabor Kovesdan struct { 46ad30f8e7SGabor Kovesdan uint32_t begin; 47ad30f8e7SGabor Kovesdan uint32_t end; 48ad30f8e7SGabor Kovesdan } __packed rcx_src_rowcol[_CITRUS_MAPPER_STD_ROWCOL_MAX]; 49ad30f8e7SGabor Kovesdan uint32_t rcx_dst_unit_bits; 50ad30f8e7SGabor Kovesdan uint32_t rcx_src_rowcol_len; 51ad30f8e7SGabor Kovesdan } __packed; 52ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_ROWCOL_INFO_SIZE 48 53ad30f8e7SGabor Kovesdan 54ad30f8e7SGabor Kovesdan /* old file layout */ 55ad30f8e7SGabor Kovesdan struct _citrus_mapper_std_rowcol_info_compat_x { 56ad30f8e7SGabor Kovesdan uint32_t rcx_src_col_bits; 57ad30f8e7SGabor Kovesdan uint32_t rcx_dst_invalid; 58ad30f8e7SGabor Kovesdan uint32_t rcx_src_row_begin; 59ad30f8e7SGabor Kovesdan uint32_t rcx_src_row_end; 60ad30f8e7SGabor Kovesdan uint32_t rcx_src_col_begin; 61ad30f8e7SGabor Kovesdan uint32_t rcx_src_col_end; 62ad30f8e7SGabor Kovesdan uint32_t rcx_dst_unit_bits; 63ad30f8e7SGabor Kovesdan uint32_t rcx_pad; 64ad30f8e7SGabor Kovesdan } __packed; 65ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_ROWCOL_INFO_COMPAT_SIZE 32 66ad30f8e7SGabor Kovesdan 67ad30f8e7SGabor Kovesdan /* rowcol oob extension info */ 68ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_SYM_ROWCOL_EXT_ILSEQ "rowcol_ext_ilseq" 69ad30f8e7SGabor Kovesdan struct _citrus_mapper_std_rowcol_ext_ilseq_info_x { 70ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_OOB_NONIDENTICAL 0 71ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_OOB_ILSEQ 1 72ad30f8e7SGabor Kovesdan uint32_t eix_oob_mode; 73ad30f8e7SGabor Kovesdan uint32_t eix_dst_ilseq; 74ad30f8e7SGabor Kovesdan } __packed; 75ad30f8e7SGabor Kovesdan #define _CITRUS_MAPPER_STD_ROWCOL_EXT_ILSEQ_SIZE 8 76ad30f8e7SGabor Kovesdan 77ad30f8e7SGabor Kovesdan #endif 78