/* $NetBSD: si470x_reg.h,v 1.1 2013/01/13 01:15:02 jakllsch Exp $ */
/*
* Copyright (c) 2012 Jonathan A. Kollasch
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef _DEV_IC_SI470X_REG_H_
#define _DEV_IC_SI470X_REG_H_
#define __BIT16(x) ((uint16_t)__BIT(x))
#define __BITS16(x, y) ((uint16_t)__BITS((x), (y)))
#define SI470X_DEVICEID 0x00
#define SI470X_PN __BITS16(15, 12)
#define SI470X_MFGID __BITS16(11, 0)
#define SI470X_CHIPID 0x01
#define SI470X_REV __BITS16(15, 10)
#define SI470X_DEV __BITS16(9, 6)
#define SI470X_FIRMWARE __BITS16(5, 0)
#define SI470X_POWERCFG 0x02
#define SI470X_DSMUTE __BIT16(15)
#define SI470X_DMUTE __BIT16(14)
#define SI470X_MONO __BIT16(13)
#define SI470X_RDSM __BIT16(11)
#define SI470X_SKMODE __BIT16(10)
#define SI470X_SEEKUP __BIT16(9)
#define SI470X_SEEK __BIT16(8)
#define SI470X_DISABLE __BIT16(6)
#define SI470X_ENABLE __BIT16(0)
#define SI470X_CHANNEL 0x03
#define SI470X_TUNE __BIT16(15)
#define SI470X_CHAN __BITS16(9, 0)
#define SI470X_SYSCONFIG1 0x04
#define SI470X_RDSIEN __BIT16(15)
#define SI470X_STCIEN __BIT16(14)
#define SI470X_RDS __BIT16(12)
#define SI470X_DE __BIT16(11)
#define SI470X_AGCD __BIT16(10)
#define SI470X_BLNDADJ __BITS16(7, 6)
#define SI470X_GPIO3 __BITS16(5, 4)
#define SI470X_GPIO2 __BITS16(3, 2)
#define SI470X_GPIO1 __BITS16(1, 0)
#define SI470X_SYSCONFIG2 0x05
#define SI470X_SEEKTH __BITS16(15, 8)
#define SI470X_BAND __BITS16(7, 6)
#define SI470X_SPACE __BITS16(5, 4)
#define SI470X_VOLUME __BITS16(3, 0)
#define SI470X_SYSCONFIG3 0x06
#define SI470X_SMUTER __BITS16(15, 14)
#define SI470X_SMUTEA __BITS16(13, 12)
#define SI470X_VOLEXT __BIT16(8)
#define SI470X_SKSNR __BITS16(7, 4)
#define SI470X_SKCNT __BITS16(3, 0)
#define SI470X_TEST1 0x07
#define SI470X_XOSCEN __BIT16(15)
#define SI470X_AHIZEN __BIT16(14)
#define SI470X_TEST2 0x08
#define SI470X_BOOTCONFIG 0x09
#define SI470X_STATUSRSSI 0x0a
#define SI470X_RDSR __BIT16(15)
#define SI470X_STC __BIT16(14)
#define SI470X_SF_BL __BIT16(13)
#define SI470X_AFCRL __BIT16(12)
#define SI470X_RDSS __BIT16(11)
#define SI470X_BLERA __BITS16(9, 10)
#define SI470X_ST __BIT16(8)
#define SI470X_RSSI __BITS16(7, 0)
#define SI470X_READCHANNEL 0x0b
#define SI470X_BLERB __BITS16(15, 14)
#define SI470X_BLERC __BITS16(13, 12)
#define SI470X_BLERD __BITS16(11, 10)
#define SI470X_READCHAN __BITS16(9, 0)
#define SI470X_RDSA 0x0c
#define SI470X_RDSB 0x0d
#define SI470X_RDSC 0x0e
#define SI470X_RDSD 0x0f
#endif /* _DEV_IC_SI470X_REG_H_ */