root/usr/src/uts/sun4u/sys/i2c/clients/pca9556_impl.h
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License, Version 1.0 only
 * (the "License").  You may not use this file except in compliance
 * with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */
/*
 * Copyright 2002 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

#ifndef _PCA9556_IMPL_H
#define _PCA9556_IMPL_H

#pragma ident   "%Z%%M% %I%     %E% SMI"

#ifdef  __cplusplus
extern "C" {
#endif

#include <sys/promif.h>

/*
 * Declarations for debug printing
 */
extern int pca9556_debug;

#define PCA9556_NUM_PORTS       1
#define PCA9555_NUM_PORTS       2
#define PCA9556_NUM_REG         3
#define PCA9556_MAX_REG         6

#define PCA9556_BUSYFLAG        0x1
#define PCA9556_MINORFLAG       0x2
#define PCA9556_TBUFFLAG        0x4
#define PCA9556_REGFLAG         0x8

#define PCA9556_INPUT_REG       0x0
#define PCA9556_OUTPUT_REG      0x1
#define PCA9556_POLARITY_REG    0x2
#define PCA9556_CONFIG_REG      0x3

#define PCA9555_INPUT_REG       0x0
#define PCA9555_OUTPUT_REG      0x2
#define PCA9555_POLARITY_REG    0x4
#define PCA9555_CONFIG_REG      0x6

#define PCA9556_NODE_TYPE       "ddi_i2c:gpio_device"
#define PCA9556_MAX_SIZE        8
#define PCA9556_NAME_LEN        16

typedef struct pca9556_unit {
        dev_info_t              *pca9556_dip;
        i2c_transfer_t          *pca9556_transfer;
        kmutex_t                pca9556_mutex;
        kcondvar_t              pca9556_cv;
        uint8_t                 pca9556_flags;
        i2c_client_hdl_t        pca9556_hdl;
        char                    pca9556_name[PCA9556_NAME_LEN];
        uint16_t                pca9556_oflag;
        uint8_t                 pca9556_cpr_state[PCA9556_MAX_REG];
        boolean_t               pca9555_device;
} pca9556_unit_t;

#ifdef  __cplusplus
}
#endif

#endif /* _PCA9556_IMPL_H */