Commit graph

306425 commits

Author SHA1 Message Date
Carter Cooper
8f7648fae6 msm: kgsl: Do not overwrite dispatcher fault
Do not overwrite the fault in dispatcher but add
the fault type and let the fault handler decide how
to deal in multiple faults. And after fault handling
there is a possibility that the fault bit will still
be set if the fault timer fires when fault handler
is running. Ignore that fault by clearing fault bit
after reset in fault handler.

Change-Id: I7b240fb55378cb30092a93adf7feca20eaca7568
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:59 -07:00
Carter Cooper
6be908e463 msm: kgsl: Do not register additional IOMMU faults
When an IOMMU fault occurs the fault is cleared in a
queued work item. Until the queued item runs the system
will report the same fault over and over again. Ignore
these faults until the original fault is cleared in the
queued work item.

Change-Id: I96a63ab8f568a874f25da0c56d1e3d8cf7e73e6c
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:58 -07:00
Carter Cooper
8e176b66e9 msm: kgsl: Clear dispatcher fault bit if inflight commands are 0
Clear the dispatcher fault bit if inflight commands are 0 and ensure
that the fault routine is called every time dispatcher is scheduled.
On a false hang detect there was a case when dispatcher fault routine
did not get called, this caused the dispatcher to stop issueing commands
to hardware, fix this by ensuring that fault routine is run every
time dispatcher is scheduled.

Change-Id: Ia36870e279f00630e0c79624437b0eaabb3d634c
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:57 -07:00
Carter Cooper
3032205a0e msm: kgsl: Free the cmdbatch when it fails to be requeued
If cmdbatch does not get re-queued in context list then
destroy it.

Change-Id: If2ba7f029887bdb04bb3d90b470ee4108ff71c24
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:57 -07:00
Carter Cooper
c6781a0080 msm: kgsl: Max the expired timestamp of invalidated context
Set the timestamp of an expired context to the maximum which is the
last timestamp that was assigned to a command batch of that context.
This is done so that any events which are registered by the context
will be triggered normally and avoid any sync timeouts.

Change-Id: I0ac4507bcaaa9835dd79ffa8f7066bfff6d3f48d
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:56 -07:00
Carter Cooper
8ecbca78ed msm: kgsl: Fix draw context fair scheduling in the dispatcher
Commit a8330f853988137425346ce8050970e6a19b64ae broke the fair scheduling
alogrithm in the dispatcher. That commit copied off the current pending
queue into a temporary list and processed it one by one.  After all the
inflight slots were filled the remaining contexts were pushed back on
the list.  Consider the following situation - max inflight is 15, current
inflight is 14 (room for 1 more command batch). There are two contexts
in the queue:

  a -> b

The contexts are copied to a temporary list so now the pending list is
empty.  'a' is processed first and submits one command batch.  After
successfully processing the command it is put back on the pending list:

 a

inflight is now full, so 'b' doesn't process anything - it gets shoved
back on the pending list:

 a -> b

See the problem?  In a fair scheduling scenario, 'b' should be first so
it has a chance to be processed the next time there is room in the queue.
Instead 'a' will dominate the time - hilarity ensues.

This is fixed by putting successfully processed contexts on to a requeue
list and then pushing them back on at the end keeping unprocessed
contexts on the master list which ensures fair scheduling (there is a
scenario where two processed contexts could swap spots, but that isn't as
big a deal as long as they both got their timeslice).

Change-Id: Ic0dedbad658dacc43efc972f7731f345f1ec8a79
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:56 -07:00
Carter Cooper
a6bf254a17 msm: kgsl: Check whether context is detached before updating timestamp
When context is detached there is a wait for the last timestamp
used by the context. This is done under the assumption that after
this timestamp there will be no commands in the pipeline that are
submitted on behalf of this context. However, the dispatcher can
still dispatch commands from the detached context because there
is a time gap between the context being detached and the dispatcher
checking whether the context is detached. Hence, guard the last
timestamp by holding the context mutex and checking if the context is
detached or not before updating it.

Trying to guard internal_timestamp with drawctxt->mutex could lead
to a locking order inversion and possibly deadlock. This variable
is set in adreno_ringbuffer_addcmds(), and used in kgsl_context_detach().
Both of these calls hold device->mutex, so it is safe to access
this variable without an additional mutex.

Change-Id: Idc1a867de94e071a3128a164724d26dd9cb29a0a
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Jeremy Gebben <jgebben@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:55 -07:00
Carter Cooper
5db8ce8772 msm: kgsl: Do not delete command batch unless it's retired
Do not remove command batch from the dispatcher list if it's timestamp
has not retired. Even if the context to which the command belongs
has been detached. If the command is in the dispatcher queue it means
it's in the ringbuffer and we should wait for it to complete the normal
way. Also make sure that we use the correct retired timestamp even if
the context was detached because of a userpace context destroy call.

Change-Id: If3a9a562180b924492ed95f208b5e3d469abdfba
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:54 -07:00
Carter Cooper
8d35ba0680 msm: kgsl: Store process private pointer in context
Store the process private pointer in context. Earlier the process
private pointer was referenced through the dev_priv pointer in the
context, but the dev_priv pointer can be destroyed before the context
process private so store this pointer locally.

Change-Id: Ic07680b79db55d6306306bd61bda5a1288813914
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:54 -07:00
Carter Cooper
27e725470c msm: kgsl: Hold a reference to process private when creating context
When a context is created hold a reference to the process private
structure which is referenced from within the context. The process
private structure can be destroyed while some threads still have
a reference to the context, this can lead to a situation where the
process private pointer inside the context pointer becomes invalid.
Avoid this by holding a reference to the process private structure
as long as the context is around.

Change-Id: Ia35629e5d027a383ed4c1378316633b4923372f7
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:53 -07:00
Carter Cooper
9e22319029 msm: kgsl: Hold the plist spinlock to protect nodes
Even though we copy the plist to process the pending contexts the
individual nodes might need to be spinlock protected against
outsiders.

Change-Id: Ic0dedbad509e9b37b5bee4b4828561950ad2f73e
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:53 -07:00
Carter Cooper
2052625719 msm: kgsl: Improve the dispatcher issuecmds loop
Instead of playing silly tricks to try to avoid going into an
infinite loop while processing pending contexts do the smart
thing and copy off the entire pending queue into a temporary
list.  That leaves the master list free to accept new and
requeued contexts and we can do evil things to our temporary
list.

Change-Id: Ic0dedbad365206031854fc95b5353184cabd40a1
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:52 -07:00
Carter Cooper
9677abc5b9 msm: kgsl: Implement KGSL fault tolerance policy in the dispatcher
Implement the KGSL fault tolerance policy for faults in the dispatcher.
Replay (or skip) the inflight command batches as dictated by the policy,
iterating progressively through the various behaviors.

Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:52 -07:00
Carter Cooper
5ab9e02502 msm: kgsl: Check the return value of _kgsl_context_get()
Check the value returned by _kgsl_context_get() and fail if
appropriate.  This prevents us from accidently increasing the
ref count on a destroyed context.

Change-Id: Ic0dedbad891842a73b1b87eb6671f9a39a275dd4
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:51 -07:00
Carter Cooper
d49f42a813 msm: kgsl: fix a race condition when calling kref_put
Fix a race condition which can occur if a thread tries to acquire
a reference to a mem_entry or context while another thread has
already decremented the refcount to 0 and is in the process of
destroying said mem_entry or context.

Change-Id: I6be64ca75f9cb12b03e870b9ca83588197c64e5e
Signed-off-by: Shrenuj Bansal <shrenujb@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:51 -07:00
Carter Cooper
79bab10ef5 msm: kgsl: Allow sync points to be created on the submitter's context
There are situations where a submitting thread may wish to create a
syncpoint on an already issued timestamp to pause a context until a
previous command has been retired.  Relax the restriction against
submitting a sync point against one's own context and only check to
make sure the user isn't submitting a syncpoint against a future
timestamp (which would be an certain deadlock).

Change-Id: Ic0dedbad883fc228da0d94c8416a88504f5d1377
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:50 -07:00
Carter Cooper
f1fa739d77 msm: kgsl: Support generic GPU trace events
If available support two generic GPU trace events:

	events/gpu/gpu_sched_switch
	events/gpu/gpu_job_enqueue

This will allow generic tools to get a better idea of when
commands are queued and scheduled.

Change-Id: Ic0dedbad5fa6c5fbb34aebdcf82fd10ee92da8d7
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:49 -07:00
Carter Cooper
2e9672fbed msm: kgsl: Try to run soft reset on all targets that support it
Run soft reset on all targets that define a soft_reset function hook.
If the target defines jump table offsets then we can run through a
faster reset sequence, otherwise default to the slower full reset
path.  In any event, both these options are much faster than the
hard reset path that toggles the regulators.

Change-Id: Ic0dedbad4cbfdc083f16b026e133159814481886
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:49 -07:00
Carter Cooper
f030f257d0 msm: kgsl: Configure FT behaviour from sysfs instead of debugfs
FT behaviour is changed to be configured from sysfs
instead of debugfs. Sysfs control gives us the advantage
of configuring FT at bootup and also across bootups.
Persistant configuration across bootups helps
testing by configuring FT once and testing the FT
config across bootups.

Change-Id: Ia3378f214371a6a4b9f205f9f884976f58585971
Signed-off-by: Tarun Karra <tkarra@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:48 -07:00
Carter Cooper
b3ba48c91d msm: kgsl: GPU soft reset
Soft reset GPU when GPU power rail is not turned off.
In hard reset we reload full microcode but in soft reset
since the memory powerrail is not turned off we only
load jump tables part of microcode, this reduces GPU
reset time from 10ms to 200us.

Change-Id: Ibbc36e97cc95425e13856fd5d847eed742743723
Signed-off-by: Tarun Karra <tkarra@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:48 -07:00
Carter Cooper
3d24c79f84 msm: kgsl: guard all mem_idr operations with the mem_lock
It isn't possible to use rcu_read_lock() sections to guard
access to a data structure that is refcounted with a kref.
Rather than creating RCU-aware refcounts for kgsl_mem_entry
as described in Documentation/RCU/rcuref.txt, just use
the mem_lock to guard lookups in the idr.

Change-Id: Ia0733b156fc7a9b446cb8221b9172ce9faf111e7
Signed-off-by: Jeremy Gebben <jgebben@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:47 -07:00
Carter Cooper
64e5301ee5 msm: kgsl: Fix addressing of FSYNR0 and FSYNR1 registers
Fix the addressing of FSYNR0 and FSYNR1 IOMMU-v1 registers. These
are context registers and were being addressed as global registers.

Change-Id: I2f6c4798a3c82bb4857a334beb99994ac9f4a1e8
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:46 -07:00
Carter Cooper
ccf3f3a551 msm: kgsl: Add the event callback symbol to GPU event tracepoints
Print the callback function symbol name in GPU event register
and fire trace events.  This makes it easier to debug which event
is being registered/fired.

Change-Id: Ic0dedbad4be4e4179c820af6119786c57d12e13f
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:46 -07:00
Carter Cooper
1011c608ab msm: kgsl: send ringbuffer NOP padding with the next command
If there isn't enough room at the bottom of the ringbuffer for a
whole command, the remaining space is filled with NOPs and
the command starts again at the top of the ringbuffer, the write
pointer of the ringbuffer shall update accordingly; the existing
implementation sends out in-complete NOP command which may potentially
cause GPU hang. This fix submits the NOP command along with the next
command instead of submitting them separately to have GPU read both
commands in the same fetch.

Change-Id: Ia3c9933c11d986c6743d8026b809bbcb1eaf54bf
Signed-off-by: Zhong Liu <zhongl@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:45 -07:00
Carter Cooper
e01247915c msm: kgsl: Add a ftrace event for adreno context switches
It is useful to track context switches since they are expensive
and we would like to have as few as possible.

Change-Id: Ic0dedbad6befc84193b17851a9db4ff87e656cc7
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:45 -07:00
Carter Cooper
bc59a6d7d3 msm: kgsl: Remove msm-dcvs pwrscale driver
The msm-dcvs pwrscale driver is no longer in development. Remove it to
avoid bitrot and simplify future target development.

Change-Id: Ic0dedbad81c2afb4bfbb377ee1a2330e115c0e71
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:44 -07:00
Carter Cooper
f182b2677d msm: kgsl: Setup a3xx protection in its start function
Setup the protection registers for a3xx towards the end of its
start function instead of doing it in generic ringbuffer start

Change-Id: I66df496afa5d1fdf7dea790306f5358c2098674d
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:43 -07:00
Carter Cooper
08f7f6fa9e msm: kgsl: Do not try to resume the device from INIT state
If the device is still in INIT state there are no open instances
of it running.  Resume calls should be no-ops.  Do not attempt
to start the device at this point.

Change-Id: I1cb6d60581b0b5b0a2ab1b13418adc4ae3983c5e
Signed-off-by: Lucille Sylvester <lsylvest@codeaurora.org>
Signed-off-by: Ajay Dudani <adudani@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:43 -07:00
Carter Cooper
b837708dfc msm: kgsl: Option to not stall IOMMU V1 on pagefault based on FT policy
There are cases where GPU has a pagefault and executes
fine after pagefault without GPU stall. init.qcom.graphics.sh
script can be used to change FT pagefault policy
to not stall IOMMU V1 on pagefault and check if pagefault is harmless.

Change-Id: If061230b66181bfd94c697ea106e7bf4de352e91
Signed-off-by: Tarun Karra <tkarra@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:42 -07:00
Carter Cooper
9354a396e0 msm: kgsl: Use the kmalloc/vmalloc trick for the sharedmem page array
It was previously assumed that most GPU memory allocations would be
small enough to allow us to fit the array of page pointers into one
or two pages allocated via kmalloc.  Recent reports have proven
those assumptions to be wrong - allocations on the order of 32MB will
end up trying to get 8 pages from kmalloc and 8 contiguous pages
on a busy system are a rare beast indeed.

So use the usual kmalloc/vmalloc trick instead - use kmalloc for the
page array when we can and vmalloc if we can't.

CRs-fixed: 513469
Change-Id: Ic0dedbad0a5b14abe6a8bd73342b3e68faa8c8b7
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:42 -07:00
Carter Cooper
af405436bc msm: kgsl: Wait for the active_count in kgsl_release()
It is possible that a context can be successfully destroyed and
kgsl_release() called by an exiting application before the kernel
threads have released all the users of the active count.  Instead
of immediately calling BUG_ON() in kgsl_release() when the active
count is unexpected, wait a second to give the others time to
finish up.  If after a second the active count still hasn't gone
where we need it to then we can assume driver error and BUG_ON().

To accomplish this, remodel kgsl_active_count_wait() to take a
active_count value to "wait" for.

Change-Id: Ic0dedbadcc7d0714ea14f25e2a43715e2e12c041
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:41 -07:00
Carter Cooper
395eb05468 msm: kgsl: use kgsl_mmu_device_setstate() whenever the gpu is idle
We really don't want new GPU commands or events to be generated
just to manage the iommu while we are idle.

Change-Id: I2e8740bee8c25c93bddc51a90a3370d151aaf558
Signed-off-by: Jeremy Gebben <jgebben@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:40 -07:00
Carter Cooper
2ba0ba9036 msm: kgsl: Check for idle in the fault detection timer
Check for idle in the fault detection timer.  Don't report a fault
if the GPU is idle.

Change-Id: Ic0dedbad0a912b2d4b3cda9f545a9301290904d6
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:40 -07:00
Carter Cooper
21655b88ed msm: kgsl: use the same logic in adreno_idle and adreno_isidle
These two functions need to agree on the meaning of "idle",
so that calling adreno_isidle() right after an adreno_idle()
will always return true.

Change-Id: I7cddf73773186c3ec8b56c111affacac3b07fcc7
Signed-off-by: Jeremy Gebben <jgebben@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:39 -07:00
Carter Cooper
28a26d0dea msm: kgsl: generate descriptive names for kgsl-timeline
Generate names for kgsl-timelines using the following format:
<device>-<thread name>(<tid>)-<proc name>(<pid>)-<context id>

This makes it possible to identify the context of a timeline in the
sync dump, which makes it much easier to identify which context has
a GPU timeout.

Change-Id: I0ce0614a53a93fd81094d92c9bef7053e6d416d2
Git-commit: e3348f389f715cb2143a708ec6796d3f65e03821
Git-repo: https://www.codeaurora.org/gitweb/quic/la/?p=kernel/msm.git
Signed-off-by: Fred Fettinger <fred.fettinger@motorola.com>
Signed-off-by: Harsh Vardhan Dwivedi <hdwivedi@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:39 -07:00
Carter Cooper
c10fe0b567 msm: kgsl: embed kgsl_context struct in adreno_context struct
Having a separate allocated struct for the device specific context
makes ownership unclear, which could lead to reference counting
problems or invalid pointers. Also, duplicate members were
starting to appear in adreno_context because there wasn't a safe
way to reach the kgsl_context from some parts of the adreno code.
This can now be done via container_of().

This change alters the lifecycle of the context->id, which is
now freed when the context reference count hits zero rather
than in kgsl_context_detach().

It also changes the context creation and destruction sequence.
The device specific code must allocate a structure containing
a struct kgsl_context and passes a pointer it to kgsl_init_context()
before doing any device specific initialization. There is also a
separate drawctxt_detach() callback for doing device specific
cleanup. This is separate from freeing memory, which is done
by the drawctxt_destroy() callback.

Change-Id: I7d238476a3bfec98fd8dbc28971cf3187a81dac2
Signed-off-by: Jeremy Gebben <jgebben@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:38 -07:00
Carter Cooper
b8692c4700 msm: kgsl: convert cffdump stub functions to inlines
Since cffdump is not often enabled in Kconfig, it is helpful
to at least catch compiler errors and warnings when it is off.

Change-Id: Ic0dedbad41b0faac6e0a2514e694f8e369c61f7f
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:38 -07:00
Carter Cooper
b30b6596a3 msm: kgsl: Use a standard function for register access
There were dual functions for reading and writing registers for
adreno devices. Stop the use of one of these dual functions as
it makes the code more uniform.

Change-Id: I703d27d1674a85a6c2d7a9fe6dc49f13005a3410
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:37 -07:00
Carter Cooper
94cb03cf46 msm: kgsl: Define register offset array
Different adreno cores have different offsets for same register.
These registers are referenced in code areas which are common to
all adreno cores. Hence, they should be referenced with a variable
instead of using a constant to make things more generic. This makes
the code more suitable for accomodating future cores.

Change-Id: Ie3d387d7cf767d46eea90e0fecdbba88dad97860
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:36 -07:00
Carter Cooper
a58cc25dbb msm: kgsl: Add support for 8226v2
8226v2 has a new spin of the 305B GPU with a different chip ID.
Add an entry to the GPU list for the new chip ID.  Unfortunately
we can't use the normal ANY_ID trick here because we have so many
different types of chips that use the same core, major and minor
values and differ only in the patchlevel.

Change-Id: Ic0dedbad9bb856a25b71cb825a2960fd0e1d4198
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:36 -07:00
Carter Cooper
91c74a4d97 msm: kgsl: don't store rptr in struct adreno_ringbuffer
Since the rptr is written by the GPU, there's no point
in keeping a copy in the ringbuffer struct where it will
likely be out of date. If you need to look at the ringbuffer,
read it into a local variable with adreno_get_rptr().

Change-Id: Ibf1ba0b9c71a93f65a5c85a58328b2202a27af3f
Signed-off-by: Jeremy Gebben <jgebben@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:35 -07:00
Carter Cooper
3324f8fd34 msm: kgsl: Fix a missing semicolon in the KGSL IOMMU handler
in check_if_freed() a call to kgsl_get_memory_usage() was terminated with
a comma instead of a semicolon.  Through a quirk in a macro this somehow
managed to compile and function properly but that doesn't make it okay.

CRs-fixed: 497280
Change-Id: Ic0dedbadfdf901bbc68b7f8cefb231d08dd01a95
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:35 -07:00
Carter Cooper
6373f66059 msm: kgsl: Enable special case performance counters
Special case performance counters do not have select registers.
Enabling performance counters first checks that the counters we want
are valid and have select registers, then it would enable the counters.
The special case performance registers were not being enabled in this
case since they fail the initial test.  Move these special cases to
before the select register error checking and perform their own sanity
checks before enabling the performance counters

Change-Id: I716103fb6bfb97ba3e198503531af139fb1725f8
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:34 -07:00
Carter Cooper
5aa6d0eb25 msm: kgsl: Do not hold memory spinlock when calling find region function
The function kgsl_sharedmem_find_region holds the memory spinlock
at the beginning of the function so we do not need to hold the lock
before calling the function

Change-Id: I20ee32e0ed6aee6ed61cdd4fb7a9cc08a876fc84
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:34 -07:00
Carter Cooper
d57e7376e8 msm: kgsl: Convert all physical address to type phys_addr_t
Future chipsets may not define phys_addr_t to 32 bits hence convert
all physical address variables to this type.

Change-Id: I4ac5bd1aabda455456ff867c973a264f68992404
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:33 -07:00
Carter Cooper
2a85e2978d msm: kgsl: Make cff capture a device specific property
Make CFF capture a device specific property. This allows the control
of CFF for a particular device without CFF interferance from another
device. This will be useful when we have a virtual device and need to
only capture CFF for the virtual device. CFF capture can only be
turned on for one device at a time.

Change-Id: I14c5a4442ad05327de1413d98bf795dbd196119d
Signed-off-by: Shubhraprakash Das <sadas@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:32 -07:00
Carter Cooper
0747e5340b msm: kgsl: Remove nap_allowed variable and functionality
Allow NAP on all targets.  The splitting of the clock enable
and disable calls into enable/prepare and disable/unprepare
allows us to safely make this change for all targets.

Change-Id: I03d909b86aef33631a887d159cf0a807a6d0ae75
Signed-off-by: Lucille Sylvester <lsylvest@codeaurora.org>
Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
Signed-off-by: Iliyan Malchev <malchev@google.com>
2013-09-11 22:41:32 -07:00
Carter Cooper
42ee55d4bd msm: kgsl: Bypass SP counter 4 on A33x
SP performance counter 4 is broken on A33x targets so do not assign
this counter.  The counter does not reliably return correct values
which can make results misleading.

Change-Id: I87c36e021c547b630e8dfd89abbdb5c65d4b3c46
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:31 -07:00
Carter Cooper
cb39fe17b1 msm: kgsl: Do not start performance counters if not present
Certain hardware does not support performance counters and does not set
them.  Ensure the uninitialized performance counter variable does not
get dereferenced in this instance.

Change-Id: I8692090d60ff1e6a0c45b5699b90d9808ef61c5a
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:31 -07:00
Carter Cooper
98538f226a msm: kgsl: Use ion_share_dma_buf_fd to get ion fd
ion_share_dma_buf is now use to get the share buffer.
Use ion_share_dma_buf_fd to get the ion fd.

Change-Id: I6f0d30782e62e245e89d907ffe22bbd4b7a5d0b0
Signed-off-by: Alex Wong <waiw@codeaurora.org>
Signed-off-by: Carter Cooper <ccooper@codeaurora.org>
2013-09-11 22:41:30 -07:00