^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) * This file is provided under a dual BSD/GPLv2 license. When using or
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * redistributing this file, you may do so under either license.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) * GPL LICENSE SUMMARY
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) * This program is free software; you can redistribute it and/or modify
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) * it under the terms of version 2 of the GNU General Public License as
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) * published by the Free Software Foundation.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) * This program is distributed in the hope that it will be useful, but
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) * WITHOUT ANY WARRANTY; without even the implied warranty of
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) * General Public License for more details.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) * You should have received a copy of the GNU General Public License
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) * along with this program; if not, write to the Free Software
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) * Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) * The full GNU General Public License is included in this distribution
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) * in the file called LICENSE.GPL.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) * BSD LICENSE
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) * All rights reserved.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) * Redistribution and use in source and binary forms, with or without
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) * modification, are permitted provided that the following conditions
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) * are met:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) * * Redistributions of source code must retain the above copyright
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) * notice, this list of conditions and the following disclaimer.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) * * Redistributions in binary form must reproduce the above copyright
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) * notice, this list of conditions and the following disclaimer in
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) * the documentation and/or other materials provided with the
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) * distribution.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) * * Neither the name of Intel Corporation nor the names of its
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) * contributors may be used to endorse or promote products derived
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) * from this software without specific prior written permission.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) #ifndef _SCI_SAS_H_
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) #define _SCI_SAS_H_
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) #include <linux/kernel.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) * SATA FIS Types These constants depict the various SATA FIS types devined in
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) * the serial ATA specification.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) * XXX: This needs to go into <scsi/sas.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) #define FIS_REGH2D 0x27
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) #define FIS_REGD2H 0x34
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) #define FIS_SETDEVBITS 0xA1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) #define FIS_DMA_ACTIVATE 0x39
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) #define FIS_DMA_SETUP 0x41
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) #define FIS_BIST_ACTIVATE 0x58
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) #define FIS_PIO_SETUP 0x5F
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) #define FIS_DATA 0x46
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) /**************************************************************************/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) #define SSP_RESP_IU_MAX_SIZE 280
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) * contents of the SSP COMMAND INFORMATION UNIT.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80) * For specific information on each of these individual fields please
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) * reference the SAS specification SSP transport layer section.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82) * XXX: This needs to go into <scsi/sas.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84) struct ssp_cmd_iu {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85) u8 LUN[8];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86) u8 add_cdb_len:6;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) u8 _r_a:2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88) u8 _r_b;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89) u8 en_fburst:1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90) u8 task_prio:4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 91) u8 task_attr:3;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 92) u8 _r_c;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 93)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 94) u8 cdb[16];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 95) } __packed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 96)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 97) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 98) * contents of the SSP TASK INFORMATION UNIT.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 99) * For specific information on each of these individual fields please
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 100) * reference the SAS specification SSP transport layer section.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 101) * XXX: This needs to go into <scsi/sas.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 102) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 103) struct ssp_task_iu {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 104) u8 LUN[8];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 105) u8 _r_a;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 106) u8 task_func;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 107) u8 _r_b[4];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 108) u16 task_tag;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 109) u8 _r_c[12];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 110) } __packed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 111)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 112)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 113) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 114) * struct smp_req_phy_id - This structure defines the contents of
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 115) * an SMP Request that is comprised of the struct smp_request_header and a
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 116) * phy identifier.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 117) * Examples: SMP_REQUEST_DISCOVER, SMP_REQUEST_REPORT_PHY_SATA.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 118) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 119) * For specific information on each of these individual fields please reference
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 120) * the SAS specification.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 121) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 122) struct smp_req_phy_id {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 123) u8 _r_a[4]; /* bytes 4-7 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 124)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 125) u8 ign_zone_grp:1; /* byte 8 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 126) u8 _r_b:7;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 127)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 128) u8 phy_id; /* byte 9 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 129) u8 _r_c; /* byte 10 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 130) u8 _r_d; /* byte 11 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 131) } __packed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 132)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 133) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 134) * struct smp_req_config_route_info - This structure defines the
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 135) * contents of an SMP Configure Route Information request.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 136) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 137) * For specific information on each of these individual fields please reference
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 138) * the SAS specification.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 139) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 140) struct smp_req_conf_rtinfo {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 141) u16 exp_change_cnt; /* bytes 4-5 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 142) u8 exp_rt_idx_hi; /* byte 6 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 143) u8 exp_rt_idx; /* byte 7 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 144)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 145) u8 _r_a; /* byte 8 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 146) u8 phy_id; /* byte 9 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 147) u16 _r_b; /* bytes 10-11 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 148)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 149) u8 _r_c:7; /* byte 12 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 150) u8 dis_rt_entry:1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 151) u8 _r_d[3]; /* bytes 13-15 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 152)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 153) u8 rt_sas_addr[8]; /* bytes 16-23 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 154) u8 _r_e[16]; /* bytes 24-39 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 155) } __packed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 156)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 157) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 158) * struct smp_req_phycntl - This structure defines the contents of an
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 159) * SMP Phy Controller request.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 160) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 161) * For specific information on each of these individual fields please reference
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 162) * the SAS specification.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 163) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 164) struct smp_req_phycntl {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 165) u16 exp_change_cnt; /* byte 4-5 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 166)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 167) u8 _r_a[3]; /* bytes 6-8 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 168)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 169) u8 phy_id; /* byte 9 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 170) u8 phy_op; /* byte 10 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 171)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 172) u8 upd_pathway:1; /* byte 11 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 173) u8 _r_b:7;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 174)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 175) u8 _r_c[12]; /* byte 12-23 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 176)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 177) u8 att_dev_name[8]; /* byte 24-31 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 178)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 179) u8 _r_d:4; /* byte 32 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 180) u8 min_linkrate:4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 181)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 182) u8 _r_e:4; /* byte 33 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 183) u8 max_linkrate:4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 184)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 185) u8 _r_f[2]; /* byte 34-35 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 186)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 187) u8 pathway:4; /* byte 36 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 188) u8 _r_g:4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 189)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 190) u8 _r_h[3]; /* bytes 37-39 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 191) } __packed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 192)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 193) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 194) * struct smp_req - This structure simply unionizes the existing request
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 195) * structures into a common request type.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 196) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 197) * XXX: This data structure may need to go to scsi/sas.h
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 198) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 199) struct smp_req {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 200) u8 type; /* byte 0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 201) u8 func; /* byte 1 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 202) u8 alloc_resp_len; /* byte 2 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 203) u8 req_len; /* byte 3 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 204) u8 req_data[];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 205) } __packed;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 206)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 207) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 208) * struct sci_sas_address - This structure depicts how a SAS address is
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 209) * represented by SCI.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 210) * XXX convert this to u8 [SAS_ADDR_SIZE] like the rest of libsas
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 211) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 212) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 213) struct sci_sas_address {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 214) u32 high;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 215) u32 low;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 216) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 217) #endif