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
nexedi
linux
Commits
fde5de6c
Commit
fde5de6c
authored
Mar 15, 2016
by
Rob Clark
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/msm: move fence code to it's own file
Signed-off-by:
Rob Clark
<
robdclark@gmail.com
>
parent
edcd60ce
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
178 additions
and
133 deletions
+178
-133
drivers/gpu/drm/msm/Makefile
drivers/gpu/drm/msm/Makefile
+1
-0
drivers/gpu/drm/msm/msm_atomic.c
drivers/gpu/drm/msm/msm_atomic.c
+1
-0
drivers/gpu/drm/msm/msm_drv.c
drivers/gpu/drm/msm/msm_drv.c
+1
-107
drivers/gpu/drm/msm/msm_drv.h
drivers/gpu/drm/msm/msm_drv.h
+1
-26
drivers/gpu/drm/msm/msm_fence.c
drivers/gpu/drm/msm/msm_fence.c
+129
-0
drivers/gpu/drm/msm/msm_fence.h
drivers/gpu/drm/msm/msm_fence.h
+43
-0
drivers/gpu/drm/msm/msm_gem.c
drivers/gpu/drm/msm/msm_gem.c
+1
-0
drivers/gpu/drm/msm/msm_gpu.c
drivers/gpu/drm/msm/msm_gpu.c
+1
-0
No files found.
drivers/gpu/drm/msm/Makefile
View file @
fde5de6c
...
...
@@ -42,6 +42,7 @@ msm-y := \
msm_debugfs.o
\
msm_drv.o
\
msm_fb.o
\
msm_fence.o
\
msm_gem.o
\
msm_gem_prime.o
\
msm_gem_submit.o
\
...
...
drivers/gpu/drm/msm/msm_atomic.c
View file @
fde5de6c
...
...
@@ -18,6 +18,7 @@
#include "msm_drv.h"
#include "msm_kms.h"
#include "msm_gem.h"
#include "msm_fence.h"
struct
msm_commit
{
struct
drm_device
*
dev
;
...
...
drivers/gpu/drm/msm/msm_drv.c
View file @
fde5de6c
...
...
@@ -17,6 +17,7 @@
#include "msm_drv.h"
#include "msm_debugfs.h"
#include "msm_fence.h"
#include "msm_gpu.h"
#include "msm_kms.h"
...
...
@@ -536,113 +537,6 @@ static void msm_disable_vblank(struct drm_device *dev, unsigned int pipe)
vblank_ctrl_queue_work
(
priv
,
pipe
,
false
);
}
/*
* Fences:
*/
int
msm_wait_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
,
ktime_t
*
timeout
,
bool
interruptible
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
int
ret
;
if
(
!
priv
->
gpu
)
return
0
;
if
(
fence
>
priv
->
gpu
->
submitted_fence
)
{
DRM_ERROR
(
"waiting on invalid fence: %u (of %u)
\n
"
,
fence
,
priv
->
gpu
->
submitted_fence
);
return
-
EINVAL
;
}
if
(
!
timeout
)
{
/* no-wait: */
ret
=
fence_completed
(
dev
,
fence
)
?
0
:
-
EBUSY
;
}
else
{
ktime_t
now
=
ktime_get
();
unsigned
long
remaining_jiffies
;
if
(
ktime_compare
(
*
timeout
,
now
)
<
0
)
{
remaining_jiffies
=
0
;
}
else
{
ktime_t
rem
=
ktime_sub
(
*
timeout
,
now
);
struct
timespec
ts
=
ktime_to_timespec
(
rem
);
remaining_jiffies
=
timespec_to_jiffies
(
&
ts
);
}
if
(
interruptible
)
ret
=
wait_event_interruptible_timeout
(
priv
->
fence_event
,
fence_completed
(
dev
,
fence
),
remaining_jiffies
);
else
ret
=
wait_event_timeout
(
priv
->
fence_event
,
fence_completed
(
dev
,
fence
),
remaining_jiffies
);
if
(
ret
==
0
)
{
DBG
(
"timeout waiting for fence: %u (completed: %u)"
,
fence
,
priv
->
completed_fence
);
ret
=
-
ETIMEDOUT
;
}
else
if
(
ret
!=
-
ERESTARTSYS
)
{
ret
=
0
;
}
}
return
ret
;
}
int
msm_queue_fence_cb
(
struct
drm_device
*
dev
,
struct
msm_fence_cb
*
cb
,
uint32_t
fence
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
int
ret
=
0
;
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
!
list_empty
(
&
cb
->
work
.
entry
))
{
ret
=
-
EINVAL
;
}
else
if
(
fence
>
priv
->
completed_fence
)
{
cb
->
fence
=
fence
;
list_add_tail
(
&
cb
->
work
.
entry
,
&
priv
->
fence_cbs
);
}
else
{
queue_work
(
priv
->
wq
,
&
cb
->
work
);
}
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
/* called from workqueue */
void
msm_update_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
mutex_lock
(
&
dev
->
struct_mutex
);
priv
->
completed_fence
=
max
(
fence
,
priv
->
completed_fence
);
while
(
!
list_empty
(
&
priv
->
fence_cbs
))
{
struct
msm_fence_cb
*
cb
;
cb
=
list_first_entry
(
&
priv
->
fence_cbs
,
struct
msm_fence_cb
,
work
.
entry
);
if
(
cb
->
fence
>
priv
->
completed_fence
)
break
;
list_del_init
(
&
cb
->
work
.
entry
);
queue_work
(
priv
->
wq
,
&
cb
->
work
);
}
mutex_unlock
(
&
dev
->
struct_mutex
);
wake_up_all
(
&
priv
->
fence_event
);
}
void
__msm_fence_worker
(
struct
work_struct
*
work
)
{
struct
msm_fence_cb
*
cb
=
container_of
(
work
,
struct
msm_fence_cb
,
work
);
cb
->
func
(
cb
);
}
/*
* DRM ioctls:
*/
...
...
drivers/gpu/drm/msm/msm_drv.h
View file @
fde5de6c
...
...
@@ -49,6 +49,7 @@ struct msm_mmu;
struct
msm_rd_state
;
struct
msm_perf_state
;
struct
msm_gem_submit
;
struct
msm_fence_cb
;
#define NUM_DOMAINS 2
/* one for KMS, then one per gpu core (?) */
...
...
@@ -157,20 +158,6 @@ struct msm_format {
uint32_t
pixel_format
;
};
/* callback from wq once fence has passed: */
struct
msm_fence_cb
{
struct
work_struct
work
;
uint32_t
fence
;
void
(
*
func
)(
struct
msm_fence_cb
*
cb
);
};
void
__msm_fence_worker
(
struct
work_struct
*
work
);
#define INIT_FENCE_CB(_cb, _func) do { \
INIT_WORK(&(_cb)->work, __msm_fence_worker); \
(_cb)->func = _func; \
} while (0)
int
msm_atomic_check
(
struct
drm_device
*
dev
,
struct
drm_atomic_state
*
state
);
int
msm_atomic_commit
(
struct
drm_device
*
dev
,
...
...
@@ -178,12 +165,6 @@ int msm_atomic_commit(struct drm_device *dev,
int
msm_register_mmu
(
struct
drm_device
*
dev
,
struct
msm_mmu
*
mmu
);
int
msm_wait_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
,
ktime_t
*
timeout
,
bool
interruptible
);
int
msm_queue_fence_cb
(
struct
drm_device
*
dev
,
struct
msm_fence_cb
*
cb
,
uint32_t
fence
);
void
msm_update_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
);
int
msm_ioctl_gem_submit
(
struct
drm_device
*
dev
,
void
*
data
,
struct
drm_file
*
file
);
...
...
@@ -303,12 +284,6 @@ u32 msm_readl(const void __iomem *addr);
#define DBG(fmt, ...) DRM_DEBUG(fmt"\n", ##__VA_ARGS__)
#define VERB(fmt, ...) if (0) DRM_DEBUG(fmt"\n", ##__VA_ARGS__)
static
inline
bool
fence_completed
(
struct
drm_device
*
dev
,
uint32_t
fence
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
return
priv
->
completed_fence
>=
fence
;
}
static
inline
int
align_pitch
(
int
width
,
int
bpp
)
{
int
bytespp
=
(
bpp
+
7
)
/
8
;
...
...
drivers/gpu/drm/msm/msm_fence.c
0 → 100644
View file @
fde5de6c
/*
* Copyright (C) 2013-2016 Red Hat
* Author: Rob Clark <robdclark@gmail.com>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 as published by
* the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; 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, see <http://www.gnu.org/licenses/>.
*/
#include "msm_drv.h"
#include "msm_fence.h"
#include "msm_gpu.h"
static
inline
bool
fence_completed
(
struct
drm_device
*
dev
,
uint32_t
fence
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
return
(
int32_t
)(
priv
->
completed_fence
-
fence
)
>=
0
;
}
int
msm_wait_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
,
ktime_t
*
timeout
,
bool
interruptible
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
int
ret
;
if
(
!
priv
->
gpu
)
return
0
;
if
(
fence
>
priv
->
gpu
->
submitted_fence
)
{
DRM_ERROR
(
"waiting on invalid fence: %u (of %u)
\n
"
,
fence
,
priv
->
gpu
->
submitted_fence
);
return
-
EINVAL
;
}
if
(
!
timeout
)
{
/* no-wait: */
ret
=
fence_completed
(
dev
,
fence
)
?
0
:
-
EBUSY
;
}
else
{
ktime_t
now
=
ktime_get
();
unsigned
long
remaining_jiffies
;
if
(
ktime_compare
(
*
timeout
,
now
)
<
0
)
{
remaining_jiffies
=
0
;
}
else
{
ktime_t
rem
=
ktime_sub
(
*
timeout
,
now
);
struct
timespec
ts
=
ktime_to_timespec
(
rem
);
remaining_jiffies
=
timespec_to_jiffies
(
&
ts
);
}
if
(
interruptible
)
ret
=
wait_event_interruptible_timeout
(
priv
->
fence_event
,
fence_completed
(
dev
,
fence
),
remaining_jiffies
);
else
ret
=
wait_event_timeout
(
priv
->
fence_event
,
fence_completed
(
dev
,
fence
),
remaining_jiffies
);
if
(
ret
==
0
)
{
DBG
(
"timeout waiting for fence: %u (completed: %u)"
,
fence
,
priv
->
completed_fence
);
ret
=
-
ETIMEDOUT
;
}
else
if
(
ret
!=
-
ERESTARTSYS
)
{
ret
=
0
;
}
}
return
ret
;
}
int
msm_queue_fence_cb
(
struct
drm_device
*
dev
,
struct
msm_fence_cb
*
cb
,
uint32_t
fence
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
int
ret
=
0
;
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
!
list_empty
(
&
cb
->
work
.
entry
))
{
ret
=
-
EINVAL
;
}
else
if
(
fence
>
priv
->
completed_fence
)
{
cb
->
fence
=
fence
;
list_add_tail
(
&
cb
->
work
.
entry
,
&
priv
->
fence_cbs
);
}
else
{
queue_work
(
priv
->
wq
,
&
cb
->
work
);
}
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
/* called from workqueue */
void
msm_update_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
)
{
struct
msm_drm_private
*
priv
=
dev
->
dev_private
;
mutex_lock
(
&
dev
->
struct_mutex
);
priv
->
completed_fence
=
max
(
fence
,
priv
->
completed_fence
);
while
(
!
list_empty
(
&
priv
->
fence_cbs
))
{
struct
msm_fence_cb
*
cb
;
cb
=
list_first_entry
(
&
priv
->
fence_cbs
,
struct
msm_fence_cb
,
work
.
entry
);
if
(
cb
->
fence
>
priv
->
completed_fence
)
break
;
list_del_init
(
&
cb
->
work
.
entry
);
queue_work
(
priv
->
wq
,
&
cb
->
work
);
}
mutex_unlock
(
&
dev
->
struct_mutex
);
wake_up_all
(
&
priv
->
fence_event
);
}
void
__msm_fence_worker
(
struct
work_struct
*
work
)
{
struct
msm_fence_cb
*
cb
=
container_of
(
work
,
struct
msm_fence_cb
,
work
);
cb
->
func
(
cb
);
}
drivers/gpu/drm/msm/msm_fence.h
0 → 100644
View file @
fde5de6c
/*
* Copyright (C) 2013-2016 Red Hat
* Author: Rob Clark <robdclark@gmail.com>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 as published by
* the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; 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, see <http://www.gnu.org/licenses/>.
*/
#ifndef __MSM_FENCE_H__
#define __MSM_FENCE_H__
#include "msm_drv.h"
/* callback from wq once fence has passed: */
struct
msm_fence_cb
{
struct
work_struct
work
;
uint32_t
fence
;
void
(
*
func
)(
struct
msm_fence_cb
*
cb
);
};
void
__msm_fence_worker
(
struct
work_struct
*
work
);
#define INIT_FENCE_CB(_cb, _func) do { \
INIT_WORK(&(_cb)->work, __msm_fence_worker); \
(_cb)->func = _func; \
} while (0)
int
msm_wait_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
,
ktime_t
*
timeout
,
bool
interruptible
);
int
msm_queue_fence_cb
(
struct
drm_device
*
dev
,
struct
msm_fence_cb
*
cb
,
uint32_t
fence
);
void
msm_update_fence
(
struct
drm_device
*
dev
,
uint32_t
fence
);
#endif
drivers/gpu/drm/msm/msm_gem.c
View file @
fde5de6c
...
...
@@ -21,6 +21,7 @@
#include <linux/pfn_t.h>
#include "msm_drv.h"
#include "msm_fence.h"
#include "msm_gem.h"
#include "msm_gpu.h"
#include "msm_mmu.h"
...
...
drivers/gpu/drm/msm/msm_gpu.c
View file @
fde5de6c
...
...
@@ -18,6 +18,7 @@
#include "msm_gpu.h"
#include "msm_gem.h"
#include "msm_mmu.h"
#include "msm_fence.h"
/*
...
...
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