mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-18 02:46:06 +00:00
023b915e1f
Based on 1 normalized pattern(s): driver is free software you can redistribute it and or modify it under the terms of the gnu general public license as published by the free software foundation version 2 the [audiowerk2] [alsa] driver is distributed in the hope that it will be useful but without any warranty without even the implied warranty of merchantability or fitness for a particular purpose see the gnu general public license for more details you should have received a copy of the gnu general public license along with the [audiowerk2] [alsa] driver if not write to the free software foundation inc 51 franklin street fifth floor boston ma 02110 1301 usa extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 5 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Enrico Weigelt <info@metux.net> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190604081201.505559553@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
98 lines
3.3 KiB
C
98 lines
3.3 KiB
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*****************************************************************************
|
|
*
|
|
* Copyright (C) 2008 Cedric Bregardis <cedric.bregardis@free.fr> and
|
|
* Jean-Christian Hassler <jhassler@free.fr>
|
|
* Copyright 1998 Emagic Soft- und Hardware GmbH
|
|
* Copyright 2002 Martijn Sipkema
|
|
*
|
|
* This file is part of the Audiowerk2 ALSA driver
|
|
*
|
|
*****************************************************************************/
|
|
|
|
#define TSL_WS0 (1UL << 31)
|
|
#define TSL_WS1 (1UL << 30)
|
|
#define TSL_WS2 (1UL << 29)
|
|
#define TSL_WS3 (1UL << 28)
|
|
#define TSL_WS4 (1UL << 27)
|
|
#define TSL_DIS_A1 (1UL << 24)
|
|
#define TSL_SDW_A1 (1UL << 23)
|
|
#define TSL_SIB_A1 (1UL << 22)
|
|
#define TSL_SF_A1 (1UL << 21)
|
|
#define TSL_LF_A1 (1UL << 20)
|
|
#define TSL_BSEL_A1 (1UL << 17)
|
|
#define TSL_DOD_A1 (1UL << 15)
|
|
#define TSL_LOW_A1 (1UL << 14)
|
|
#define TSL_DIS_A2 (1UL << 11)
|
|
#define TSL_SDW_A2 (1UL << 10)
|
|
#define TSL_SIB_A2 (1UL << 9)
|
|
#define TSL_SF_A2 (1UL << 8)
|
|
#define TSL_LF_A2 (1UL << 7)
|
|
#define TSL_BSEL_A2 (1UL << 4)
|
|
#define TSL_DOD_A2 (1UL << 2)
|
|
#define TSL_LOW_A2 (1UL << 1)
|
|
#define TSL_EOS (1UL << 0)
|
|
|
|
/* Audiowerk8 hardware setup: */
|
|
/* WS0, SD4, TSL1 - Analog/ digital in */
|
|
/* WS1, SD0, TSL1 - Analog out #1, digital out */
|
|
/* WS2, SD2, TSL1 - Analog out #2 */
|
|
/* WS3, SD1, TSL2 - Analog out #3 */
|
|
/* WS4, SD3, TSL2 - Analog out #4 */
|
|
|
|
/* Audiowerk8 timing: */
|
|
/* Timeslot: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | ... */
|
|
|
|
/* A1_INPUT: */
|
|
/* SD4: <_ADC-L_>-------<_ADC-R_>-------< */
|
|
/* WS0: _______________/---------------\_ */
|
|
|
|
/* A1_OUTPUT: */
|
|
/* SD0: <_1-L___>-------<_1-R___>-------< */
|
|
/* WS1: _______________/---------------\_ */
|
|
/* SD2: >-------<_2-L___>-------<_2-R___> */
|
|
/* WS2: -------\_______________/--------- */
|
|
|
|
/* A2_OUTPUT: */
|
|
/* SD1: <_3-L___>-------<_3-R___>-------< */
|
|
/* WS3: _______________/---------------\_ */
|
|
/* SD3: >-------<_4-L___>-------<_4-R___> */
|
|
/* WS4: -------\_______________/--------- */
|
|
|
|
static int tsl1[8] = {
|
|
1 * TSL_SDW_A1 | 3 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1 | TSL_LF_A1,
|
|
|
|
1 * TSL_SDW_A1 | 2 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1,
|
|
|
|
0 * TSL_SDW_A1 | 3 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1,
|
|
|
|
0 * TSL_SDW_A1 | 2 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1,
|
|
|
|
1 * TSL_SDW_A1 | 1 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1 | TSL_WS1 | TSL_WS0,
|
|
|
|
1 * TSL_SDW_A1 | 0 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1 | TSL_WS1 | TSL_WS0,
|
|
|
|
0 * TSL_SDW_A1 | 1 * TSL_BSEL_A1 |
|
|
0 * TSL_DIS_A1 | 0 * TSL_DOD_A1 | TSL_WS1 | TSL_WS0,
|
|
|
|
0 * TSL_SDW_A1 | 0 * TSL_BSEL_A1 | 0 * TSL_DIS_A1 |
|
|
0 * TSL_DOD_A1 | TSL_WS1 | TSL_WS0 | TSL_SF_A1 | TSL_EOS,
|
|
};
|
|
|
|
static int tsl2[8] = {
|
|
0 * TSL_SDW_A2 | 3 * TSL_BSEL_A2 | 2 * TSL_DOD_A2 | TSL_LF_A2,
|
|
0 * TSL_SDW_A2 | 2 * TSL_BSEL_A2 | 2 * TSL_DOD_A2,
|
|
0 * TSL_SDW_A2 | 3 * TSL_BSEL_A2 | 2 * TSL_DOD_A2,
|
|
0 * TSL_SDW_A2 | 2 * TSL_BSEL_A2 | 2 * TSL_DOD_A2,
|
|
0 * TSL_SDW_A2 | 1 * TSL_BSEL_A2 | 2 * TSL_DOD_A2 | TSL_WS2,
|
|
0 * TSL_SDW_A2 | 0 * TSL_BSEL_A2 | 2 * TSL_DOD_A2 | TSL_WS2,
|
|
0 * TSL_SDW_A2 | 1 * TSL_BSEL_A2 | 2 * TSL_DOD_A2 | TSL_WS2,
|
|
0 * TSL_SDW_A2 | 0 * TSL_BSEL_A2 | 2 * TSL_DOD_A2 | TSL_WS2 | TSL_EOS
|
|
};
|