/*-1* SPDX-License-Identifier: BSD-3-Clause2*3* Copyright 2000, 2001, 2002, 20034* Broadcom Corporation. All rights reserved.5*6* This software is furnished under license and may be used and7* copied only in accordance with the following terms and8* conditions. Subject to these conditions, you may download,9* copy, install, use, modify and distribute modified or unmodified10* copies of this software in source and/or binary form. No title11* or ownership is transferred hereby.12*13* 1) Any source code used, modified or distributed must reproduce and14* retain this copyright notice and list of conditions as they appear in15* the source file.16*17* 2) No right is granted to use any trade name, trademark, or logo of18* Broadcom Corporation. The "Broadcom Corporation" name may not be19* used to endorse or promote products derived from this software20* without the prior written permission of Broadcom Corporation.21*22* 3) THIS SOFTWARE IS PROVIDED "AS-IS" AND ANY EXPRESS OR IMPLIED23* WARRANTIES, INCLUDING BUT NOT LIMITED TO, ANY IMPLIED WARRANTIES OF24* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR25* NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL BROADCOM BE LIABLE26* FOR ANY DAMAGES WHATSOEVER, AND IN PARTICULAR, BROADCOM SHALL NOT BE27* LIABLE FOR DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR28* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF29* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR30* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,31* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE32* OR OTHERWISE), EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.33*/3435/* *********************************************************************36* Broadcom Common Firmware Environment (CFE)37*38* IOCTL definitions File: cfe_ioctl.h39*40* IOCTL function numbers and I/O data structures.41*42* Author: Mitch Lichtenberg43*44********************************************************************* */4546/* *********************************************************************47* NVFAM and FLASH stuff48********************************************************************* */4950#define IOCTL_NVRAM_GETINFO 1 /* return nvram_info_t */51#define IOCTL_NVRAM_ERASE 2 /* erase sector containing nvram_info_t area */52#define IOCTL_FLASH_ERASE_SECTOR 3 /* erase an arbitrary sector */53#define IOCTL_FLASH_ERASE_ALL 4 /* Erase the entire flash */54#define IOCTL_FLASH_WRITE_ALL 5 /* write entire flash */55#define IOCTL_FLASH_GETINFO 6 /* get flash device info */56#define IOCTL_FLASH_GETSECTORS 7 /* get sector information */57#define IOCTL_FLASH_ERASE_RANGE 8 /* erase range of bytes */58#define IOCTL_NVRAM_UNLOCK 9 /* allow r/w beyond logical end of device */59#define IOCTL_FLASH_PROTECT_RANGE 10 /* Protect a group of sectors */60#define IOCTL_FLASH_UNPROTECT_RANGE 11 /* unprotect a group of sectors */61#define IOCTL_FLASH_DATA_WIDTH_MODE 12 /* switch flash and gen bus to support 8 or 16-bit mode I/Os */62#define IOCTL_FLASH_BURST_MODE 13 /* configure gen bus for burst mode */6364typedef struct flash_range_s {65unsigned int range_base;66unsigned int range_length;67} flash_range_t;6869typedef struct flash_info_s {70unsigned long long flash_base; /* flash physical base address */71unsigned int flash_size; /* available device size in bytes */72unsigned int flash_type; /* type, from FLASH_TYPE below */73unsigned int flash_flags; /* Various flags (FLASH_FLAG_xxx) */74} flash_info_t;7576typedef struct flash_sector_s {77int flash_sector_idx;78int flash_sector_status;79unsigned int flash_sector_offset;80unsigned int flash_sector_size;81} flash_sector_t;8283#define FLASH_SECTOR_OK 084#define FLASH_SECTOR_INVALID -18586#define FLASH_TYPE_UNKNOWN 0 /* not sure what kind of flash */87#define FLASH_TYPE_SRAM 1 /* not flash: it's SRAM */88#define FLASH_TYPE_ROM 2 /* not flash: it's ROM */89#define FLASH_TYPE_FLASH 3 /* it's flash memory of some sort */9091#define FLASH_FLAG_NOERASE 1 /* Byte-range writes supported,92Erasing is not necessary */9394typedef struct nvram_info_s {95int nvram_offset; /* offset of environment area */96int nvram_size; /* size of environment area */97int nvram_eraseflg; /* true if we need to erase first */98} nvram_info_t;99100/* *********************************************************************101* Ethernet stuff102********************************************************************* */103104#define IOCTL_ETHER_GETHWADDR 1 /* Get hardware address (6bytes) */105#define IOCTL_ETHER_SETHWADDR 2 /* Set hardware address (6bytes) */106#define IOCTL_ETHER_GETSPEED 3 /* Get Speed and Media (int) */107#define IOCTL_ETHER_SETSPEED 4 /* Set Speed and Media (int) */108#define IOCTL_ETHER_GETLINK 5 /* get link status (int) */109#define IOCTL_ETHER_GETLOOPBACK 7 /* get loopback state */110#define IOCTL_ETHER_SETLOOPBACK 8 /* set loopback state */111#define IOCTL_ETHER_SETPACKETFIFO 9 /* set packet fifo mode (int) */112#define IOCTL_ETHER_SETSTROBESIG 10 /* set strobe signal (int) */113114#define ETHER_LOOPBACK_OFF 0 /* no loopback */115#define ETHER_LOOPBACK_INT 1 /* Internal loopback */116#define ETHER_LOOPBACK_EXT 2 /* External loopback (through PHY) */117118#define ETHER_SPEED_AUTO 0 /* Auto detect */119#define ETHER_SPEED_UNKNOWN 0 /* Speed not known (on link status) */120#define ETHER_SPEED_10HDX 1 /* 10MB hdx and fdx */121#define ETHER_SPEED_10FDX 2122#define ETHER_SPEED_100HDX 3 /* 100MB hdx and fdx */123#define ETHER_SPEED_100FDX 4124#define ETHER_SPEED_1000HDX 5 /* 1000MB hdx and fdx */125#define ETHER_SPEED_1000FDX 6126127#define ETHER_FIFO_8 0 /* 8-bit packet fifo mode */128#define ETHER_FIFO_16 1 /* 16-bit packet fifo mode */129#define ETHER_ETHER 2 /* Standard ethernet mode */130131#define ETHER_STROBE_GMII 0 /* GMII style strobe signal */132#define ETHER_STROBE_ENCODED 1 /* Encoded */133#define ETHER_STROBE_SOP 2 /* SOP flagged. Only in 8-bit mode*/134#define ETHER_STROBE_EOP 3 /* EOP flagged. Only in 8-bit mode*/135136/* *********************************************************************137* Serial Ports138********************************************************************* */139140#define IOCTL_SERIAL_SETSPEED 1 /* get baud rate (int) */141#define IOCTL_SERIAL_GETSPEED 2 /* set baud rate (int) */142#define IOCTL_SERIAL_SETFLOW 3 /* Set Flow Control */143#define IOCTL_SERIAL_GETFLOW 4 /* Get Flow Control */144145#define SERIAL_FLOW_NONE 0 /* no flow control */146#define SERIAL_FLOW_SOFTWARE 1 /* software flow control (not impl) */147#define SERIAL_FLOW_HARDWARE 2 /* hardware flow control */148149/* *********************************************************************150* Block device stuff151********************************************************************* */152153#define IOCTL_BLOCK_GETBLOCKSIZE 1 /* get block size (int) */154#define IOCTL_BLOCK_GETTOTALBLOCKS 2 /* get total bocks (long long) */155#define IOCTL_BLOCK_GETDEVTYPE 3 /* get device type (struct) */156157typedef struct blockdev_info_s {158unsigned long long blkdev_totalblocks;159unsigned int blkdev_blocksize;160unsigned int blkdev_devtype;161} blockdev_info_t;162163#define BLOCK_DEVTYPE_DISK 0164#define BLOCK_DEVTYPE_CDROM 1165166167