From: Fredrik Noring <noring@nocrew.org>
To: linux-mips@vger.kernel.org
Subject: [PATCH 104/120] MIPS: PS2: FB: Hardware accelerated fb_tilefill() support
Date: Sun, 1 Sep 2019 18:33:06 +0200 [thread overview]
Message-ID: <0b481fd149279130e4fa0cfbed92f74c66cd5489.1567326213.git.noring@nocrew.org> (raw)
In-Reply-To: <cover.1567326213.git.noring@nocrew.org>
The local Graphics Synthesizer palette is updated if either the
background or the foreground colour index have changed. A single
BITBLTBUF operation performs the tile fill.
Signed-off-by: Fredrik Noring <noring@nocrew.org>
---
drivers/video/fbdev/ps2fb.c | 233 ++++++++++++++++++++++++++++++++++++
1 file changed, 233 insertions(+)
diff --git a/drivers/video/fbdev/ps2fb.c b/drivers/video/fbdev/ps2fb.c
index 2123686af013..c00c0f6a4a49 100644
--- a/drivers/video/fbdev/ps2fb.c
+++ b/drivers/video/fbdev/ps2fb.c
@@ -252,6 +252,23 @@ static const struct fb_videomode standard_modes[] = {
FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA }
};
+/**
+ * console_pseudo_palette - Graphics Synthesizer RGBA for a palette index
+ * @regno: pseudo palette index number
+ * @par: driver specific object
+ *
+ * Return: RGBA colour object for the Graphics Synthesizer
+ */
+static struct gs_rgbaq console_pseudo_palette(const u32 regno,
+ const struct ps2fb_par *par)
+{
+ const struct gs_rgba32 c = regno < PALETTE_SIZE ?
+ par->pseudo_palette[regno] : (struct gs_rgba32) { };
+ const u32 a = (c.a + 1) / 2; /* 0x80 = GS_ALPHA_ONE = 1.0 */
+
+ return (struct gs_rgbaq) { .r = c.r, .g = c.g, .b = c.b, .a = a };
+}
+
/**
* var_to_fbw - frame buffer width for a given virtual x resolution
* @var: screen info object to compute FBW for
@@ -344,6 +361,19 @@ static u32 block_address_for_index(const u32 block_index,
return 0;
}
+/**
+ * color_base_pointer - colour base pointer
+ * @info: frame buffer info object
+ *
+ * Return: block index of the colour palette, that follows the display buffer
+ */
+static u32 color_base_pointer(const struct fb_info *info)
+{
+ const struct ps2fb_par *par = info->par;
+
+ return par->cb.block_count;
+}
+
/**
* texture_address_for_index - frame buffer texture address for given index
* @block_index: index of block to compute the address of
@@ -968,6 +998,187 @@ static void ps2fb_cb_settile(struct fb_info *info, struct fb_tilemap *map)
ps2fb_cb_texflush(info);
}
+/**
+ * package_palette - package palette tags and data for the GIF
+ * @package: DMA buffer to put packages in
+ * @bg: background colour palette index
+ * @fg: foreground colour palette index
+ * @info: frame buffer info object
+ *
+ * Return: number of generated GIF packages in 16-byte unit
+ */
+static size_t package_palette(union package *package,
+ const int bg, const int fg, struct fb_info *info)
+{
+ struct ps2fb_par *par = info->par;
+ union package * const base_package = par->package.buffer;
+ const struct gs_rgbaq bg_rgbaq = console_pseudo_palette(bg, par);
+ const struct gs_rgbaq fg_rgbaq = console_pseudo_palette(fg, par);
+
+ GIF_PACKAGE_TAG(package) {
+ .flg = gif_packed_mode,
+ .reg0 = gif_reg_ad,
+ .nreg = 1,
+ .nloop = 4
+ };
+ GIF_PACKAGE_AD(package) {
+ .addr = gs_addr_bitbltbuf,
+ .data.bitbltbuf = {
+ .dpsm = gs_psm_ct32,
+ .dbw = 1, /* Palette is one block wide */
+ .dbp = color_base_pointer(info)
+ }
+ };
+ GIF_PACKAGE_AD(package) {
+ .addr = gs_addr_trxpos,
+ .data.trxpos = {
+ .dsax = 0,
+ .dsay = 0
+ }
+ };
+ GIF_PACKAGE_AD(package) {
+ .addr = gs_addr_trxreg,
+ .data.trxreg = {
+ .rrw = 2, /* Background and foreground color */
+ .rrh = 1
+ }
+ };
+ GIF_PACKAGE_AD(package) {
+ .addr = gs_addr_trxdir,
+ .data.trxdir = { .xdir = gs_trxdir_host_to_local }
+ };
+
+ GIF_PACKAGE_TAG(package) {
+ .flg = gif_image_mode,
+ .nloop = 1,
+ .eop = 1
+ };
+ package->gif.rgba32[0] = (struct gs_rgba32) {
+ .r = bg_rgbaq.r,
+ .g = bg_rgbaq.g,
+ .b = bg_rgbaq.b,
+ .a = bg_rgbaq.a
+ };
+ package->gif.rgba32[1] = (struct gs_rgba32) {
+ .r = fg_rgbaq.r,
+ .g = fg_rgbaq.g,
+ .b = fg_rgbaq.b,
+ .a = fg_rgbaq.a
+ };
+ package++;
+
+ GIF_PACKAGE_TAG(package) {
+ .flg = gif_packed_mode,
+ .reg0 = gif_reg_ad,
+ .nreg = 1,
+ .nloop = 1
+ };
+ GIF_PACKAGE_AD(package) {
+ .addr = gs_addr_texflush
+ };
+
+ return package - base_package;
+}
+
+/**
+ * write_tilefill - write console buffer tile fill operation to the GIF
+ * @info: frame buffer info object
+ * @rect: rectangle to fill with tiles
+ */
+static void write_tilefill(struct fb_info *info, const struct fb_tilerect rect)
+{
+ const struct tile_texture tt = texture_for_tile(rect.index, info);
+ struct ps2fb_par *par = info->par;
+ union package * const base_package = par->package.buffer;
+ union package *package = base_package;
+ const u32 cbp = color_base_pointer(info);
+ const u32 dsax = par->cb.tile.width * rect.sx;
+ const u32 dsay = par->cb.tile.height * rect.sy;
+ const u32 rrw = par->cb.tile.width * rect.width;
+ const u32 rrh = par->cb.tile.height * rect.height;
+ const u32 tw2 = par->cb.tile.width2;
+ const u32 th2 = par->cb.tile.height2;
+
+ /* Determine whether background or foreground color needs update. */
+ const bool cld = (par->cb.bg != rect.bg || par->cb.fg != rect.fg);
+
+ if (!gif_wait())
+ return;
+
+ if (cld) {
+ package += package_palette(package, rect.bg, rect.fg, info);
+ par->cb.bg = rect.bg;
+ par->cb.fg = rect.fg;
+ }
+
+ GIF_PACKAGE_TAG(package) {
+ .flg = gif_reglist_mode,
+ .reg0 = gif_reg_prim,
+ .reg1 = gif_reg_nop,
+ .reg2 = gif_reg_tex0_1,
+ .reg3 = gif_reg_clamp_1,
+ .reg4 = gif_reg_uv,
+ .reg5 = gif_reg_xyz2,
+ .reg6 = gif_reg_uv,
+ .reg7 = gif_reg_xyz2,
+ .nreg = 8,
+ .nloop = 1,
+ .eop = 1
+ };
+ GIF_PACKAGE_REG(package) {
+ .lo.prim = {
+ .prim = gs_sprite,
+ .tme = gs_texturing_on,
+ .fst = gs_texturing_uv
+ }
+ };
+ GIF_PACKAGE_REG(package) {
+ .lo.tex0 = {
+ .tbp0 = tt.tbp,
+ .tbw = GS_PSMT4_BLOCK_WIDTH / 64,
+ .psm = gs_psm_t4,
+ .tw = 5, /* 2^5 = 32 texels wide PSMT4 block */
+ .th = 4, /* 2^4 = 16 texels high PSMT4 block */
+ .tcc = gs_tcc_rgba,
+ .tfx = gs_tfx_decal,
+ .cbp = cbp,
+ .cpsm = gs_psm_ct32,
+ .csm = gs_csm1,
+ .cld = cld ? 1 : 0
+ },
+ .hi.clamp_1 = {
+ .wms = gs_clamp_region_repeat,
+ .wmt = gs_clamp_region_repeat,
+ .minu = tw2 - 1, /* Mask, tw is always a power of 2 */
+ .maxu = tt.u,
+ .minv = th2 - 1, /* Mask, th is always a power of 2 */
+ .maxv = tt.v
+ }
+ };
+ GIF_PACKAGE_REG(package) {
+ .lo.uv = {
+ .u = gs_pxcs_to_tcs(tt.u),
+ .v = gs_pxcs_to_tcs(tt.v)
+ },
+ .hi.xyz2 = {
+ .x = gs_fbcs_to_pcs(dsax),
+ .y = gs_fbcs_to_pcs(dsay)
+ }
+ };
+ GIF_PACKAGE_REG(package) {
+ .lo.uv = {
+ .u = gs_pxcs_to_tcs(tt.u + rrw),
+ .v = gs_pxcs_to_tcs(tt.v + rrh)
+ },
+ .hi.xyz2 = {
+ .x = gs_fbcs_to_pcs(dsax + rrw),
+ .y = gs_fbcs_to_pcs(dsay + rrh)
+ }
+ };
+
+ gif_write(&base_package->gif, package - base_package);
+}
+
/**
* ps2fb_cb_tilecopy - copy console buffer tiles
* @info: frame buffer info object
@@ -990,6 +1201,26 @@ static void ps2fb_cb_tilecopy(struct fb_info *info, struct fb_tilearea *area)
ps2fb_cb_copyarea(&a, info);
}
+/**
+ * ps2fb_cb_tilefill - tile fill operation
+ * @info: frame buffer info object
+ * @rect: rectangle to fill with tiles
+ */
+static void ps2fb_cb_tilefill(struct fb_info *info, struct fb_tilerect *rect)
+{
+ struct ps2fb_par *par = info->par;
+ unsigned long flags;
+
+ if (info->state != FBINFO_STATE_RUNNING)
+ return;
+
+ spin_lock_irqsave(&par->lock, flags);
+
+ write_tilefill(info, *rect);
+
+ spin_unlock_irqrestore(&par->lock, flags);
+}
+
/**
* ps2fb_cb_get_tilemax - maximum number of tiles
* @info: frame buffer info object
@@ -1654,6 +1885,7 @@ static int init_console_buffer(struct platform_device *pdev,
static struct fb_tile_ops tileops = {
.fb_settile = ps2fb_cb_settile,
.fb_tilecopy = ps2fb_cb_tilecopy,
+ .fb_tilefill = ps2fb_cb_tilefill,
.fb_get_tilemax = ps2fb_cb_get_tilemax
};
@@ -1670,6 +1902,7 @@ static int init_console_buffer(struct platform_device *pdev,
info->fbops = &fbops;
info->flags = FBINFO_DEFAULT |
FBINFO_HWACCEL_COPYAREA |
+ FBINFO_HWACCEL_FILLRECT |
FBINFO_READS_FAST;
info->flags |= FBINFO_MISC_TILEBLITTING;
--
2.21.0
next prev parent reply other threads:[~2019-09-01 16:33 UTC|newest]
Thread overview: 161+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-09-01 15:35 [PATCH 000/120] Linux for the PlayStation 2 Fredrik Noring
2019-09-01 15:35 ` [PATCH 001/120] MIPS: R5900: Initial support for the Emotion Engine in " Fredrik Noring
2019-09-01 21:14 ` Maciej W. Rozycki
2019-09-02 15:09 ` Fredrik Noring
2019-09-01 15:36 ` [PATCH 002/120] MIPS: R5900: Trap the RDHWR instruction as an SQ address exception Fredrik Noring
2019-09-01 22:00 ` Maciej W. Rozycki
2020-11-19 7:15 ` Philippe Mathieu-Daudé
2020-11-19 13:28 ` Maciej W. Rozycki
2020-11-19 13:42 ` Maciej W. Rozycki
2020-12-12 10:58 ` Fredrik Noring
2020-12-12 11:36 ` Maciej W. Rozycki
2020-12-12 12:14 ` Fredrik Noring
2020-12-13 11:43 ` Fredrik Noring
2019-09-01 15:36 ` [PATCH 003/120] MIPS: R5900: Sign-extend o32 system call registers Fredrik Noring
2019-09-01 15:37 ` [PATCH 004/120] MIPS: R5900: Reset bits 127..64 of GPRs in RESTORE_SOME Fredrik Noring
2019-09-01 15:38 ` [PATCH 005/120] MIPS: R5900: Reset the funnel shift amount (SA) register " Fredrik Noring
2019-09-01 15:38 ` [PATCH 006/120] MIPS: R5900: Workaround for the short loop bug Fredrik Noring
2019-09-01 15:39 ` [PATCH 007/120] MIPS: R5900: Add the SYNC.P instruction Fredrik Noring
2019-09-01 15:39 ` [PATCH 008/120] MIPS: R5900: Add implicit SYNC.P to the UASM_i_M[FT]C0 macros Fredrik Noring
2019-09-01 15:39 ` [PATCH 009/120] MIPS: R5900: Add mandatory SYNC.P to all M[FT]C0 instructions Fredrik Noring
2019-09-01 15:39 ` [PATCH 010/120] MIPS: R5900: Workaround exception NOP execution bug (FLX05) Fredrik Noring
2019-09-01 23:01 ` Philippe Mathieu-Daudé
2019-09-01 15:40 ` [PATCH 011/120] MIPS: R5900: Avoid pipeline hazard with the TLBP instruction Fredrik Noring
2019-09-01 17:15 ` Sergei Shtylyov
2019-09-01 17:36 ` Fredrik Noring
2019-09-01 15:40 ` [PATCH 012/120] MIPS: R5900: Avoid pipeline hazards with the TLBW[IR] instructions Fredrik Noring
2019-09-01 15:40 ` [PATCH 013/120] MIPS: R5900: Avoid pipeline hazard with the TLBR instruction Fredrik Noring
2019-09-01 15:41 ` [PATCH 014/120] MIPS: R5900: Install final length of TLB refill handler rather than 256 bytes Fredrik Noring
2019-09-01 15:41 ` [PATCH 015/120] MIPS: R5900: Verify that the TLB refill handler does not overflow Fredrik Noring
2019-09-01 15:41 ` [PATCH 016/120] MIPS: R5900: The ERET instruction has issues with delay slot and CACHE Fredrik Noring
2019-09-01 15:42 ` [PATCH 017/120] MIPS: R5900: Define CACHE instruction operation field encodings Fredrik Noring
2019-09-01 15:42 ` [PATCH 018/120] MIPS: R5900: Workaround where MSB must be 0 for the instruction cache Fredrik Noring
2019-09-01 15:42 ` [PATCH 019/120] MIPS: R5900: Use SYNC.L for data cache and SYNC.P for " Fredrik Noring
2019-09-01 15:43 ` [PATCH 020/120] MIPS: R5900: Define CP0.Config register fields Fredrik Noring
2019-09-01 23:04 ` Philippe Mathieu-Daudé
2019-09-01 15:43 ` [PATCH 021/120] MIPS: R5900: Workaround for CACHE instruction near branch delay slot Fredrik Noring
2019-09-01 15:46 ` [PATCH 022/120] MIPS: R5900: Support 64-bit inq() and outq() macros in 32-bit kernels Fredrik Noring
2019-09-04 1:04 ` Jiaxun Yang
2019-09-04 16:00 ` Maciej W. Rozycki
2019-09-01 15:46 ` [PATCH 023/120] MIPS: R5900: Add MFSA and MTSA instructions for the special SA register Fredrik Noring
2019-09-01 15:46 ` [PATCH 024/120] MIPS: PS2: Define PlayStation 2 I/O port, ROM and RAM address spaces Fredrik Noring
2019-09-01 15:47 ` [PATCH 025/120] MIPS: PS2: Define interrupt controller, DMA and timer IRQs Fredrik Noring
2019-09-01 15:47 ` [PATCH 026/120] MIPS: PS2: Interrupt controller (INTC) IRQ support Fredrik Noring
2019-09-01 15:47 ` [PATCH 027/120] MIPS: PS2: DMAC: Define DMA controller registers Fredrik Noring
2019-09-01 15:47 ` [PATCH 028/120] MIPS: PS2: DMAC: Define tag structures Fredrik Noring
2019-09-01 15:48 ` [PATCH 029/120] MIPS: PS2: DMAC: IRQ support Fredrik Noring
2019-09-01 15:48 ` [PATCH 030/120] MIPS: PS2: Timer support Fredrik Noring
2019-09-01 15:48 ` [PATCH 031/120] MIPS: PS2: SCMD: System command support Fredrik Noring
2019-09-01 15:48 ` [PATCH 032/120] MIPS: PS2: SCMD: System power off command Fredrik Noring
2019-09-01 15:48 ` [PATCH 033/120] MIPS: PS2: SCMD: Read system machine name command Fredrik Noring
2019-09-01 15:49 ` [PATCH 034/120] MIPS: PS2: SCMD: Read system command for the real-time clock (RTC) Fredrik Noring
2019-09-01 15:49 ` [PATCH 035/120] MIPS: PS2: SCMD: Set " Fredrik Noring
2019-09-01 15:49 ` [PATCH 036/120] MIPS: PS2: ROM: Iterate over the files in a given ROM directory Fredrik Noring
2019-09-01 15:49 ` [PATCH 037/120] MIPS: PS2: ROM: Find ROM files with a given name, if they exist Fredrik Noring
2019-09-01 15:50 ` [PATCH 038/120] MIPS: PS2: ROM: Read data for a given ROM file name Fredrik Noring
2019-09-02 9:05 ` Sergei Shtylyov
2019-09-04 11:46 ` Sergei Shtylyov
2019-09-06 13:07 ` Fredrik Noring
2019-09-01 15:50 ` [PATCH 039/120] MIPS: PS2: ROM: Read extended information for a given ROM file Fredrik Noring
2019-09-01 15:50 ` [PATCH 040/120] MIPS: PS2: ROM: Read and decode the ROMVER file Fredrik Noring
2019-09-01 15:52 ` [PATCH 041/120] MIPS: PS2: ROM: Resolve the name for the type in " Fredrik Noring
2019-09-01 15:52 ` [PATCH 042/120] MIPS: PS2: ROM: Resolve the name for the region " Fredrik Noring
2019-09-01 15:53 ` [PATCH 043/120] MIPS: PS2: ROM: Permit /dev/mem to access read-only memory Fredrik Noring
2019-09-01 15:53 ` [PATCH 044/120] MIPS: PS2: ROM: Sysfs module to inspect ROM files Fredrik Noring
2019-09-01 15:54 ` [PATCH 045/120] MIPS: PS2: ROM: Provide extended file information via sysfs Fredrik Noring
2019-09-01 15:54 ` [PATCH 046/120] MIPS: PS2: Identify the machine by model name Fredrik Noring
2019-09-01 15:54 ` [PATCH 047/120] MIPS: PS2: Let the system type be Sony PlayStation 2 Fredrik Noring
2019-09-01 23:09 ` Philippe Mathieu-Daudé
2019-09-01 15:55 ` [PATCH 048/120] MIPS: Define and use cpu_relax_forever() for various halting loops Fredrik Noring
2019-09-01 15:55 ` [PATCH 049/120] MIPS: PS2: Power off support Fredrik Noring
2019-09-01 15:55 ` [PATCH 050/120] MIPS: PS2: Real-time clock (RTC) driver Fredrik Noring
2019-09-01 15:56 ` [PATCH 051/120] MIPS: PS2: IOP: I/O processor DMA register PCR2 set and clear Fredrik Noring
2019-09-01 15:57 ` [PATCH 052/120] MIPS: PS2: SIF: Sub-system interface reset of the I/O processor (IOP) Fredrik Noring
2019-09-01 15:57 ` [PATCH 053/120] MIPS: PS2: IOP: Define error numbers, descriptions and errno mapping Fredrik Noring
2019-09-01 15:58 ` [PATCH 054/120] MIPS: PS2: SIF: SIF register write command support Fredrik Noring
2019-09-01 15:58 ` [PATCH 055/120] MIPS: PS2: SIF: Respond to remote procedure call (RPC) bind command Fredrik Noring
2019-09-01 15:58 ` [PATCH 056/120] MIPS: PS2: SIF: Respond to RPC bind end command Fredrik Noring
2019-09-01 15:59 ` [PATCH 057/120] MIPS: PS2: SIF: Reset the SIF0 (sub-to-main) DMA controller Fredrik Noring
2019-09-01 15:59 ` [PATCH 058/120] MIPS: PS2: SIF: Handle SIF0 (sub-to-main) RPCs via interrupts Fredrik Noring
2019-09-01 15:59 ` [PATCH 059/120] MIPS: PS2: SIF: Enable the IOP to issue SIF commands Fredrik Noring
2019-09-01 16:00 ` [PATCH 060/120] MIPS: PS2: SIF: Enable the IOP to issue SIF RPCs Fredrik Noring
2019-09-01 16:01 ` [PATCH 061/120] MIPS: PS2: SIF: sif_rpc_bind() to request an RPC server connection Fredrik Noring
2019-09-01 16:02 ` [PATCH 062/120] MIPS: PS2: SIF: sif_rpc_unbind() to release " Fredrik Noring
2019-09-01 16:02 ` [PATCH 063/120] MIPS: PS2: SIF: sif_rpc() to issue a remote procedure call Fredrik Noring
2019-09-01 16:03 ` [PATCH 064/120] MIPS: PS2: IOP: Permit /dev/mem to access IOP memory Fredrik Noring
2019-09-01 16:03 ` [PATCH 065/120] MIPS: PS2: IOP: I/O processor memory support Fredrik Noring
2019-09-01 16:10 ` [PATCH 066/120] FIXME: Export _dma_cache_{wback,wback_inv,inv} Fredrik Noring
2019-09-01 16:10 ` [PATCH 067/120] MIPS: PS2: IOP: Module linking support Fredrik Noring
2019-09-01 16:11 ` [PATCH 068/120] MIPS: PS2: IOP: Verify that modules are IRX objects Fredrik Noring
2019-09-01 16:11 ` [PATCH 069/120] MIPS: PS2: IOP: Module version compatibility verification Fredrik Noring
2019-09-01 16:11 ` [PATCH 070/120] MIPS: PS2: IOP: Avoid linking already linked library modules Fredrik Noring
2019-09-01 16:12 ` [PATCH 071/120] MIPS: PS2: IOP: Resolve module dependencies Fredrik Noring
2019-09-01 16:12 ` [PATCH 072/120] MIPS: PS2: IOP: SIF printk command support Fredrik Noring
2019-09-01 17:44 ` Sergei Shtylyov
2019-09-01 18:08 ` Fredrik Noring
2019-09-01 16:16 ` [PATCH 073/120] MIPS: PS2: IOP: Heap memory allocate and free Fredrik Noring
2019-09-01 16:16 ` [PATCH 074/120] MIPS: PS2: SIF: Request RPC IRQ command Fredrik Noring
2019-09-01 16:17 ` [PATCH 075/120] MIPS: PS2: IOP: IRQ support Fredrik Noring
2019-09-01 16:17 ` [PATCH 076/120] MIPS: PS2: GS: Define privileged Graphics Synthesizer registers Fredrik Noring
2019-09-01 16:18 ` [PATCH 077/120] MIPS: PS2: GS: Write privileged registers Fredrik Noring
2019-09-01 16:18 ` [PATCH 078/120] MIPS: PS2: GS: Read " Fredrik Noring
2019-09-01 16:18 ` [PATCH 079/120] MIPS: PS2: GS: Define privileged register structures Fredrik Noring
2019-09-01 16:19 ` [PATCH 080/120] MIPS: PS2: GS: Define gs_xorq_imr() Fredrik Noring
2019-09-01 16:20 ` [PATCH 081/120] MIPS: PS2: GS: Privileged register write macros with named fields Fredrik Noring
2019-09-01 16:20 ` [PATCH 082/120] MIPS: PS2: GS: IRQ support Fredrik Noring
2019-09-01 16:21 ` [PATCH 083/120] MIPS: PS2: GS: Define Graphics Synthesizer primitive structures Fredrik Noring
2019-09-01 16:21 ` [PATCH 084/120] MIPS: PS2: GIF: Define Graphics Synthesizer interface structures Fredrik Noring
2019-09-01 16:22 ` [PATCH 085/120] MIPS: PS2: GIF: Graphics Synthesizer interface support Fredrik Noring
2019-09-01 16:22 ` [PATCH 086/120] MIPS: PS2: GS: Graphics Synthesizer device init and video clock Fredrik Noring
2019-09-01 16:23 ` [PATCH 087/120] MIPS: PS2: GS: Compute block count and indices Fredrik Noring
2019-09-01 16:23 ` [PATCH 088/120] MIPS: PS2: GS: Primitive and texel coordinate transformations Fredrik Noring
2019-09-01 16:23 ` [PATCH 089/120] MIPS: PS2: GS: Approximate video region with ROM region Fredrik Noring
2019-09-01 16:24 ` [PATCH 090/120] macro: Extend COUNT_ARGS() from 12 to 32 arguments Fredrik Noring
2019-09-01 16:25 ` [PATCH 091/120] MIPS: PS2: GS: Show privileged registers with sysfs Fredrik Noring
2019-09-01 16:25 ` [PATCH 092/120] MIPS: PS2: GS: Store " Fredrik Noring
2019-09-01 16:25 ` [PATCH 093/120] fbdev: Add fb_warn_once() variant that only prints a warning once Fredrik Noring
2019-09-01 23:12 ` Philippe Mathieu-Daudé
2019-09-01 16:26 ` [PATCH 094/120] MIPS: PS2: FB: Frame buffer driver for the PlayStation 2 Fredrik Noring
2019-09-02 1:12 ` Jiaxun Yang
2019-09-02 14:40 ` Fredrik Noring
2019-09-02 17:47 ` Aaro Koskinen
2019-09-03 14:32 ` Fredrik Noring
2019-09-03 4:01 ` Jiaxun Yang
2019-09-03 17:42 ` Fredrik Noring
2019-09-03 17:59 ` Maciej W. Rozycki
2019-09-03 18:46 ` Fredrik Noring
2020-12-13 13:20 ` Fredrik Noring
2022-01-29 11:23 ` Fredrik Noring
2019-09-01 16:30 ` [PATCH 095/120] MIPS: PS2: FB: fb_set_par() standard-definition television support Fredrik Noring
2019-09-01 16:30 ` [PATCH 096/120] MIPS: PS2: FB: fb_set_par() high-definition " Fredrik Noring
2019-09-01 16:31 ` [PATCH 097/120] MIPS: PS2: FB: fb_set_par() VESA computer display mode support Fredrik Noring
2019-09-01 16:31 ` [PATCH 098/120] MIPS: PS2: FB: Preconfigure standard PAL, NTSC and VESA display modes Fredrik Noring
2019-09-01 16:31 ` [PATCH 099/120] MIPS: PS2: FB: Reset the Graphics Synthesizer drawing environment Fredrik Noring
2019-09-01 16:32 ` [PATCH 100/120] MIPS: PS2: FB: Clear the display buffer when changing video modes Fredrik Noring
2019-09-01 16:32 ` [PATCH 101/120] MIPS: PS2: FB: fb_setcolreg() 256 colour pseudo palette support Fredrik Noring
2019-09-01 16:32 ` [PATCH 102/120] MIPS: PS2: FB: fb_settile() with font stored as palette indexed textures Fredrik Noring
2019-09-01 16:32 ` [PATCH 103/120] MIPS: PS2: FB: Hardware accelerated fb_tilecopy() support Fredrik Noring
2019-09-01 16:33 ` Fredrik Noring [this message]
2019-09-01 16:33 ` [PATCH 105/120] MIPS: PS2: FB: Simplified fb_tileblit() support Fredrik Noring
2019-09-01 16:33 ` [PATCH 106/120] MIPS: PS2: FB: fb_tilecursor() placeholder Fredrik Noring
2019-09-01 16:33 ` [PATCH 107/120] MIPS: PS2: FB: Hardware accelerated fb_pan_display() support Fredrik Noring
2019-09-01 16:34 ` [PATCH 108/120] MIPS: PS2: FB: fb_blank() display power management signaling (DPMS) Fredrik Noring
2019-09-01 16:34 ` [PATCH 109/120] MIPS: PS2: FB: Disable GIF DMA completion interrupts Fredrik Noring
2019-09-01 16:34 ` [PATCH 110/120] MIPS: PS2: FB: PAL and NTSC grayscale support Fredrik Noring
2019-09-01 16:34 ` [PATCH 111/120] MIPS: PS2: FB: Analogue display mode adjustment module parameter Fredrik Noring
2019-09-01 16:35 ` [PATCH 112/120] USB: OHCI: Support for the PlayStation 2 Fredrik Noring
2019-09-01 16:35 ` [PATCH 113/120] USB: OHCI: OHCI_INTR_MIE workaround for freeze on " Fredrik Noring
2019-09-01 16:35 ` [PATCH 114/120] MIPS: PS2: Workaround for unexpected uLaunchELF CP0 Status user mode Fredrik Noring
2019-09-01 16:35 ` [PATCH 115/120] MIPS: PS2: Define initial PlayStation 2 devices Fredrik Noring
2019-09-01 16:35 ` [PATCH 116/120] MIPS: PS2: Define workarounds related to the PlayStation 2 Fredrik Noring
2019-09-01 16:36 ` [PATCH 117/120] MIPS: PS2: Define R5900 feature overrides Fredrik Noring
2019-09-01 16:36 ` [PATCH 118/120] MIPS: PS2: Define the PlayStation 2 platform Fredrik Noring
2019-09-01 16:36 ` [PATCH 119/120] MIPS: PS2: Initial support for the Sony PlayStation 2 Fredrik Noring
2019-09-01 16:37 ` [PATCH 120/120] MIPS: Fix name of BOOT_MEM_ROM_DATA Fredrik Noring
2019-09-01 23:15 ` Philippe Mathieu-Daudé
2019-09-02 1:02 ` Jiaxun Yang
2019-09-02 15:26 ` Fredrik Noring
2019-09-03 3:50 ` Jiaxun Yang
2019-09-03 16:06 ` Fredrik Noring
2019-09-04 14:19 ` [PATCH 000/120] Linux for the PlayStation 2 Paul Burton
2019-09-05 18:32 ` Fredrik Noring
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=0b481fd149279130e4fa0cfbed92f74c66cd5489.1567326213.git.noring@nocrew.org \
--to=noring@nocrew.org \
--cc=linux-mips@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).