Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
4c0bccbe
Commit
4c0bccbe
authored
Sep 30, 2009
by
Mark Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'upstream/wm8974' into for-2.6.33
parents
4fa9c1a5
c36b2fc7
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
10 deletions
+13
-10
sound/soc/codecs/wm8974.c
sound/soc/codecs/wm8974.c
+13
-10
No files found.
sound/soc/codecs/wm8974.c
View file @
4c0bccbe
...
...
@@ -281,36 +281,38 @@ static int wm8974_add_widgets(struct snd_soc_codec *codec)
}
struct
pll_
{
unsigned
int
pre_div
:
4
;
/* prescale - 1 */
unsigned
int
pre_div
:
1
;
unsigned
int
n
:
4
;
unsigned
int
k
;
};
static
struct
pll_
pll_div
;
/* The size in bits of the pll divide multiplied by 10
* to allow rounding later */
#define FIXED_PLL_SIZE ((1 << 24) * 10)
static
void
pll_factors
(
unsigned
int
target
,
unsigned
int
source
)
static
void
pll_factors
(
struct
pll_
*
pll_div
,
unsigned
int
target
,
unsigned
int
source
)
{
unsigned
long
long
Kpart
;
unsigned
int
K
,
Ndiv
,
Nmod
;
/* There is a fixed divide by 4 in the output path */
target
*=
4
;
Ndiv
=
target
/
source
;
if
(
Ndiv
<
6
)
{
source
>>=
1
;
pll_div
.
pre_div
=
1
;
source
/=
2
;
pll_div
->
pre_div
=
1
;
Ndiv
=
target
/
source
;
}
else
pll_div
.
pre_div
=
0
;
pll_div
->
pre_div
=
0
;
if
((
Ndiv
<
6
)
||
(
Ndiv
>
12
))
printk
(
KERN_WARNING
"WM8974 N value %u outwith recommended range!
\n
"
,
Ndiv
);
pll_div
.
n
=
Ndiv
;
pll_div
->
n
=
Ndiv
;
Nmod
=
target
%
source
;
Kpart
=
FIXED_PLL_SIZE
*
(
long
long
)
Nmod
;
...
...
@@ -325,13 +327,14 @@ static void pll_factors(unsigned int target, unsigned int source)
/* Move down to proper range now rounding is done */
K
/=
10
;
pll_div
.
k
=
K
;
pll_div
->
k
=
K
;
}
static
int
wm8974_set_dai_pll
(
struct
snd_soc_dai
*
codec_dai
,
int
pll_id
,
int
source
,
unsigned
int
freq_in
,
unsigned
int
freq_out
)
{
struct
snd_soc_codec
*
codec
=
codec_dai
->
codec
;
struct
pll_
pll_div
;
u16
reg
;
if
(
freq_in
==
0
||
freq_out
==
0
)
{
...
...
@@ -345,7 +348,7 @@ static int wm8974_set_dai_pll(struct snd_soc_dai *codec_dai, int pll_id,
return
0
;
}
pll_factors
(
freq_out
*
4
,
freq_in
);
pll_factors
(
&
pll_div
,
freq_out
,
freq_in
);
snd_soc_write
(
codec
,
WM8974_PLLN
,
(
pll_div
.
pre_div
<<
4
)
|
pll_div
.
n
);
snd_soc_write
(
codec
,
WM8974_PLLK1
,
pll_div
.
k
>>
18
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment