platform/upstream/libSkiaSharp.git
9 years agoImprove caching of special case paths in GrStencilAndCoverPathRenderer
kkinnunen [Thu, 21 May 2015 07:37:30 +0000 (00:37 -0700)]
Improve caching of special case paths in GrStencilAndCoverPathRenderer

Cache lines and oval paths in their own cache domains. Skia has many
hard-to-replace codepaths that create volatile paths out of lines or
ovals.

Results for amd64:
               desk_tigersvg.skp_1 3.06ms -> 3.07ms 1x
                   tabl_cnet.skp_1  2.3ms ->  2.3ms 1x
                  desk_baidu.skp_1 8.99ms -> 8.98ms 1x
                desk_weather.skp_1 4.58ms -> 4.57ms 1x
               desk_samoasvg.skp_1 12.3ms -> 12.3ms 1x
            tabl_gamedeksiam.skp_1 15.8ms -> 15.7ms 1x
             desk_chalkboard.skp_1 14.9ms -> 14.9ms 1x
                 desk_mapsvg.skp_1 6.57ms -> 6.54ms 1x
              desk_wordpress.skp_1  2.2ms -> 2.19ms 1x
               tabl_slashdot.skp_1 6.91ms -> 6.84ms 0.99x
               desk_linkedin.skp_1  7.7ms -> 7.58ms 0.98x
      desk_googlespreadsheet.skp_1 58.7ms -> 57.7ms 0.98x
                  tabl_ukwsj.skp_1 7.67ms -> 7.53ms 0.98x
               tabl_engadget.skp_1 4.71ms -> 4.61ms 0.98x
                 desk_carsvg.skp_1  116ms ->  114ms 0.98x
                tabl_nytimes.skp_1 3.71ms -> 3.61ms 0.97x
desk_googlespreadsheetdashed.skp_1 25.8ms -> 24.9ms 0.97x
                   tabl_hsfi.skp_1  5.3ms ->  5.1ms 0.96x
               tabl_techmeme.skp_1  2.9ms ->  2.8ms 0.96x
                    tabl_cnn.skp_1 6.88ms -> 6.62ms 0.96x
                   desk_espn.skp_1 9.12ms -> 8.64ms 0.95x
                    desk_gws.skp_1 5.15ms -> 4.88ms 0.95x
                  tabl_gspro.skp_1 4.48ms ->  4.2ms 0.94x
           desk_yahooanswers.skp_1 6.84ms ->  6.3ms 0.92x
                 tabl_pravda.skp_1 11.1ms -> 10.1ms 0.91x
                tabl_sahadan.skp_1 11.8ms -> 10.7ms 0.91x
                desk_wowwiki.skp_1 8.48ms -> 7.58ms 0.89x
             tabl_googleblog.skp_1    6ms -> 5.34ms 0.89x
           tabl_worldjournal.skp_1 6.08ms -> 5.35ms 0.88x
                desk_booking.skp_1 15.3ms -> 13.4ms 0.88x
          tabl_androidpolice.skp_1 15.5ms -> 13.5ms 0.87x
                desk_twitter.skp_1 12.2ms -> 10.6ms 0.87x
                 tabl_nofolo.skp_1 5.49ms -> 4.76ms 0.87x
             desk_mobilenews.skp_1   22ms -> 18.9ms 0.86x
             desk_forecastio.skp_1 9.47ms -> 8.05ms 0.85x
      tabl_culturalsolutions.skp_1 6.21ms -> 5.28ms 0.85x
                desk_youtube.skp_1 16.1ms -> 13.5ms 0.84x
                    tabl_mlb.skp_1 9.75ms -> 8.01ms 0.82x
                   tabl_digg.skp_1  5.2ms -> 4.22ms 0.81x
                desk_blogger.skp_1 10.2ms -> 8.24ms 0.81x
            desk_gmailthread.skp_1 26.8ms -> 21.6ms 0.81x
             desk_googleplus.skp_1 10.5ms -> 8.39ms 0.8x
               tabl_frantzen.skp_1 4.55ms -> 3.58ms 0.79x
              desk_pinterest.skp_1 8.85ms -> 6.88ms 0.78x
                   desk_ebay.skp_1 10.5ms -> 8.15ms 0.77x
           tabl_transformice.skp_1 4.93ms ->  3.5ms 0.71x

Results for arm_v7_neon:
               desk_samoasvg.skp_1 13.9ms -> 14.6ms 1.05x
                 desk_mapsvg.skp_1 8.31ms -> 8.75ms 1.05x
             tabl_deviantart.skp_1 1.41ms -> 1.45ms 1.02x
                desk_weather.skp_1  3.8ms -> 3.88ms 1.02x
                 desk_sfgate.skp_1 3.06ms ->  3.1ms 1.01x
          desk_css3gradients.skp_1 2.78ms -> 2.79ms 1x
                   desk_espn.skp_1 6.52ms -> 6.43ms 0.99x
                    desk_gws.skp_1 4.16ms -> 4.09ms 0.98x
                    tabl_cnn.skp_1 4.66ms -> 4.58ms 0.98x
                   tabl_hsfi.skp_1 3.49ms -> 3.42ms 0.98x
           tabl_cuteoverload.skp_1 2.41ms -> 2.35ms 0.98x
           desk_yahooanswers.skp_1 5.28ms -> 5.14ms 0.97x
                 desk_carsvg.skp_1 90.8ms -> 87.9ms 0.97x
                  tabl_gspro.skp_1 2.81ms -> 2.71ms 0.96x
                desk_wowwiki.skp_1 5.85ms -> 5.63ms 0.96x
                 tabl_pravda.skp_1  7.8ms ->  7.5ms 0.96x
                desk_twitter.skp_1 8.14ms ->  7.8ms 0.96x
          tabl_androidpolice.skp_1 10.4ms -> 9.96ms 0.96x
             tabl_googleblog.skp_1 4.06ms -> 3.83ms 0.95x
             desk_mobilenews.skp_1 15.2ms ->   14ms 0.93x
                desk_booking.skp_1 9.89ms -> 9.08ms 0.92x
             desk_forecastio.skp_1 6.16ms -> 5.65ms 0.92x
                desk_blogger.skp_1 6.17ms -> 5.66ms 0.92x
                   tabl_digg.skp_1 3.73ms -> 3.41ms 0.91x
                 tabl_nofolo.skp_1 3.82ms -> 3.47ms 0.91x
           tabl_worldjournal.skp_1 4.24ms -> 3.84ms 0.9x
                desk_youtube.skp_1 10.5ms -> 9.39ms 0.9x
             desk_googleplus.skp_1 7.01ms -> 6.19ms 0.88x
                    tabl_mlb.skp_1 5.91ms -> 5.22ms 0.88x
         tabl_googlecalendar.skp_1 10.7ms -> 9.44ms 0.88x
            desk_gmailthread.skp_1 19.2ms -> 16.8ms 0.88x
                   desk_ebay.skp_1 5.68ms -> 4.93ms 0.87x
              desk_pinterest.skp_1 5.99ms -> 5.08ms 0.85x
             desk_googlehome.skp_1 3.31ms -> 2.71ms 0.82x
           tabl_transformice.skp_1 3.03ms -> 2.44ms 0.81x
                 desk_amazon.skp_1 6.05ms -> 4.84ms 0.8x
               desk_facebook.skp_1 12.6ms -> 9.62ms 0.76x

Review URL: https://codereview.chromium.org/1120023005

9 years agoUse high precision vertex attributes.
senorblanco [Wed, 20 May 2015 21:03:42 +0000 (14:03 -0700)]
Use high precision vertex attributes.

Specifying vertex attributes and the view matrix as mediump causes bad artifacts on Mali T6XX.

Covered by the bigmatrix GM in msaa4 mode.

BUG:skia=3545,3771

Review URL: https://codereview.chromium.org/1145273002

9 years agopurge imagefilter cache so we can better track leaks
reed [Wed, 20 May 2015 20:22:58 +0000 (13:22 -0700)]
purge imagefilter cache so we can better track leaks

BUG=skia:

Review URL: https://codereview.chromium.org/1148973002

9 years agocheck for big sizes in NewData
reed [Wed, 20 May 2015 20:06:00 +0000 (13:06 -0700)]
check for big sizes in NewData

BUG=486977

Review URL: https://codereview.chromium.org/1148873004

9 years agoDon't serialize SkPictures in SkPictureShaders when in untrusted mode.
mtklein [Wed, 20 May 2015 19:05:15 +0000 (12:05 -0700)]
Don't serialize SkPictures in SkPictureShaders when in untrusted mode.

This requires we "first" add a has-picture bool to SkPictureShader serialized format.

BUG=chromium:486947, billions and billions of others.

Review URL: https://codereview.chromium.org/1151663002

9 years agoFix for bisector computation bug in GrAAConvexTessellator
robertphillips [Wed, 20 May 2015 18:49:55 +0000 (11:49 -0700)]
Fix for bisector computation bug in GrAAConvexTessellator

Review URL: https://codereview.chromium.org/1151623002

9 years agoHave SkPicture inherit from SkRefCnt.
mtklein [Wed, 20 May 2015 17:55:49 +0000 (10:55 -0700)]
Have SkPicture inherit from SkRefCnt.

This re-enables adoption tracking for SkPictures in Blink,
which should be green now that crrev.com/1136123011 has landed.

BUG=skia:3847

Review URL: https://codereview.chromium.org/1145153002

9 years agoMake SkEmptyPicture a singleton.
mtklein [Wed, 20 May 2015 17:32:22 +0000 (10:32 -0700)]
Make SkEmptyPicture a singleton.

In my confusion yesterday I accidentally left this as a non-singleton.
The issue in Blink was not related to this being a singleton,
and it should be safe to make it one.

This means recording an empty picture properly costs zero mallocs.

BUG=skia:

Review URL: https://codereview.chromium.org/1147053002

9 years agoMore efficient SkRecorder::flushMiniRecorder()
mtklein [Wed, 20 May 2015 17:16:49 +0000 (10:16 -0700)]
More efficient SkRecorder::flushMiniRecorder()

This should involve no mallocs, frees, or memcpys, and less refcounting.

BUG=skia:

Review URL: https://codereview.chromium.org/1144173002

9 years agoSort build files for consistent link order.
bungeman [Wed, 20 May 2015 16:26:47 +0000 (09:26 -0700)]
Sort build files for consistent link order.

Prior to the introduction of find.py, GMs were liked in the order they
were listed in the gypi file, which was generally alphabetically. This
made it fairly easy to predict where slides would show up in SampleApp
and the order was consistent. This simply sorts the list of files in
find.py to restore the expectation that files should be listed in the
build in alphabetical order.

Review URL: https://codereview.chromium.org/1144973003

9 years agoFont variations.
bungeman [Wed, 20 May 2015 16:21:04 +0000 (09:21 -0700)]
Font variations.

Multiple Master and TrueType fonts support variation axes.
This implements back-end support for axes on platforms which
support it.

Committed: https://skia.googlesource.com/skia/+/05773ed30920c0214d1433c07cf6360a05476c97

Committed: https://skia.googlesource.com/skia/+/3489ee0f4fa34f124f9de090d12bdc2107d52aa9

Review URL: https://codereview.chromium.org/1027373002

9 years agofix win 8 bot
caryclark [Wed, 20 May 2015 15:22:45 +0000 (08:22 -0700)]
fix win 8 bot

Comment out assert (runtime documentation)
It fails on Win 8 because the result isn't bit identical.

TBR=bungeman@google.com

Review URL: https://codereview.chromium.org/1148053003

9 years agoUnmount before app-install
stephana [Wed, 20 May 2015 14:31:32 +0000 (07:31 -0700)]
Unmount before app-install
TBR=borenet

NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1145093005

9 years agoDon't fail SkMergeImageFilter if one of the inputs are empty
fs [Wed, 20 May 2015 07:52:17 +0000 (00:52 -0700)]
Don't fail SkMergeImageFilter if one of the inputs are empty

If one of the inputs to a SkMergeImageFilter was clipped away or
otherwise caused the filterImage(...) invocation for it to return
false, the entire effect would be "failed" and return false --
regardless of if it had produced a result or not.
Instead of returning false directly if filterImage(...) for a source
returned false, consider all the inputs, and then only return false if
all of them do.

BUG=chromium:489046

Review URL: https://codereview.chromium.org/1133523006

9 years agosmall cleanup of GrAtlas
joshualitt [Tue, 19 May 2015 22:05:24 +0000 (15:05 -0700)]
small cleanup of GrAtlas

BUG=skia:

Committed: https://skia.googlesource.com/skia/+/d706f11b6e3f4398ab93b23458a7599ee324be2c

Review URL: https://codereview.chromium.org/1142263002

9 years agoRevert of small cleanup of GrAtlas (patchset #2 id:20001 of https://codereview.chromi...
bungeman [Tue, 19 May 2015 21:45:11 +0000 (14:45 -0700)]
Revert of small cleanup of GrAtlas (patchset #2 id:20001 of https://codereview.chromium.org/1142263002/)

Reason for revert:
Broke compile on Linux

Original issue's description:
> small cleanup of GrAtlas
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/d706f11b6e3f4398ab93b23458a7599ee324be2c

TBR=robertphillips@google.com,joshualitt@google.com,jvanverth@google.com,joshualitt@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1142273002

9 years agosmall cleanup of GrAtlas
joshualitt [Tue, 19 May 2015 21:41:41 +0000 (14:41 -0700)]
small cleanup of GrAtlas

BUG=skia:

Review URL: https://codereview.chromium.org/1142263002

9 years agoAdding immediate mode draw target for debug
joshualitt [Tue, 19 May 2015 21:28:04 +0000 (14:28 -0700)]
Adding immediate mode draw target for debug

BUG=skia:

Review URL: https://codereview.chromium.org/1126043007

9 years agoimplement --quiet for DM
reed [Tue, 19 May 2015 21:13:31 +0000 (14:13 -0700)]
implement --quiet for DM

BUG=skia:

Review URL: https://codereview.chromium.org/1139413003

9 years agoAdd a newline to the font load debug message
kkinnunen [Tue, 19 May 2015 20:50:50 +0000 (13:50 -0700)]
Add a newline to the font load debug message

Add a newline to the font load debug message. Helps reading nanobench
results. Otherwise the message "Resource /fonts/Funkster.ttf not a valid
font." causes first result be hard to read or missing.

Review URL: https://codereview.chromium.org/1142183002

9 years agoSketch splitting SkPicture into an interface and SkBigPicture.
mtklein [Tue, 19 May 2015 18:11:26 +0000 (11:11 -0700)]
Sketch splitting SkPicture into an interface and SkBigPicture.

Adds small pictures for drawRect(), drawTextBlob(), and drawPath().
These cover about 89% of draw calls from Blink SKPs,
and about 25% of draw calls from our GMs.

SkPicture handles:
  - serialization and deserialization
  - unique IDs

Everything else is left to the subclasses:
  - playback(), cullRect()
  - hasBitmap(), hasText(), suitableForGPU(), etc.
  - LayerInfo / AccelData if applicable.

The time to record a 1-op picture improves a good chunk
(2 mallocs to 1), and the time to record a 0-op picture
greatly improves (2 mallocs to none):

    picture_overhead_draw:   450ns -> 350ns
    picture_overhead_nodraw: 300ns -> 90ns

BUG=skia:

Committed: https://skia.googlesource.com/skia/+/c92c129ff85b05a714bd1bf921c02d5e14651f8b

Latest blink_linux_rel:

http://build.chromium.org/p/tryserver.blink/builders/linux_blink_rel/builds/61248

Committed: https://skia.googlesource.com/skia/+/15877b6eae33a9282458bdb904a6d00440eca0ec

http://build.chromium.org/p/tryserver.blink/builders/linux_blink_rel/builds/62015

Review URL: https://codereview.chromium.org/1112523006

9 years agohandle large conic strokes better
caryclark [Tue, 19 May 2015 18:05:37 +0000 (11:05 -0700)]
handle large conic strokes better

A stroked conic computes the outset quad's control point by
computing the intersection of the quad's endpoints. If the
the denominator used to compute the scale factor for the
control point is small, check to see if the numerator is also
small so that the division stays bounded.

Also clean up error returns and internal function calls to
simplify the code.

Additionally, remove comic max curvature (unimplemented) and call
extrema functions instead to handle cases where the conic is degenerate
or is a line.

R=reed@google.com, fmalita@chromium.org
BUG=skia:3843

Review URL: https://codereview.chromium.org/1144883003

9 years agoDocumentation: SkCanvas API
halcanary [Tue, 19 May 2015 17:21:29 +0000 (10:21 -0700)]
Documentation: SkCanvas API
NOTRY=true
DOCS_PREVIEW= https://skia.org/?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api/skcanvas?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api/skpaint?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api/skrect?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api/skregion?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api/skmatrix?cl=1127383010
DOCS_PREVIEW= https://skia.org/user/api/canvas?cl=1127383010

Review URL: https://codereview.chromium.org/1127383010

9 years agorename GrDrawTargetCaps to GrCaps
bsalomon [Tue, 19 May 2015 16:29:46 +0000 (09:29 -0700)]
rename GrDrawTargetCaps to GrCaps

Review URL: https://codereview.chromium.org/1133123009

9 years agoPreliminary attempt to remove batch tracker
joshualitt [Tue, 19 May 2015 15:23:30 +0000 (08:23 -0700)]
Preliminary attempt to remove batch tracker

BUG=skia:

Committed: https://skia.googlesource.com/skia/+/cbfe91d82500f4ae8c3ff7bd74b3021a4b89fd84

Review URL: https://codereview.chromium.org/1139723004

9 years agoRevert of Preliminary attempt to remove batch tracker (patchset #3 id:40001 of https...
joshualitt [Tue, 19 May 2015 14:15:28 +0000 (07:15 -0700)]
Revert of Preliminary attempt to remove batch tracker (patchset #3 id:40001 of https://codereview.chromium.org/1139723004/)

Reason for revert:
breaking bots

Original issue's description:
> Preliminary attempt to remove batch tracker
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/cbfe91d82500f4ae8c3ff7bd74b3021a4b89fd84

TBR=robertphillips@google.com,joshualitt@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1132323003

9 years agoPreliminary attempt to remove batch tracker
joshualitt [Tue, 19 May 2015 13:49:32 +0000 (06:49 -0700)]
Preliminary attempt to remove batch tracker

BUG=skia:

Review URL: https://codereview.chromium.org/1139723004

9 years agoThis allows to restart the device.
stephana [Tue, 19 May 2015 13:27:09 +0000 (06:27 -0700)]
This allows to restart the device.

BUG=skia:
TBR=borenet

Review URL: https://codereview.chromium.org/1137873007

9 years agoFix GrAARectRenderer's handling of unsorted nested rects
robertphillips [Tue, 19 May 2015 11:35:38 +0000 (04:35 -0700)]
Fix GrAARectRenderer's handling of unsorted nested rects

What is going on here is that, after the mapPoints in fillAANestedRects, devInside was upside down so the isEmpty check was always firing. I don't see why we need to avoid having devInside sorted.

BUG=488103

Review URL: https://codereview.chromium.org/1135753004

9 years agoImprove caching of dashed paths in GrStencilAndCoverPathRenderer
kkinnunen [Tue, 19 May 2015 06:02:07 +0000 (23:02 -0700)]
Improve caching of dashed paths in GrStencilAndCoverPathRenderer

Improve caching of dashed paths in GrStencilAndCoverPathRenderer.
Look up the (NVPR specific) GrGLPath based on GrStrokeInfo and
the original path.

Use unique keys for all GrPaths.

Dash the path with Skia dash stroker and use that path geometry for
NVPR path.

NVPR internal dashing stroke is not used, because the dashing
implementation of NVPR does not match Skia implementation.

Review URL: https://codereview.chromium.org/1116123003

9 years agoMake GrResourceCache perf less sensitive to key length change
kkinnunen [Tue, 19 May 2015 05:47:33 +0000 (22:47 -0700)]
Make GrResourceCache perf less sensitive to key length change

Make GrResourceCache performance less sensitive to key length change.
The memcmp in GrResourceKey is called when SkTDynamicHash jumps the
slots to find the hash by a index. Avoid most of the memcmps by
comparing the hash first.

This is important because small changes in key data length can cause
big performance regressions. The theory is that key length change causes
different hash values. These hash values might trigger memcmps that
originally weren't there, causing the regression.

Adds few specialized benches to grresourcecache_add to test different
key lengths. The tests are run only on release, because on debug the
SkTDynamicHash validation takes too long, and adding many such delays
to development test runs would be unproductive. On release the tests
are quite fast.

Effect of this patch to the added tests on amd64:
grresourcecache_find_10  738us ->  768us        1.04x
 grresourcecache_find_2  472us ->  476us        1.01x
grresourcecache_find_25  841us ->  845us        1x
 grresourcecache_find_4  565us ->  531us        0.94x
grresourcecache_find_54 1.18ms ->  1.1ms        0.93x
 grresourcecache_find_5  834us ->  749us        0.9x
 grresourcecache_find_3  620us ->  542us        0.87x
 grresourcecache_add_25 2.74ms -> 2.24ms        0.82x
 grresourcecache_add_56 3.23ms -> 2.56ms        0.79x
 grresourcecache_add_54 3.34ms -> 2.62ms        0.78x
  grresourcecache_add_5 2.68ms ->  2.1ms        0.78x
 grresourcecache_add_10  2.7ms -> 2.11ms        0.78x
  grresourcecache_add_2 1.85ms -> 1.41ms        0.76x
    grresourcecache_add 1.84ms ->  1.4ms        0.76x
  grresourcecache_add_4 1.99ms -> 1.49ms        0.75x
  grresourcecache_add_3 2.11ms -> 1.55ms        0.73x
 grresourcecache_add_55   39ms -> 13.9ms        0.36x
grresourcecache_find_55 23.2ms -> 6.21ms        0.27x

On arm64 the results are similar.

On arm_v7_neon, the results lack the discontinuity at 55:
    grresourcecache_add 4.06ms -> 4.26ms        1.05x
  grresourcecache_add_2 4.05ms -> 4.23ms        1.05x
   grresourcecache_find 1.28ms ->  1.3ms        1.02x
grresourcecache_find_56 3.35ms -> 3.32ms        0.99x
 grresourcecache_find_2 1.31ms -> 1.29ms        0.99x
grresourcecache_find_54 3.28ms -> 3.24ms        0.99x
  grresourcecache_add_5 6.38ms -> 6.26ms        0.98x
 grresourcecache_add_55 8.44ms -> 8.24ms        0.98x
 grresourcecache_add_25 7.03ms -> 6.86ms        0.98x
grresourcecache_find_25  2.7ms -> 2.59ms        0.96x
 grresourcecache_find_4 1.45ms -> 1.38ms        0.95x
grresourcecache_find_10 2.52ms -> 2.39ms        0.95x
grresourcecache_find_55 3.54ms -> 3.33ms        0.94x
 grresourcecache_find_5  2.5ms -> 2.32ms        0.93x
 grresourcecache_find_3 1.57ms -> 1.43ms        0.91x

The extremely slow case, 55, is postulated to be due to the index jump
collisions running the memcmp. This is not visible on arm_v7_neon probably due
to hash function producing different results for 32 bit architectures.

This change is needed for extending path cache key in Gr
NV_path_rendering codepath. Extending is needed in order to add dashed
paths to the path cache.

Review URL: https://codereview.chromium.org/1132723003

9 years agoImprove NVPR stroke accuracy to fix thick strokes
kkinnunen [Tue, 19 May 2015 05:25:47 +0000 (22:25 -0700)]
Improve NVPR stroke accuracy to fix thick strokes

Set the "path stroke error bound" path parameter to 0.02 for all paths.
This means that the stroked path area will be within 98% of the stroke
width in path space.

This should fix many cases where NVPR stroked paths were visibly different to
Skia stroked paths. One such path is in dashcubics gm.

This increases the amount of subdivisions the path object creation will
make for paths that need it. This in turn will increase gpu object space
requirements sligthly. Both of these effects should be unnoticeable.

GL_NV_path_rendering.txt:
"""
    Every path object has a stroke approximation bound parameter
    (PATH_STROKE_BOUND_NV) that is a floating-point value /sab/ clamped
    between 0.0 and 1.0 and set and queried with the PATH_STROKE_BOUND_NV
    path parameter.  Exact determination of samples swept an orthogonal
    centered line segment along cubic Bezier segments and rational
    quadratic Bezier curves (so non-circular partial elliptical arcs) is
    intractable for real-time rendering so an approximation is required;
    /sab/ intuitively bounds the approximation error as a percentage of
    the path object's stroke width.  Specifically, this path parameter
    requests the implementation to stencil any samples within /sweep/
    object space units of the exact sweep of the path's cubic Bezier
    segments or partial elliptical arcs to be sampled by the stroke where

      sweep = ((1-sab)*sw)/2

    where /sw/ is the path object's stroke width.  The initial value
    of /sab/ when a path is created is 0.2.  In practical terms, this
    initial value means the stencil sample positions coverage within 80%
    (100%-20%) of the stroke width of cubic and rational quadratic stroke
    segments should be sampled.
"""

BUG=skia:2049

Review URL: https://codereview.chromium.org/1124423007

9 years agoMake GrStrokeInfo inherit from SkStrokeRec
kkinnunen [Tue, 19 May 2015 05:23:54 +0000 (22:23 -0700)]
Make GrStrokeInfo inherit from SkStrokeRec

Make the code more readable by inheriting GrStrokeInfo from SkStrokeRec.
This should avoid the long .getStrokeRec() and .getStrokeRecPtr(). These
were a bit cumbersome especially in cases where an alias variable was
created for these, and then the reader had to keep track to which
StrokeInfo member the StrokeRec alias was pointing.

Removes SkStrokeRec::SkStrokeRec(const SkStrokeRec&). It was memcpying.
Try to play it safe wrt compiler using the possible padding of
superclass for subclass members. Instead, let the compiler generate
the copy constructor. Assignment operator was already
compiler-generated, so at least in that way this is consistent.

Renames GrStrokeInfo::applyDash to applyDashToPath for consistency
with superclass applyToPath.

Review URL: https://codereview.chromium.org/1128113008

9 years agoRevert of Sketch splitting SkPicture into an interface and SkBigPicture. (patchset...
mtklein [Mon, 18 May 2015 21:53:43 +0000 (14:53 -0700)]
Revert of Sketch splitting SkPicture into an interface and SkBigPicture. (patchset #25 id:480001 of https://codereview.chromium.org/1112523006/)

Reason for revert:
win_chromium_compile_dbg_ng

FAILED: ninja -t msvc -e environment.x86 -- E:\b\build\goma/gomacc "E:\b\depot_tools\win_toolchain\vs2013_files\VC\bin\amd64_x86\cl.exe" /nologo /showIncludes /FC @obj\third_party\skia\src\core\skia.SkBitmapHeap.obj.rsp /c ..\..\third_party\skia\src\core\SkBitmapHeap.cpp /Foobj\third_party\skia\src\core\skia.SkBitmapHeap.obj /Fdobj\skia\skia.cc.pdb
e:\b\build\slave\win\build\src\third_party\skia\include\core\skpicture.h(176) : error C2487: 'CURRENT_PICTURE_VERSION' : member of dll interface class may not be declared with dll interface

Original issue's description:
> Sketch splitting SkPicture into an interface and SkBigPicture.
>
> Adds small pictures for drawRect(), drawTextBlob(), and drawPath().
> These cover about 89% of draw calls from Blink SKPs,
> and about 25% of draw calls from our GMs.
>
> SkPicture handles:
>   - serialization and deserialization
>   - unique IDs
>
> Everything else is left to the subclasses:
>   - playback(), cullRect()
>   - hasBitmap(), hasText(), suitableForGPU(), etc.
>   - LayerInfo / AccelData if applicable.
>
> The time to record a 1-op picture improves a good chunk
> (2 mallocs to 1), and the time to record a 0-op picture
> greatly improves (2 mallocs to none):
>
>     picture_overhead_draw:   450ns -> 350ns
>     picture_overhead_nodraw: 300ns -> 90ns
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/c92c129ff85b05a714bd1bf921c02d5e14651f8b
>
> Latest blink_linux_rel:
>
> http://build.chromium.org/p/tryserver.blink/builders/linux_blink_rel/builds/61248
>
> Committed: https://skia.googlesource.com/skia/+/15877b6eae33a9282458bdb904a6d00440eca0ec

TBR=reed@google.com,robertphillips@google.com,fmalita@chromium.org,mtklein@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1130283004

9 years agoMaking mount more robust
stephana [Mon, 18 May 2015 20:50:05 +0000 (13:50 -0700)]
Making mount more robust

BUG=skia:
TBR=borenet

Review URL: https://codereview.chromium.org/1131933007

9 years agoSketch splitting SkPicture into an interface and SkBigPicture.
mtklein [Mon, 18 May 2015 20:47:17 +0000 (13:47 -0700)]
Sketch splitting SkPicture into an interface and SkBigPicture.

Adds small pictures for drawRect(), drawTextBlob(), and drawPath().
These cover about 89% of draw calls from Blink SKPs,
and about 25% of draw calls from our GMs.

SkPicture handles:
  - serialization and deserialization
  - unique IDs

Everything else is left to the subclasses:
  - playback(), cullRect()
  - hasBitmap(), hasText(), suitableForGPU(), etc.
  - LayerInfo / AccelData if applicable.

The time to record a 1-op picture improves a good chunk
(2 mallocs to 1), and the time to record a 0-op picture
greatly improves (2 mallocs to none):

    picture_overhead_draw:   450ns -> 350ns
    picture_overhead_nodraw: 300ns -> 90ns

BUG=skia:

Committed: https://skia.googlesource.com/skia/+/c92c129ff85b05a714bd1bf921c02d5e14651f8b

Latest blink_linux_rel:

http://build.chromium.org/p/tryserver.blink/builders/linux_blink_rel/builds/61248

Review URL: https://codereview.chromium.org/1112523006

9 years agoEmpty picture shaders should draw nothing.
mtklein [Mon, 18 May 2015 20:44:35 +0000 (13:44 -0700)]
Empty picture shaders should draw nothing.

BUG=skia:

Review URL: https://codereview.chromium.org/1142053004

9 years agoSkPDF: Add Sfntly to DEPS, gyp
halcanary [Mon, 18 May 2015 20:15:56 +0000 (13:15 -0700)]
SkPDF: Add Sfntly to DEPS, gyp

Note: this can be disabled via:
    GYP_DEFINES='skia_pdf_use_sfntly=0

Warning: dm is 34% slower and uses 9% more memory.  This is
okay.

Motivation: We want to test this code path in DM, since it is
always used by Chromium and Android.

BUG=skia:3563

Committed: https://skia.googlesource.com/skia/+/6a53b04e26749ea61f690ece408f2a1c0a5ad5bb

Review URL: https://codereview.chromium.org/1134683006

9 years agoPrevent integer wrap around for malloc size when creating a SkRegion
djsollen [Mon, 18 May 2015 20:05:11 +0000 (13:05 -0700)]
Prevent integer wrap around for malloc size when creating a SkRegion

BUG=484998

Review URL: https://codereview.chromium.org/1143603003

9 years agoDon't do discards when on Adreno4xx due to driver bug.
egdaniel [Mon, 18 May 2015 20:04:26 +0000 (13:04 -0700)]
Don't do discards when on Adreno4xx due to driver bug.

BUG=skia:

Review URL: https://codereview.chromium.org/1126423006

9 years agoadd GM to test extractAlpha
reed [Mon, 18 May 2015 19:57:56 +0000 (12:57 -0700)]
add GM to test extractAlpha

BUG=skia:
TBR=

Review URL: https://codereview.chromium.org/1142123003

9 years agofix builder winding again
caryclark [Mon, 18 May 2015 19:56:57 +0000 (12:56 -0700)]
fix builder winding again

Record the nesting level when finding the edge winding contribution
so that inner edges can be reversed as needed.

R=fmalita@chromium.org
BUG=skia:3838

Review URL: https://codereview.chromium.org/1140383002

9 years agoRemove SK_LEGACY_DRAWPICTURECALLBACK from skia_for_chromium_defines.gypi
Florin Malita [Mon, 18 May 2015 19:14:08 +0000 (15:14 -0400)]
Remove SK_LEGACY_DRAWPICTURECALLBACK from skia_for_chromium_defines.gypi

The flag now lives in Chromium's SkUserConfig.h.

R=reed@google.com

Review URL: https://codereview.chromium.org/1133243009

9 years agoRevert of SkPDF: Add Sfntly to DEPS, gyp, SkUserConfig (patchset #7 id:570001 of...
halcanary [Mon, 18 May 2015 17:27:16 +0000 (10:27 -0700)]
Revert of SkPDF: Add Sfntly to DEPS, gyp, SkUserConfig (patchset #7 id:570001 of https://codereview.chromium.org/1134683006/)

Reason for revert:
break cros build

Original issue's description:
> SkPDF: Add Sfntly to DEPS, gyp
>
> Note: this can be disabled via:
>     GYP_DEFINES='skia_pdf_use_sfntly=0
>
> Warning: dm is 34% slower and uses 9% more memory.  This is
> okay.
>
> Motivation: We want to test this code path in DM, since it is
> always used by Chromium and Android.
>
> BUG=skia:3563
>
> Committed: https://skia.googlesource.com/skia/+/6a53b04e26749ea61f690ece408f2a1c0a5ad5bb

TBR=reed@google.com,mtklein@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:3563

Review URL: https://codereview.chromium.org/1128353004

9 years agoSkPDF: Add Sfntly to DEPS, gyp
halcanary [Mon, 18 May 2015 17:18:58 +0000 (10:18 -0700)]
SkPDF: Add Sfntly to DEPS, gyp

Note: this can be disabled via:
    GYP_DEFINES='skia_pdf_use_sfntly=0

Warning: dm is 34% slower and uses 9% more memory.  This is
okay.

Motivation: We want to test this code path in DM, since it is
always used by Chromium and Android.

BUG=skia:3563

Review URL: https://codereview.chromium.org/1134683006

9 years agoRevert of Move copy-surface-as-draw fallback to GrGLGpu. (patchset #12 id:220001...
mtklein [Mon, 18 May 2015 16:29:10 +0000 (09:29 -0700)]
Revert of Move copy-surface-as-draw fallback to GrGLGpu. (patchset #12 id:220001 of https://codereview.chromium.org/1144433002/)

Reason for revert:
Many GMs changed, some totally busted.

Original issue's description:
> Move copy-surface-as-draw fallback to GrGLGpu.
>
> Committed: https://skia.googlesource.com/skia/+/5df6fee929823f50c55cc50f7c882a309c1b1de9

TBR=joshualitt@google.com,egdaniel@google.com,bsalomon@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true

Review URL: https://codereview.chromium.org/1142003003

9 years agosk4px the rest of the easy xfermodes.
mtklein [Mon, 18 May 2015 14:03:01 +0000 (07:03 -0700)]
sk4px the rest of the easy xfermodes.

Adds and uses fastMulDiv255Round() where possible,
which approximates x*y/255 as (x*y+x)/256.  Seems like a sizeable
speedup, as seen below on Exclusion, Screen, and Modulate.  The
existing NEON code uses this approximation for
{Src,Dst}x{In,Out,Over}, and without it we'd regress speed there.

This will require rebaselines whether or not we use this
approximation: the x86 bots change if we do, the ARM bots change
if we don't.  None of the diffs are significant.

Desktop:
   Xfermode_Screen_aa 5.82ms -> 5.54ms 0.95x
 Xfermode_Modulate_aa 5.67ms -> 5.36ms 0.95x
Xfermode_Exclusion_aa 6.18ms -> 5.81ms 0.94x
   Xfermode_Exclusion 5.03ms -> 4.24ms 0.84x
      Xfermode_Screen 4.51ms -> 3.59ms 0.8x
    Xfermode_Modulate  4.2ms -> 3.19ms 0.76x
     Xfermode_DstOver 6.73ms -> 3.88ms 0.58x
      Xfermode_SrcOut 6.47ms -> 3.48ms 0.54x
       Xfermode_SrcIn 6.46ms -> 3.46ms 0.54x
      Xfermode_DstOut 6.49ms -> 3.41ms 0.52x
       Xfermode_DstIn  6.5ms -> 3.32ms 0.51x
      Xfermode_Src_aa 9.53ms -> 4.75ms 0.5x
    Xfermode_Clear_aa 9.65ms ->  4.8ms 0.5x
    Xfermode_DstIn_aa 11.5ms -> 5.57ms 0.49x
  Xfermode_DstOver_aa 11.6ms -> 5.63ms 0.49x
   Xfermode_SrcOut_aa 11.6ms ->  5.5ms 0.47x
    Xfermode_SrcIn_aa 11.7ms -> 5.51ms 0.47x
   Xfermode_DstOut_aa 11.7ms ->  5.4ms 0.46x

N7 performance is close enough to 1x that I'm not sure whether
this is a net win, net loss, or truly neutral.  I figure the bots will
show that.

I experimented with another approximation,
(x*(255-y))/255 â‰ˆ (x*(256-y))/256.  This was inconclusive, so I'm
leaving it out for now.

The remaining modes are the complicated conditional ones.

BUG=skia:

Review URL: https://codereview.chromium.org/1141953004

9 years agoSet OpenGLRenderer light center separately from initial setup
scroggo [Mon, 18 May 2015 13:41:35 +0000 (06:41 -0700)]
Set OpenGLRenderer light center separately from initial setup

Cherry-pick from Android.

Fixes master-skia build.

BUG=b/16523629

Review URL: https://codereview.chromium.org/1134403003

9 years agoMove copy-surface-as-draw fallback to GrGLGpu.
bsalomon [Mon, 18 May 2015 13:26:15 +0000 (06:26 -0700)]
Move copy-surface-as-draw fallback to GrGLGpu.

Review URL: https://codereview.chromium.org/1144433002

9 years agoThe path ops builder code needs to determine the winding of each contour added, and...
caryclark [Mon, 18 May 2015 12:12:56 +0000 (05:12 -0700)]
The path ops builder code needs to determine the winding of each contour added, and reverse windings if the contours are nested in other contours.

Cheap (one contour) paths can be evaluated and reversed as needed with a minimum of checking, but multi-contour paths invoke the regular path ops machinery to determine who is contained by whom.

More tests need to be added to verify that all corner cases are considered, but this fixes the cases in the bug thus far.

R=fmalita@chromium.org
TBR=reed@google.com
BUG=skia:3838

Review URL: https://codereview.chromium.org/1129193006

9 years agoGyp: Sanity Part II (GM+Tests)
halcanary [Sun, 17 May 2015 13:47:49 +0000 (06:47 -0700)]
Gyp: Sanity Part II (GM+Tests)

DOCS_PREVIEW= https://skia.org/dev/testing/tests?cl=1133343006

Review URL: https://codereview.chromium.org/1133343006

9 years agoUpdate SKP version
skia.buildbots [Sun, 17 May 2015 08:14:01 +0000 (01:14 -0700)]
Update SKP version

Automatic commit by the RecreateSKPs bot.

TBR=
NO_MERGE_BUILDS

Review URL: https://codereview.chromium.org/1128353003

9 years agoExperiment with find as a road to Gyp sanity.
mtklein [Sat, 16 May 2015 22:47:10 +0000 (15:47 -0700)]
Experiment with find as a road to Gyp sanity.

BUG=skia:

Review URL: https://codereview.chromium.org/1123173005

9 years agoReplace self.NavigateToPage with self.Navigate(self.url) for skia page sets
nednguyen [Sat, 16 May 2015 22:47:02 +0000 (15:47 -0700)]
Replace self.NavigateToPage with self.Navigate(self.url) for skia page sets

BUG=487800

Review URL: https://codereview.chromium.org/1131113005

9 years agoRevert of Font variations. (patchset #26 id:500001 of https://codereview.chromium...
robertphillips [Fri, 15 May 2015 18:30:41 +0000 (11:30 -0700)]
Revert of Font variations. (patchset #26 id:500001 of https://codereview.chromium.org/1027373002/)

Reason for revert:
Appears to be breaking  Linux ARM bots:

FAILED:
/usr/local/google/home/mosaic-role/slave/repo_clients/chromium_tot/chromium/src/../../prebuilt/toolchain/armv7a/bin/armv7a-cros-linux-gnueabi-g++
... -o obj/third_party/skia/src/ports/skia_library.SkFontHost_FreeType.o
../../third_party/skia/src/ports/SkFontHost_FreeType.cpp:37:31: fatal error:
freetype/ftmm.h: No such file or directory
 #include FT_MULTIPLE_MASTERS_H
                               ^
compilation terminated.

Original issue's description:
> Font variations.
>
> Multiple Master and TrueType fonts support variation axes.
> This implements back-end support for axes on platforms which
> support it.
>
> Committed: https://skia.googlesource.com/skia/+/05773ed30920c0214d1433c07cf6360a05476c97
>
> Committed: https://skia.googlesource.com/skia/+/3489ee0f4fa34f124f9de090d12bdc2107d52aa9

TBR=reed@google.com,mtklein@google.com,djsollen@google.com,halcanary@google.com,bungeman@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true

Review URL: https://codereview.chromium.org/1139123008

9 years agoRevert of antialias matrix-image-filter to get smooth diagonals (patchset #6 id:80002...
reed [Fri, 15 May 2015 17:39:17 +0000 (10:39 -0700)]
Revert of antialias matrix-image-filter to get smooth diagonals (patchset #6 id:80002 of https://codereview.chromium.org/1134743003/)

Reason for revert:
likely affect layouttests, so need to add a guard

Original issue's description:
> antialias matrix-image-filter to get smooth diagonals
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/fa33f5a6b770130acdc55f2ffe19dd545665726a

TBR=senorblanco@google.com,robertphillips@google.com,bsalomon@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1128823010

9 years agoSk4px: Difference and Exclusion
mtklein [Fri, 15 May 2015 17:36:21 +0000 (10:36 -0700)]
Sk4px: Difference and Exclusion

This will cause minor (off-by-one) diffs due to a little lost precision:
colortype_xfermodes
mixed_xfermodes
xfermodes2
xfermodeimagefilter
xfermodes3
xfermodes

Desktop:
Xfermode_Difference_aa 9.77ms -> 7.32ms 0.75x
 Xfermode_Exclusion_aa 8.49ms -> 6.21ms 0.73x
   Xfermode_Difference   17ms -> 7.54ms 0.44x
    Xfermode_Exclusion 13.5ms -> 5.09ms 0.38x

N7:
Xfermode_Difference_aa 32.2ms -> 27.6ms 0.86x
   Xfermode_Difference 43.9ms ->   32ms 0.73x
 Xfermode_Exclusion_aa 40.5ms -> 26.7ms 0.66x
    Xfermode_Exclusion 71.5ms -> 23.9ms 0.33x

This wraps up the xfermodes implemented in Sk4f.

BUG=skia:

Review URL: https://codereview.chromium.org/1141213002

9 years agoantialias matrix-image-filter to get smooth diagonals
reed [Fri, 15 May 2015 17:33:31 +0000 (10:33 -0700)]
antialias matrix-image-filter to get smooth diagonals

BUG=skia:

Review URL: https://codereview.chromium.org/1134743003

9 years agoUpdate SVGDevice for RRect and drawPoints
reed [Fri, 15 May 2015 17:11:11 +0000 (10:11 -0700)]
Update SVGDevice for RRect and drawPoints

BUG=skia:

Review URL: https://codereview.chromium.org/1127933003

9 years agoremove localmatrix from GrGeometryProcessor base class
joshualitt [Fri, 15 May 2015 14:56:07 +0000 (07:56 -0700)]
remove localmatrix from GrGeometryProcessor base class

BUG=skia:

Review URL: https://codereview.chromium.org/1131513005

9 years agoMake the c and ac scripts work with sh and without bin in PATH
kkinnunen [Fri, 15 May 2015 12:35:50 +0000 (05:35 -0700)]
Make the c and ac scripts work with sh and without bin in PATH

Make the bin/c and bin/ac scripts work with sh. The scripts are run with
/bin/sh shebang, which fails atleast on ubuntu 12.04 /bin/sh. The sh in
Ubuntu 12.04 is dash.

The fixes are according to the suggestions in http://mywiki.wooledge.org/Bashism

Also run "compare" script with explicit ./bin/ path to support people
who do not have skia/bin in PATH.

Review URL: https://codereview.chromium.org/1139033005

9 years agoadd Min to SkNi, specialized for u8 and u16 on SSE and NEON
mtklein [Fri, 15 May 2015 00:53:04 +0000 (17:53 -0700)]
add Min to SkNi, specialized for u8 and u16 on SSE and NEON

0x8001 / 0x7fff don't seem to work, but we were close: 0x8000 does.

I plan to use this to implement the Difference xfermode,
and it seems generally handy.

BUG=skia:

Review URL: https://codereview.chromium.org/1133933004

9 years agoAdd a test for decoding a gif with sampleSize 4.
scroggo [Thu, 14 May 2015 21:44:13 +0000 (14:44 -0700)]
Add a test for decoding a gif with sampleSize 4.

Prior to https://codereview.chromium.org/1085253002/, this would crash.

Only happens with interlaced gif images with an odd height. (Maybe
there are more restrictions?)

Test image provided by zoran.jovanovic@sonymobile.com for checking in.

Add include before includes.

Review URL: https://codereview.chromium.org/1091053002

9 years agoRemove high ref count tracker from GrFakeRefObj
bsalomon [Thu, 14 May 2015 21:23:11 +0000 (14:23 -0700)]
Remove high ref count tracker from GrFakeRefObj

TBR=robertphillips@google.com

Review URL: https://codereview.chromium.org/1139803003

9 years agofix path op builder
caryclark [Thu, 14 May 2015 21:18:13 +0000 (14:18 -0700)]
fix path op builder

The rewrite of path ops caused the inner contour direction to be reversed.
This exposed an existing bug in path ops builder, namely that the implicit
winding of the internal sum path could hide inner contours if they ended
up in the wrong direction.

Setting the sum path's fill type to even-odd ensures that the inner
contours aren't discarded.

R=fmalita@chromium.org
BUG=skia:3838

Review URL: https://codereview.chromium.org/1126193004

9 years agoFont variations.
bungeman [Thu, 14 May 2015 21:18:02 +0000 (14:18 -0700)]
Font variations.

Multiple Master and TrueType fonts support variation axes.
This implements back-end support for axes on platforms which
support it.

Committed: https://skia.googlesource.com/skia/+/05773ed30920c0214d1433c07cf6360a05476c97

Review URL: https://codereview.chromium.org/1027373002

9 years agoRevert of Implement support for non-scale/translate CTM in image filters. (patchset...
reed [Thu, 14 May 2015 19:25:22 +0000 (12:25 -0700)]
Revert of Implement support for non-scale/translate CTM in image filters. (patchset #4 id:60001 of https://codereview.chromium.org/1140943004/)

Reason for revert:
matriximagefilter needs to antialias its draw, so we get smooth diagonals...

Original issue's description:
> Implement support for non-scale/translate CTM in image filters.
>
> Clone with tweaks of https://codereview.chromium.org/986623003/
>
> pre-cl to guard chrome here: https://codereview.chromium.org/1133403003/
>
> BUG=skia:3288
>
> Committed: https://skia.googlesource.com/skia/+/35786b176c159d2e7a816e9da9b051ef3129d5cb

TBR=robertphillips@google.com,senorblanco@google.com,senorblanco@chromium.org,reed@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:3288

Review URL: https://codereview.chromium.org/1139173002

9 years agoRevert of Temporarily revert just Multiply to see if that's the source of NEON diffs...
mtklein [Thu, 14 May 2015 18:49:01 +0000 (11:49 -0700)]
Revert of Temporarily revert just Multiply to see if that's the source of NEON diffs. (patchset #2 id:20001 of https://codereview.chromium.org/1129293005/)

Reason for revert:
Undo Xor revert.  Getting too confusing now.

Original issue's description:
> Temporarily revert just Multiply to see if that's the source of NEON diffs.
>
> Local testing is confusing and inconclusive.  Pulling out the big guns.
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/5b9f352ff1e245dd48e200f8f8b683f4569547d3
>
> Committed: https://skia.googlesource.com/skia/+/6095260e55ac5f263df26cdde427531a0e7da8dd

TBR=mtklein@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1138073005

9 years agoTemporarily revert just Multiply to see if that's the source of NEON diffs.
mtklein [Thu, 14 May 2015 17:35:33 +0000 (10:35 -0700)]
Temporarily revert just Multiply to see if that's the source of NEON diffs.

Local testing is confusing and inconclusive.  Pulling out the big guns.

BUG=skia:

Committed: https://skia.googlesource.com/skia/+/5b9f352ff1e245dd48e200f8f8b683f4569547d3

Review URL: https://codereview.chromium.org/1129293005

9 years agoRevert of Temporarily revert just Multiply to see if that's the source of NEON diffs...
mtklein [Thu, 14 May 2015 17:18:14 +0000 (10:18 -0700)]
Revert of Temporarily revert just Multiply to see if that's the source of NEON diffs. (patchset #1 id:1 of https://codereview.chromium.org/1129293005/)

Reason for revert:
Diff's still there.  Multiply is not the culprit.

Original issue's description:
> Temporarily revert just Multiply to see if that's the source of NEON diffs.
>
> Local testing is confusing and inconclusive.  Pulling out the big guns.
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/5b9f352ff1e245dd48e200f8f8b683f4569547d3

TBR=mtklein@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1143553004

9 years agoRemove viewmatrix from GrGeometryProcessor base class
joshualitt [Thu, 14 May 2015 17:09:13 +0000 (10:09 -0700)]
Remove viewmatrix from GrGeometryProcessor base class

BUG=skia:

Review URL: https://codereview.chromium.org/1127953003

9 years agoTemporarily revert just Multiply to see if that's the source of NEON diffs.
mtklein [Thu, 14 May 2015 16:17:08 +0000 (09:17 -0700)]
Temporarily revert just Multiply to see if that's the source of NEON diffs.

Local testing is confusing and inconclusive.  Pulling out the big guns.

BUG=skia:

Review URL: https://codereview.chromium.org/1129293005

9 years agoTesellating path renderer: typecast cleanup; logging build fix.
senorblanco [Thu, 14 May 2015 16:08:14 +0000 (09:08 -0700)]
Tesellating path renderer: typecast cleanup; logging build fix.

Use SkPoint* for all vertex data. (It was void* to support two different
vertex data formats, which we no longer need.)
Assert that vertex stride == sizeof(SkPoint).
Fix build when LOGGING_ENABLED=1.

BUG=skia:

Review URL: https://codereview.chromium.org/1128083004

9 years agoRevert of Defer glClear to just before draw call (patchset #2 id:20001 of https:...
robertphillips [Thu, 14 May 2015 15:54:12 +0000 (08:54 -0700)]
Revert of Defer glClear to just before draw call (patchset #2 id:20001 of https://codereview.chromium.org/1113003005/)

Reason for revert:
This CL seems to be triggering the assert:
src/gpu/SkGpuDevice.cpp:319: failed assertion "!fNeedClear"
on, at least, Mac & Ubuntu.

Original issue's description:
> Defer glClear to just before draw call
>
> Remove some DO_DEFERRED_CLEAR call to avoid call glClear separately, like this:
> glBindFramebuffer(1)
> glClear
> glBindFramebuffer(2)
> glClear
> glBindFramebuffer(1)
> glDrawXXX
> glBindFramebuffer(2)
> glDrawXXX
>
> These call sequences may need read and write memory back and forth.
>
> If we call DO_DEFERRED_CLEAR just before draw call, we can bind, clear and draw in one go.
> e.g.
> glBindFramebuffer(1)
> glClear
> glDrawXXX
> glBindFramebuffer(2)
> glClear
> glDrawXXX
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/c3c06a13e69b90d4cc1d543853504072d363ae8b

TBR=bsalomon@google.com,joel.liang@arm.com,wasim.abbas@arm.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1136393005

9 years agoDefer glClear to just before draw call
wasim.abbas [Thu, 14 May 2015 15:24:52 +0000 (08:24 -0700)]
Defer glClear to just before draw call

Remove some DO_DEFERRED_CLEAR call to avoid call glClear separately, like this:
glBindFramebuffer(1)
glClear
glBindFramebuffer(2)
glClear
glBindFramebuffer(1)
glDrawXXX
glBindFramebuffer(2)
glDrawXXX

These call sequences may need read and write memory back and forth.

If we call DO_DEFERRED_CLEAR just before draw call, we can bind, clear and draw in one go.
e.g.
glBindFramebuffer(1)
glClear
glDrawXXX
glBindFramebuffer(2)
glClear
glDrawXXX

BUG=skia:

Review URL: https://codereview.chromium.org/1113003005

9 years agoAndroid scripts: add --verbose, fix missing 'source android_setup'
borenet [Thu, 14 May 2015 13:37:23 +0000 (06:37 -0700)]
Android scripts: add --verbose, fix missing 'source android_setup'

BUG=skia:3836
TBR=djsollen

Review URL: https://codereview.chromium.org/1145473002

9 years agoImplement support for non-scale/translate CTM in image filters.
reed [Thu, 14 May 2015 13:36:52 +0000 (06:36 -0700)]
Implement support for non-scale/translate CTM in image filters.

Clone with tweaks of https://codereview.chromium.org/986623003/

pre-cl to guard chrome here: https://codereview.chromium.org/1133403003/

BUG=skia:3288

Review URL: https://codereview.chromium.org/1140943004

9 years agolook for deleted pts when detecting line/curve coincident edges
caryclark [Thu, 14 May 2015 12:45:54 +0000 (05:45 -0700)]
look for deleted pts when detecting line/curve coincident edges

TBR=reed@google.com
BUG=skia:3651

Review URL: https://codereview.chromium.org/1129863007

9 years agoRevert of Refactor GrBufferAllocPools to use resource cache (patchset #9 id:160001...
robertphillips [Thu, 14 May 2015 12:24:53 +0000 (05:24 -0700)]
Revert of Refactor GrBufferAllocPools to use resource cache (patchset #9 id:160001 of https://codereview.chromium.org/1139753002/)

Reason for revert:
Perf Regression for some bot/skp combinations

Original issue's description:
> Refactor GrBufferAllocPools to use resource cache
>
> Committed: https://skia.googlesource.com/skia/+/c5f1c5414fc8f73cbefadcc1b24ec794056fa203

TBR=bsalomon@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true

Review URL: https://codereview.chromium.org/1129863008

9 years agoPerform SkPicture analysis lazily.
mtklein [Thu, 14 May 2015 02:26:14 +0000 (19:26 -0700)]
Perform SkPicture analysis lazily.

I realized when writing the comment on https://crrev.com/1135363002/
that I'd really just sketched out the entire thing, so I couldn't help
but actually write up a working CL.  How does this do for your benchmark?

BUG=chromium:487075

Review URL: https://codereview.chromium.org/1130123006

9 years agoremove color from GrGeometryProcessor
joshualitt [Wed, 13 May 2015 21:18:07 +0000 (14:18 -0700)]
remove color from GrGeometryProcessor

BUG=skia:

Review URL: https://codereview.chromium.org/1140983002

9 years agoSk4px: SrcATop, DstATop, Xor, Multiply
mtklein [Wed, 13 May 2015 21:08:45 +0000 (14:08 -0700)]
Sk4px: SrcATop, DstATop, Xor, Multiply

SSE runs 2-3x faster (than 4f), NEON runs 1.2-1.4x faster (than existing NEON).

Small diffs on {aarectmodes, imagefilters_xfermodes, hairmodes, mixed_xfermodes} only on AA edges due to precision drop.

BUG=skia:

Review URL: https://codereview.chromium.org/1132853005

9 years agoRevert of Implement support for non-scale/translate CTM in image filters. (patchset...
reed [Wed, 13 May 2015 21:00:00 +0000 (14:00 -0700)]
Revert of Implement support for non-scale/translate CTM in image filters. (patchset #4 id:60001 of https://codereview.chromium.org/1120043002/)

Reason for revert:
don't reference layer after its deleted

Original issue's description:
> Implement support for non-scale/translate CTM in image filters.
>
> Implemented by extracting out the non-scale/translate components
> and applying that post-filter as an SkMatrixImageFilter.
>
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/4f12b8bd2cb43daeffa4d1c53120ae94c5ccf486

TBR=robertphillips@google.com,senorblanco@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1128133005

9 years agoImplement support for non-scale/translate CTM in image filters.
reed [Wed, 13 May 2015 20:34:57 +0000 (13:34 -0700)]
Implement support for non-scale/translate CTM in image filters.

Implemented by extracting out the non-scale/translate components
and applying that post-filter as an SkMatrixImageFilter.

BUG=skia:

Review URL: https://codereview.chromium.org/1120043002

9 years agoDon't issue texture barriers for RT's with separate storage
cdalton [Wed, 13 May 2015 19:35:36 +0000 (12:35 -0700)]
Don't issue texture barriers for RT's with separate storage

BUG=skia:

Review URL: https://codereview.chromium.org/1137663004

9 years agoremoving equality / compute invariant loops from GrGeometryProcessors
joshualitt [Wed, 13 May 2015 19:24:23 +0000 (12:24 -0700)]
removing equality / compute invariant loops from GrGeometryProcessors

BUG=skia:

Committed: https://skia.googlesource.com/skia/+/ef292a0901205b9785a30daae2c036aa34a970ca

Review URL: https://codereview.chromium.org/1111603004

9 years agoSk4px: alphas() and Load[24]Alphas()
mtklein [Wed, 13 May 2015 19:19:42 +0000 (12:19 -0700)]
Sk4px: alphas() and Load[24]Alphas()

alphas() extracts the 4 alphas from an existing Sk4px as another Sk4px.
LoadNAlphas() constructs an Sk4px from N packed alphas.

In both cases, we end up with 4x repeated alphas aligned with their pixels.

alphas()
  A0 R0 G0 B0  A1 R1 G1 B1  A2 R2 G2 B2  A3 R3 G3 B3
  ->
  A0 A0 A0 A0  A1 A1 A1 A1  A2 A2 A2 A2  A3 A3 A3 A3

Load4Alphas()
  A0 A1 A2 A3
  ->
  A0 A0 A0 A0  A1 A1 A1 A1  A2 A2 A2 A2  A3 A3 A3 A3

Load2Alphas()
  A0 A1
  ->
  A0 A0 A0 A0  A1 A1 A1 A1  0 0 0 0  0 0 0 0

This is a 5-10% speedup for AA on Intel, and wash on ARM.
AA is still mostly dominated by the final lerp.

alphas() isn't used yet, but it's similar enough to Load[24]Alphas()
that it was easier to write all at once.

BUG=skia:

Review URL: https://codereview.chromium.org/1138333003

9 years agoRevert of Font variations. (patchset #21 id:400001 of https://codereview.chromium...
bungeman [Wed, 13 May 2015 19:16:41 +0000 (12:16 -0700)]
Revert of Font variations. (patchset #21 id:400001 of https://codereview.chromium.org/1027373002/)

Reason for revert:
Mac failing to build due to CFNumberType in Chromium Canary.

Original issue's description:
> Font variations.
>
> Multiple Master and TrueType fonts support variation axes.
> This implements back-end support for axes on platforms which
> support it.
>
> Committed: https://skia.googlesource.com/skia/+/05773ed30920c0214d1433c07cf6360a05476c97

TBR=reed@google.com,mtklein@google.com,djsollen@google.com,halcanary@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true

Review URL: https://codereview.chromium.org/1128913008

9 years agofix for angle bot
joshualitt [Wed, 13 May 2015 19:15:14 +0000 (12:15 -0700)]
fix for angle bot

TBR=
BUG=skia:

Review URL: https://codereview.chromium.org/1137333004

9 years agofix for blur large glyphs problems
joshualitt [Wed, 13 May 2015 19:15:06 +0000 (12:15 -0700)]
fix for blur large glyphs problems

BUG=skia:

Review URL: https://codereview.chromium.org/1131023006

9 years agoAdd _aa variants of Xfermode benches.
mtklein [Wed, 13 May 2015 18:54:00 +0000 (11:54 -0700)]
Add _aa variants of Xfermode benches.

Also, allow multiple DEF_BENCH() per line by using __COUNTER__ instead of __LINE__.

BUG=skia:

Review URL: https://codereview.chromium.org/1140643004

9 years agoKeep Big Glyph coordinates in float in GrAtlasTextContext
joshualitt [Wed, 13 May 2015 18:23:03 +0000 (11:23 -0700)]
Keep Big Glyph coordinates in float in GrAtlasTextContext

TBR=jvanverth@google.com
BUG=skia:

Review URL: https://codereview.chromium.org/1132853004

9 years agoFont variations.
bungeman [Wed, 13 May 2015 17:57:09 +0000 (10:57 -0700)]
Font variations.

Multiple Master and TrueType fonts support variation axes.
This implements back-end support for axes on platforms which
support it.

Review URL: https://codereview.chromium.org/1027373002

9 years agoRefactor GrBufferAllocPools to use resource cache
robertphillips [Wed, 13 May 2015 17:55:33 +0000 (10:55 -0700)]
Refactor GrBufferAllocPools to use resource cache

Review URL: https://codereview.chromium.org/1139753002

9 years agoRevert of Revert of Revert of Remove workaround to for lower glsl support for qualcom...
egdaniel [Wed, 13 May 2015 17:32:49 +0000 (10:32 -0700)]
Revert of Revert of Revert of Remove workaround to for lower glsl support for qualcomm (patchset #1 id:1 of https://codereview.chromium.org/1138013004/)

Reason for revert:
still broken :(

Original issue's description:
> Revert of Revert of Remove workaround to for lower glsl support for qualcomm (patchset #1 id:1 of https://codereview.chromium.org/1135393003/)
>
> Reason for revert:
> trying once more
>
> Original issue's description:
> > Revert of Remove workaround to for lower glsl support for qualcomm (patchset #1 id:1 of https://codereview.chromium.org/1133543004/)
> >
> > Reason for revert:
> > breaks many qualcomm gms
> >
> > Original issue's description:
> > > Remove workaround to for lower glsl support for qualcomm
> > >
> > > BUG=skia:
> > >
> > > Committed: https://skia.googlesource.com/skia/+/9770bdce776f45367c419b8dd82219eece26ca5c
> >
> > TBR=bsalomon@google.com
> > NOPRESUBMIT=true
> > NOTREECHECKS=true
> > NOTRY=true
> > BUG=skia:
> >
> > Committed: https://skia.googlesource.com/skia/+/0cfe1242ee284290bde1ebe3f48626c555fdac51
>
> TBR=bsalomon@google.com
> NOPRESUBMIT=true
> NOTREECHECKS=true
> NOTRY=true
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/b72f920ef581e9cf50a6c1afc80ed04bb086488e

TBR=bsalomon@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1130413006

9 years agoclean up tests
caryclark [Wed, 13 May 2015 17:13:17 +0000 (10:13 -0700)]
clean up tests

Confirm that no path ops tests are flaky, and clean up errors around
that. The test framework was incorrectly checking for >= MAX_ERRORS for
failure and <= MAX_ERRORS for success.

TBR=reed@google.com

Review URL: https://codereview.chromium.org/1140563003

9 years agoRemove GrGLVertexArray from GrGpuResource hierarchy.
bsalomon [Wed, 13 May 2015 16:56:37 +0000 (09:56 -0700)]
Remove GrGLVertexArray from GrGpuResource hierarchy.

Review URL: https://codereview.chromium.org/1137093002

9 years agoExtensible Android font configuration parsing.
bungeman [Wed, 13 May 2015 15:52:16 +0000 (08:52 -0700)]
Extensible Android font configuration parsing.

The xml parsing of the Android font configuration is quite lax in what
it allows. This has lead to issues with forward compatibility and
extending the existing format. This has lead to some confusion about
what the actual format is and how a given proposed change will affect
existing files and readers.

The main issue this fixes is containment. Tags are now only recognized
at the correct levels in the correct containing tags. Tags which are
not recognized are properly skipped. Tags which accumulate character
data now only accumulate the character data in their own element as
opposed to all child elements.

Review URL: https://codereview.chromium.org/1138073002

9 years agoGLProgramsTest 3.0
joshualitt [Wed, 13 May 2015 15:51:49 +0000 (08:51 -0700)]
GLProgramsTest 3.0

BUG=skia:

Review URL: https://codereview.chromium.org/1139743002

9 years agoRevert of Revert of Remove workaround to for lower glsl support for qualcomm (patchse...
egdaniel [Wed, 13 May 2015 15:46:51 +0000 (08:46 -0700)]
Revert of Revert of Remove workaround to for lower glsl support for qualcomm (patchset #1 id:1 of https://codereview.chromium.org/1135393003/)

Reason for revert:
trying once more

Original issue's description:
> Revert of Remove workaround to for lower glsl support for qualcomm (patchset #1 id:1 of https://codereview.chromium.org/1133543004/)
>
> Reason for revert:
> breaks many qualcomm gms
>
> Original issue's description:
> > Remove workaround to for lower glsl support for qualcomm
> >
> > BUG=skia:
> >
> > Committed: https://skia.googlesource.com/skia/+/9770bdce776f45367c419b8dd82219eece26ca5c
>
> TBR=bsalomon@google.com
> NOPRESUBMIT=true
> NOTREECHECKS=true
> NOTRY=true
> BUG=skia:
>
> Committed: https://skia.googlesource.com/skia/+/0cfe1242ee284290bde1ebe3f48626c555fdac51

TBR=bsalomon@google.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:

Review URL: https://codereview.chromium.org/1138013004