summaryrefslogtreecommitdiffstats
path: root/kernel/drivers/clk/clk.h
blob: 00b35a13cdf389310afe65856fc23e3fee68d067 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/*
 * linux/drivers/clk/clk.h
 *
 * Copyright (C) 2013 Samsung Electronics Co., Ltd.
 * Sylwester Nawrocki <s.nawrocki@samsung.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

struct clk_hw;

#if defined(CONFIG_OF) && defined(CONFIG_COMMON_CLK)
struct clk *__of_clk_get_from_provider(struct of_phandle_args *clkspec,
				       const char *dev_id, const char *con_id);
#endif

#ifdef CONFIG_COMMON_CLK
struct clk *__clk_create_clk(struct clk_hw *hw, const char *dev_id,
			     const char *con_id);
void __clk_free_clk(struct clk *clk);
#else
/* All these casts to avoid ifdefs in clkdev... */
static inline struct clk *
__clk_create_clk(struct clk_hw *hw, const char *dev_id, const char *con_id)
{
	return (struct clk *)hw;
}
static inline void __clk_free_clk(struct clk *clk) { }
static struct clk_hw *__clk_get_hw(struct clk *clk)
{
	return (struct clk_hw *)clk;
}

#endif
D, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ #include "qemu/osdep.h" #include "qemu-common.h" #include "ui/console.h" #include "ui/shader.h" #include "shader/texture-blit-vert.h" #include "shader/texture-blit-frag.h" struct ConsoleGLState { GLint texture_blit_prog; GLint texture_blit_vao; }; /* ---------------------------------------------------------------------- */ ConsoleGLState *console_gl_init_context(void) { ConsoleGLState *gls = g_new0(ConsoleGLState, 1); gls->texture_blit_prog = qemu_gl_create_compile_link_program (texture_blit_vert_src, texture_blit_frag_src); if (!gls->texture_blit_prog) { exit(1); } gls->texture_blit_vao = qemu_gl_init_texture_blit(gls->texture_blit_prog); return gls; } void console_gl_fini_context(ConsoleGLState *gls) { if (!gls) { return; } g_free(gls); } bool console_gl_check_format(DisplayChangeListener *dcl, pixman_format_code_t format) { switch (format) { case PIXMAN_BE_b8g8r8x8: case PIXMAN_BE_b8g8r8a8: case PIXMAN_r5g6b5: return true; default: return false; } } void surface_gl_create_texture(ConsoleGLState *gls, DisplaySurface *surface) { assert(gls); assert(surface_stride(surface) % surface_bytes_per_pixel(surface) == 0); switch (surface->format) { case PIXMAN_BE_b8g8r8x8: case PIXMAN_BE_b8g8r8a8: surface->glformat = GL_BGRA_EXT; surface->gltype = GL_UNSIGNED_BYTE; break; case PIXMAN_r5g6b5: surface->glformat = GL_RGB; surface->gltype = GL_UNSIGNED_SHORT_5_6_5; break; default: g_assert_not_reached(); } glGenTextures(1, &surface->texture); glEnable(GL_TEXTURE_2D); glBindTexture(GL_TEXTURE_2D, surface->texture); glPixelStorei(GL_UNPACK_ROW_LENGTH_EXT, surface_stride(surface) / surface_bytes_per_pixel(surface)); glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, surface_width(surface), surface_height(surface), 0, surface->glformat, surface->gltype, surface_data(surface)); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); } void surface_gl_update_texture(ConsoleGLState *gls, DisplaySurface *surface, int x, int y, int w, int h) { uint8_t *data = (void *)surface_data(surface); assert(gls); glPixelStorei(GL_UNPACK_ROW_LENGTH_EXT, surface_stride(surface) / surface_bytes_per_pixel(surface)); glTexSubImage2D(GL_TEXTURE_2D, 0, x, y, w, h, surface->glformat, surface->gltype, data + surface_stride(surface) * y + surface_bytes_per_pixel(surface) * x); } void surface_gl_render_texture(ConsoleGLState *gls, DisplaySurface *surface) { assert(gls); glClearColor(0.1f, 0.1f, 0.1f, 0.0f); glClear(GL_COLOR_BUFFER_BIT); qemu_gl_run_texture_blit(gls->texture_blit_prog, gls->texture_blit_vao); } void surface_gl_destroy_texture(ConsoleGLState *gls, DisplaySurface *surface) { if (!surface || !surface->texture) { return; } glDeleteTextures(1, &surface->texture); surface->texture = 0; } void surface_gl_setup_viewport(ConsoleGLState *gls, DisplaySurface *surface, int ww, int wh) { int gw, gh, stripe; float sw, sh; assert(gls); gw = surface_width(surface); gh = surface_height(surface); sw = (float)ww/gw; sh = (float)wh/gh; if (sw < sh) { stripe = wh - wh*sw/sh; glViewport(0, stripe / 2, ww, wh - stripe); } else { stripe = ww - ww*sh/sw; glViewport(stripe / 2, 0, ww - stripe, wh); } }