Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
c203f677
Commit
c203f677
authored
Jan 31, 2018
by
Vinod Koul
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'topic/qcom' into for-linus
parents
c4cc2c3a
b5419adc
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
27 additions
and
27 deletions
+27
-27
Documentation/devicetree/bindings/dma/qcom_hidma_mgmt.txt
Documentation/devicetree/bindings/dma/qcom_hidma_mgmt.txt
+2
-2
drivers/dma/qcom/hidma.c
drivers/dma/qcom/hidma.c
+19
-22
drivers/dma/qcom/hidma_ll.c
drivers/dma/qcom/hidma_ll.c
+6
-3
No files found.
Documentation/devicetree/bindings/dma/qcom_hidma_mgmt.txt
View file @
c203f677
...
@@ -47,8 +47,8 @@ When the OS is not in control of the management interface (i.e. it's a guest),
...
@@ -47,8 +47,8 @@ When the OS is not in control of the management interface (i.e. it's a guest),
the channel nodes appear on their own, not under a management node.
the channel nodes appear on their own, not under a management node.
Required properties:
Required properties:
- compatible: must contain "qcom,hidma-1.0" for initial HW or
"qcom,hidma-1.1"
- compatible: must contain "qcom,hidma-1.0" for initial HW or
for MSI capable HW.
"qcom,hidma-1.1"/"qcom,hidma-1.2"
for MSI capable HW.
- reg: Addresses for the transfer and event channel
- reg: Addresses for the transfer and event channel
- interrupts: Should contain the event interrupt
- interrupts: Should contain the event interrupt
- desc-count: Number of asynchronous requests this channel can handle
- desc-count: Number of asynchronous requests this channel can handle
...
...
drivers/dma/qcom/hidma.c
View file @
c203f677
...
@@ -50,6 +50,7 @@
...
@@ -50,6 +50,7 @@
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/spinlock.h>
#include <linux/spinlock.h>
#include <linux/of_dma.h>
#include <linux/of_dma.h>
#include <linux/of_device.h>
#include <linux/property.h>
#include <linux/property.h>
#include <linux/delay.h>
#include <linux/delay.h>
#include <linux/acpi.h>
#include <linux/acpi.h>
...
@@ -104,6 +105,10 @@ static unsigned int nr_desc_prm;
...
@@ -104,6 +105,10 @@ static unsigned int nr_desc_prm;
module_param
(
nr_desc_prm
,
uint
,
0644
);
module_param
(
nr_desc_prm
,
uint
,
0644
);
MODULE_PARM_DESC
(
nr_desc_prm
,
"number of descriptors (default: 0)"
);
MODULE_PARM_DESC
(
nr_desc_prm
,
"number of descriptors (default: 0)"
);
enum
hidma_cap
{
HIDMA_MSI_CAP
=
1
,
HIDMA_IDENTITY_CAP
,
};
/* process completed descriptors */
/* process completed descriptors */
static
void
hidma_process_completed
(
struct
hidma_chan
*
mchan
)
static
void
hidma_process_completed
(
struct
hidma_chan
*
mchan
)
...
@@ -736,25 +741,12 @@ static int hidma_request_msi(struct hidma_dev *dmadev,
...
@@ -736,25 +741,12 @@ static int hidma_request_msi(struct hidma_dev *dmadev,
#endif
#endif
}
}
static
bool
hidma_
msi_capable
(
struct
device
*
dev
)
static
bool
hidma_
test_capability
(
struct
device
*
dev
,
enum
hidma_cap
test_cap
)
{
{
struct
acpi_device
*
adev
=
ACPI_COMPANION
(
dev
);
enum
hidma_cap
cap
;
const
char
*
of_compat
;
int
ret
=
-
EINVAL
;
if
(
!
adev
||
acpi_disabled
)
{
ret
=
device_property_read_string
(
dev
,
"compatible"
,
&
of_compat
);
if
(
ret
)
return
false
;
ret
=
strcmp
(
of_compat
,
"qcom,hidma-1.1"
);
cap
=
(
enum
hidma_cap
)
device_get_match_data
(
dev
);
}
else
{
return
cap
?
((
cap
&
test_cap
)
>
0
)
:
0
;
#ifdef CONFIG_ACPI
ret
=
strcmp
(
acpi_device_hid
(
adev
),
"QCOM8062"
);
#endif
}
return
ret
==
0
;
}
}
static
int
hidma_probe
(
struct
platform_device
*
pdev
)
static
int
hidma_probe
(
struct
platform_device
*
pdev
)
...
@@ -834,8 +826,7 @@ static int hidma_probe(struct platform_device *pdev)
...
@@ -834,8 +826,7 @@ static int hidma_probe(struct platform_device *pdev)
* Determine the MSI capability of the platform. Old HW doesn't
* Determine the MSI capability of the platform. Old HW doesn't
* support MSI.
* support MSI.
*/
*/
msi
=
hidma_msi_capable
(
&
pdev
->
dev
);
msi
=
hidma_test_capability
(
&
pdev
->
dev
,
HIDMA_MSI_CAP
);
device_property_read_u32
(
&
pdev
->
dev
,
"desc-count"
,
device_property_read_u32
(
&
pdev
->
dev
,
"desc-count"
,
&
dmadev
->
nr_descriptors
);
&
dmadev
->
nr_descriptors
);
...
@@ -848,7 +839,10 @@ static int hidma_probe(struct platform_device *pdev)
...
@@ -848,7 +839,10 @@ static int hidma_probe(struct platform_device *pdev)
if
(
!
dmadev
->
nr_descriptors
)
if
(
!
dmadev
->
nr_descriptors
)
dmadev
->
nr_descriptors
=
HIDMA_NR_DEFAULT_DESC
;
dmadev
->
nr_descriptors
=
HIDMA_NR_DEFAULT_DESC
;
dmadev
->
chidx
=
readl
(
dmadev
->
dev_trca
+
0x28
);
if
(
hidma_test_capability
(
&
pdev
->
dev
,
HIDMA_IDENTITY_CAP
))
dmadev
->
chidx
=
readl
(
dmadev
->
dev_trca
+
0x40
);
else
dmadev
->
chidx
=
readl
(
dmadev
->
dev_trca
+
0x28
);
/* Set DMA mask to 64 bits. */
/* Set DMA mask to 64 bits. */
rc
=
dma_set_mask_and_coherent
(
&
pdev
->
dev
,
DMA_BIT_MASK
(
64
));
rc
=
dma_set_mask_and_coherent
(
&
pdev
->
dev
,
DMA_BIT_MASK
(
64
));
...
@@ -953,7 +947,8 @@ static int hidma_remove(struct platform_device *pdev)
...
@@ -953,7 +947,8 @@ static int hidma_remove(struct platform_device *pdev)
#if IS_ENABLED(CONFIG_ACPI)
#if IS_ENABLED(CONFIG_ACPI)
static
const
struct
acpi_device_id
hidma_acpi_ids
[]
=
{
static
const
struct
acpi_device_id
hidma_acpi_ids
[]
=
{
{
"QCOM8061"
},
{
"QCOM8061"
},
{
"QCOM8062"
},
{
"QCOM8062"
,
HIDMA_MSI_CAP
},
{
"QCOM8063"
,
(
HIDMA_MSI_CAP
|
HIDMA_IDENTITY_CAP
)},
{},
{},
};
};
MODULE_DEVICE_TABLE
(
acpi
,
hidma_acpi_ids
);
MODULE_DEVICE_TABLE
(
acpi
,
hidma_acpi_ids
);
...
@@ -961,7 +956,9 @@ MODULE_DEVICE_TABLE(acpi, hidma_acpi_ids);
...
@@ -961,7 +956,9 @@ MODULE_DEVICE_TABLE(acpi, hidma_acpi_ids);
static
const
struct
of_device_id
hidma_match
[]
=
{
static
const
struct
of_device_id
hidma_match
[]
=
{
{.
compatible
=
"qcom,hidma-1.0"
,},
{.
compatible
=
"qcom,hidma-1.0"
,},
{.
compatible
=
"qcom,hidma-1.1"
,},
{.
compatible
=
"qcom,hidma-1.1"
,
.
data
=
(
void
*
)(
HIDMA_MSI_CAP
),},
{.
compatible
=
"qcom,hidma-1.2"
,
.
data
=
(
void
*
)(
HIDMA_MSI_CAP
|
HIDMA_IDENTITY_CAP
),},
{},
{},
};
};
MODULE_DEVICE_TABLE
(
of
,
hidma_match
);
MODULE_DEVICE_TABLE
(
of
,
hidma_match
);
...
...
drivers/dma/qcom/hidma_ll.c
View file @
c203f677
...
@@ -393,6 +393,8 @@ static int hidma_ll_reset(struct hidma_lldev *lldev)
...
@@ -393,6 +393,8 @@ static int hidma_ll_reset(struct hidma_lldev *lldev)
*/
*/
static
void
hidma_ll_int_handler_internal
(
struct
hidma_lldev
*
lldev
,
int
cause
)
static
void
hidma_ll_int_handler_internal
(
struct
hidma_lldev
*
lldev
,
int
cause
)
{
{
unsigned
long
irqflags
;
if
(
cause
&
HIDMA_ERR_INT_MASK
)
{
if
(
cause
&
HIDMA_ERR_INT_MASK
)
{
dev_err
(
lldev
->
dev
,
"error 0x%x, disabling...
\n
"
,
dev_err
(
lldev
->
dev
,
"error 0x%x, disabling...
\n
"
,
cause
);
cause
);
...
@@ -410,6 +412,10 @@ static void hidma_ll_int_handler_internal(struct hidma_lldev *lldev, int cause)
...
@@ -410,6 +412,10 @@ static void hidma_ll_int_handler_internal(struct hidma_lldev *lldev, int cause)
return
;
return
;
}
}
spin_lock_irqsave
(
&
lldev
->
lock
,
irqflags
);
writel_relaxed
(
cause
,
lldev
->
evca
+
HIDMA_EVCA_IRQ_CLR_REG
);
spin_unlock_irqrestore
(
&
lldev
->
lock
,
irqflags
);
/*
/*
* Fine tuned for this HW...
* Fine tuned for this HW...
*
*
...
@@ -421,9 +427,6 @@ static void hidma_ll_int_handler_internal(struct hidma_lldev *lldev, int cause)
...
@@ -421,9 +427,6 @@ static void hidma_ll_int_handler_internal(struct hidma_lldev *lldev, int cause)
* Try to consume as many EVREs as possible.
* Try to consume as many EVREs as possible.
*/
*/
hidma_handle_tre_completion
(
lldev
);
hidma_handle_tre_completion
(
lldev
);
/* We consumed TREs or there are pending TREs or EVREs. */
writel_relaxed
(
cause
,
lldev
->
evca
+
HIDMA_EVCA_IRQ_CLR_REG
);
}
}
irqreturn_t
hidma_ll_inthandler
(
int
chirq
,
void
*
arg
)
irqreturn_t
hidma_ll_inthandler
(
int
chirq
,
void
*
arg
)
...
...
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