Blame view

kernel/linux-rt-4.4.41/arch/blackfin/include/asm/bfin_sport.h 1.21 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
  /*
   * bfin_sport.h - interface to Blackfin SPORTs
   *
   * Copyright 2004-2009 Analog Devices Inc.
   *
   * Licensed under the GPL-2 or later.
   */
  #ifndef __BFIN_SPORT_H__
  #define __BFIN_SPORT_H__
  
  
  #include <linux/types.h>
  #include <uapi/asm/bfin_sport.h>
  
  /*
   * All Blackfin system MMRs are padded to 32bits even if the register
   * itself is only 16bits.  So use a helper macro to streamline this.
   */
  #define __BFP(m) u16 m; u16 __pad_##m
  struct sport_register {
  	__BFP(tcr1);
  	__BFP(tcr2);
  	__BFP(tclkdiv);
  	__BFP(tfsdiv);
  	union {
  		u32 tx32;
  		u16 tx16;
  	};
  	u32 __pad_tx;
  	union {
  		u32 rx32;	/* use the anomaly wrapper below */
  		u16 rx16;
  	};
  	u32 __pad_rx;
  	__BFP(rcr1);
  	__BFP(rcr2);
  	__BFP(rclkdiv);
  	__BFP(rfsdiv);
  	__BFP(stat);
  	__BFP(chnl);
  	__BFP(mcmc1);
  	__BFP(mcmc2);
  	u32 mtcs0;
  	u32 mtcs1;
  	u32 mtcs2;
  	u32 mtcs3;
  	u32 mrcs0;
  	u32 mrcs1;
  	u32 mrcs2;
  	u32 mrcs3;
  };
  #undef __BFP
  
  struct bfin_snd_platform_data {
  	const unsigned short *pin_req;
  };
  
  #define bfin_read_sport_rx32(base) \
  ({ \
  	struct sport_register *__mmrs = (void *)base; \
  	u32 __ret; \
  	unsigned long flags; \
  	if (ANOMALY_05000473) \
  		local_irq_save(flags); \
  	__ret = __mmrs->rx32; \
  	if (ANOMALY_05000473) \
  		local_irq_restore(flags); \
  	__ret; \
  })
  
  #endif