Blame view

kernel/linux-rt-4.4.41/include/sound/aess.h 1.63 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
  /*
   * AESS IP block reset
   *
   * Copyright (C) 2012 Texas Instruments, Inc.
   * Paul Walmsley
   *
   * This program 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.
   *
   * This program is distributed "as is" WITHOUT ANY WARRANTY of any
   * kind, whether express or implied; 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 this program; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
   * 02110-1301 USA
   */
  #ifndef __SOUND_AESS_H__
  #define __SOUND_AESS_H__
  
  #include <linux/kernel.h>
  #include <linux/io.h>
  
  /*
   * AESS_AUTO_GATING_ENABLE_OFFSET: offset in bytes of the AESS IP
   *     block's AESS_AUTO_GATING_ENABLE__1 register from the IP block's
   *     base address
   */
  #define AESS_AUTO_GATING_ENABLE_OFFSET			0x07c
  
  /* Register bitfields in the AESS_AUTO_GATING_ENABLE__1 register */
  #define AESS_AUTO_GATING_ENABLE_SHIFT			0
  
  /**
   * aess_enable_autogating - enable AESS internal autogating
   * @oh: struct omap_hwmod *
   *
   * Enable internal autogating on the AESS.  This allows the AESS to
   * indicate that it is idle to the OMAP PRCM.  Returns 0.
   */
  static inline void aess_enable_autogating(void __iomem *base)
  {
  	u32 v;
  
  	/* Set AESS_AUTO_GATING_ENABLE__1.ENABLE to allow idle entry */
  	v = 1 << AESS_AUTO_GATING_ENABLE_SHIFT;
  	writel(v, base + AESS_AUTO_GATING_ENABLE_OFFSET);
  }
  
  #endif /* __SOUND_AESS_H__ */