x86/mm/pat: Don't report PAT on CPUs that don't support it
[linux/fpc-iii.git] / sound / pci / ctxfi / ctdaio.h
bloba30be73b08ea6c4bb50cb5735d6fa7d0978d0a9d
1 /**
2 * Copyright (C) 2008, Creative Technology Ltd. All Rights Reserved.
4 * This source file is released under GPL v2 license (no other versions).
5 * See the COPYING file included in the main directory of this source
6 * distribution for the license terms and conditions.
8 * @File ctdaio.h
10 * @Brief
11 * This file contains the definition of Digital Audio Input Output
12 * resource management object.
14 * @Author Liu Chun
15 * @Date May 23 2008
19 #ifndef CTDAIO_H
20 #define CTDAIO_H
22 #include "ctresource.h"
23 #include "ctimap.h"
24 #include <linux/spinlock.h>
25 #include <linux/list.h>
26 #include <sound/core.h>
28 /* Define the descriptor of a daio resource */
29 enum DAIOTYP {
30 LINEO1,
31 LINEO2,
32 LINEO3,
33 LINEO4,
34 SPDIFOO, /* S/PDIF Out (Flexijack/Optical) */
35 LINEIM,
36 SPDIFIO, /* S/PDIF In (Flexijack/Optical) on the card */
37 MIC, /* Dedicated mic on Titanium HD */
38 SPDIFI1, /* S/PDIF In on internal Drive Bay */
39 NUM_DAIOTYP
42 struct dao_rsc_ops;
43 struct dai_rsc_ops;
44 struct daio_mgr;
46 struct daio {
47 struct rsc rscl; /* Basic resource info for left TX/RX */
48 struct rsc rscr; /* Basic resource info for right TX/RX */
49 enum DAIOTYP type;
52 struct dao {
53 struct daio daio;
54 const struct dao_rsc_ops *ops; /* DAO specific operations */
55 struct imapper **imappers;
56 struct daio_mgr *mgr;
57 struct hw *hw;
58 void *ctrl_blk;
61 struct dai {
62 struct daio daio;
63 const struct dai_rsc_ops *ops; /* DAI specific operations */
64 struct hw *hw;
65 void *ctrl_blk;
68 struct dao_desc {
69 unsigned int msr:4;
70 unsigned int passthru:1;
73 struct dao_rsc_ops {
74 int (*set_spos)(struct dao *dao, unsigned int spos);
75 int (*commit_write)(struct dao *dao);
76 int (*get_spos)(struct dao *dao, unsigned int *spos);
77 int (*reinit)(struct dao *dao, const struct dao_desc *desc);
78 int (*set_left_input)(struct dao *dao, struct rsc *input);
79 int (*set_right_input)(struct dao *dao, struct rsc *input);
80 int (*clear_left_input)(struct dao *dao);
81 int (*clear_right_input)(struct dao *dao);
84 struct dai_rsc_ops {
85 int (*set_srt_srcl)(struct dai *dai, struct rsc *src);
86 int (*set_srt_srcr)(struct dai *dai, struct rsc *src);
87 int (*set_srt_msr)(struct dai *dai, unsigned int msr);
88 int (*set_enb_src)(struct dai *dai, unsigned int enb);
89 int (*set_enb_srt)(struct dai *dai, unsigned int enb);
90 int (*commit_write)(struct dai *dai);
93 /* Define daio resource request description info */
94 struct daio_desc {
95 unsigned int type:4;
96 unsigned int msr:4;
97 unsigned int passthru:1;
100 struct daio_mgr {
101 struct rsc_mgr mgr; /* Basic resource manager info */
102 struct snd_card *card; /* pointer to this card */
103 spinlock_t mgr_lock;
104 spinlock_t imap_lock;
105 struct list_head imappers;
106 struct imapper *init_imap;
107 unsigned int init_imap_added;
109 /* request one daio resource */
110 int (*get_daio)(struct daio_mgr *mgr,
111 const struct daio_desc *desc, struct daio **rdaio);
112 /* return one daio resource */
113 int (*put_daio)(struct daio_mgr *mgr, struct daio *daio);
114 int (*daio_enable)(struct daio_mgr *mgr, struct daio *daio);
115 int (*daio_disable)(struct daio_mgr *mgr, struct daio *daio);
116 int (*imap_add)(struct daio_mgr *mgr, struct imapper *entry);
117 int (*imap_delete)(struct daio_mgr *mgr, struct imapper *entry);
118 int (*commit_write)(struct daio_mgr *mgr);
121 /* Constructor and destructor of daio resource manager */
122 int daio_mgr_create(struct hw *hw, struct daio_mgr **rdaio_mgr);
123 int daio_mgr_destroy(struct daio_mgr *daio_mgr);
125 #endif /* CTDAIO_H */