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