Chameleon

Chameleon Svn Source Tree

Root/branches/cparm/i386/libsaio/nbp_cmd.h

1/*
2 * Copyright (c) 1999-2003 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * Portions Copyright (c) 1999-2003 Apple Computer, Inc. All Rights
7 * Reserved. This file contains Original Code and/or Modifications of
8 * Original Code as defined in and that are subject to the Apple Public
9 * Source License Version 2.0 (the "License"). You may not use this file
10 * except in compliance with the License. Please obtain a copy of the
11 * License at http://www.apple.com/publicsource and read it before using
12 * this file.
13 *
14 * The Original Code and all software distributed under the License are
15 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
16 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
17 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT. Please see the
19 * License for the specific language governing rights and limitations
20 * under the License.
21 *
22 * @APPLE_LICENSE_HEADER_END@
23 */
24
25#ifndef __LIBSAIO_NBP_CMD_H
26#define __LIBSAIO_NBP_CMD_H
27
28#include <IOKit/IOTypes.h>
29/*==========================================================================
30 * NBP return status codes.
31 */
32typedef enum {
33 nbpStatusSuccess = 0,
34 nbpStatusFailed,
35nbpStatusInvalid,
36} nbpStatus_t;
37
38/*==========================================================================
39 * NBP commands codes.
40 */
41typedef enum {
42 nbpCommandTFTPReadFile = 1,
43 nbpCommandTFTPGetFileSize,
44 nbpCommandUnloadBaseCode,
45} nbpCommandCode_t;
46
47/*==========================================================================
48 * NBP commands.
49 */
50typedef struct {
51 UInt32 status; /* return code from NBP */
52} nbpCommandHeader_s;
53
54typedef struct {
55 UInt32 status; /* return code from NBP */
56 UInt8 filename[128]; /* name of file to be downloaded */
57 UInt32 bufferSize; /* size of the download buffer */
58 UInt32 buffer; /* physical address of the download buffer */
59} nbpCommandTFTPReadFile_s;
60
61typedef struct {
62 UInt32 status; /* return code from NBP */
63 UInt8 filename[128]; /* name of file to be downloaded */
64 UInt32 filesize; /* size of the file specified */
65} nbpCommandTFTPGetFileSize_s;
66
67typedef struct {
68 UInt32 status; /* return code from NBP */
69 UInt8 sname[64]; /* server name */
70 UInt32 CIP; /* client IP address */
71 UInt32 SIP; /* server IP address */
72 UInt32 GIP; /* gateway IP address */
73} nbpCommandGetNetworkInfo_s;
74
75/*==========================================================================
76 * An union of all NBP command structures.
77 */
78typedef union {
79nbpCommandHeader_s header;
80nbpCommandTFTPReadFile_s tftpReadFile;
81nbpCommandTFTPGetFileSize_s tftpFileSize;
82} nbpCommand_u;
83#endif /* !__LIBSAIO_NBP_CMD_H */
84

Archive Download this file

Revision: 2006