OLD | NEW |
---|---|
1 /* Copyright (c) 2010, Google Inc. | 1 /* |
2 * All rights reserved. | 2 * Copyright (C) 2012 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
11 * copyright notice, this list of conditions and the following disclaimer | 11 * copyright notice, this list of conditions and the following disclaimer |
12 * in the documentation and/or other materials provided with the | 12 * in the documentation and/or other materials provided with the |
13 * distribution. | 13 * distribution. |
14 * * Neither the name of Google Inc. nor the names of its | 14 * * Neither the name of Google Inc. nor the names of its |
15 * contributors may be used to endorse or promote products derived from | 15 * contributors may be used to endorse or promote products derived from |
16 * this software without specific prior written permission. | 16 * this software without specific prior written permission. |
17 * | 17 * |
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 * | |
30 * --- | |
31 * This file is an internal part spinlock.cc and once.cc | |
32 * It may not be used directly by code outside of //base. | |
33 */ | 29 */ |
34 | 30 |
35 #ifndef BASE_SPINLOCK_INTERNAL_H_ | |
36 #define BASE_SPINLOCK_INTERNAL_H_ | |
37 | 31 |
38 #include <config.h> | 32 #ifndef DecorationLayerChromium_h |
39 #include "base/basictypes.h" | 33 #define DecorationLayerChromium_h |
40 #include "base/atomicops.h" | |
41 | 34 |
42 namespace base { | 35 #if USE(ACCELERATED_COMPOSITING) |
danakj
2012/09/24 14:35:00
nit: drop the ACCELERATED_COMPOSITING in new files
| |
43 namespace internal { | |
44 | 36 |
45 // SpinLockWait() waits until it can perform one of several transitions from | 37 #include "LayerChromium.h" |
46 // "from" to "to". It returns when it performs a transition where done==true. | 38 #include "LayerTextureUpdater.h" |
47 struct SpinLockWaitTransition { | 39 #include "SkBitmap.h" |
48 int32 from; | 40 |
49 int32 to; | 41 namespace cc { |
50 bool done; | 42 |
43 class DecorationLayerTextureUpdater; | |
44 | |
45 // A Layer that contains sparse quads being sourced from bitmaps. | |
46 class DecorationLayerChromium : public LayerChromium { | |
47 public: | |
48 static PassRefPtr<DecorationLayerChromium> create(); | |
49 virtual ~DecorationLayerChromium(); | |
50 | |
51 virtual bool drawsContent() const OVERRIDE; | |
52 virtual void setTexturePriorities(const CCPriorityCalculator&) OVERRIDE; | |
53 virtual void update(CCTextureUpdateQueue&, const CCOcclusionTracker*, CCRend eringStats&) OVERRIDE; | |
54 virtual bool needsContentsScale() const OVERRIDE; | |
55 virtual void pushPropertiesTo(CCLayerImpl*) OVERRIDE; | |
56 | |
57 void setBitmap(const SkBitmap& bitmap, const IntRect& aperture); | |
58 | |
59 private: | |
60 DecorationLayerChromium(); | |
61 PassOwnPtr<CCLayerImpl> createCCLayerImpl() OVERRIDE; | |
62 | |
63 virtual void createTextureUpdaterIfNeeded() OVERRIDE; | |
64 | |
65 RefPtr<DecorationLayerTextureUpdater> m_textureUpdater; | |
66 OwnPtr<LayerTextureUpdater::Texture> m_texture; | |
67 | |
68 SkBitmap m_bitmap; | |
69 | |
70 // The transparent center region that shows the parent layer's contents in i mage space. | |
71 IntRect m_imageAperture; | |
51 }; | 72 }; |
52 | 73 |
53 // Wait until *w can transition from trans[i].from to trans[i].to for some i | 74 } |
54 // satisfying 0<=i<n && trans[i].done, atomically make the transition, | 75 #endif // USE(ACCELERATED_COMPOSITING) |
55 // then return the old value of *w. Make any other atomic tranistions | |
56 // where !trans[i].done, but continue waiting. | |
57 int32 SpinLockWait(volatile Atomic32 *w, int n, | |
58 const SpinLockWaitTransition trans[]); | |
59 void SpinLockWake(volatile Atomic32 *w, bool all); | |
60 void SpinLockDelay(volatile Atomic32 *w, int32 value, int loop); | |
61 | 76 |
62 } // namespace internal | |
63 } // namespace base | |
64 #endif | 77 #endif |
OLD | NEW |