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