extern struct emulator_config *cfg;
void rtg_blittemplate(uint16_t x, uint16_t y, uint16_t w, uint16_t h, uint32_t src_addr, uint32_t fgcol, uint32_t bgcol, uint16_t pitch, uint16_t t_pitch, uint16_t format, uint16_t offset_x, uint8_t mask, uint8_t draw_mode) {
- if (mask) {}
-
uint8_t *dptr = &rtg_mem[rtg_address_adj[1] + (x << format) + (y * pitch)];
uint8_t *sptr = NULL;
uint8_t cur_bit = 0, base_bit = 0, cur_byte = 0;
if (realtime_graphics_debug) {
printf("DEBUG: BlitTemplate - %d, %d (%dx%d)\n", x, y, w, h);
- printf("Src: %.8X (%.8X)\n", src_addr, rtg_address_adj[0]);
+ printf("Src: %.8X\n", src_addr);
printf("Dest: %.8X (%.8X)\n", rtg_address[1], rtg_address_adj[1]);
printf("pitch: %d t_pitch: %d format: %d\n", pitch, t_pitch, format);
printf("offset_x: %d mask: %.2X draw_mode: %d\n", offset_x, mask, draw_mode);
htobe32(bgcol),
};
- if (src_addr >= (PIGFX_RTG_BASE + PIGFX_REG_SIZE)) {
- sptr = &rtg_mem[src_addr - (PIGFX_RTG_BASE + PIGFX_REG_SIZE)];
+ sptr = get_mapped_data_pointer_by_address(cfg, src_addr);
+ if (!sptr) {
if (realtime_graphics_debug) {
- printf("Origin: %.8X\n", rtg_address[2]);
- printf("Grabbing data from RTG memory.\nData:\n");
- for (int i = 0; i < h; i++) {
- for (int j = 0; j < t_pitch; j++) {
- printf("%.2X", sptr[j + (i * t_pitch)]);
- }
- printf("\n");
- }
-#ifndef FAKESTORM
- printf("Data available at origin:\n");
- for (int i = 0; i < h; i++) {
- for (int j = 0; j < w; j++) {
- printf("%.2X", read8(rtg_address[2] + j + (i * t_pitch)));
- }
- printf("\n");
- }
-#endif
+ printf("BlitTemplate pattern data NOT available in mapped range, source address: $%.8X\n", src_addr);
}
- }
- else {
- int i = get_mapped_item_by_address(cfg, src_addr);
- if (i != -1) {
- sptr = &cfg->map_data[i][src_addr - cfg->map_offset[i]];
- if (realtime_graphics_debug) {
- printf("Grabbing data from maping %d - offset %.8lX\nData:\n", i, src_addr - cfg->map_offset[i]);
- for (int i = 0; i < h; i++) {
- for (int j = 0; j < t_pitch; j++) {
- printf("%.2X", sptr[j + (i * t_pitch)]);
- }
- printf("\n");
- }
- }
- }
- else {
- printf("BlitTemplate: Failed to find mapped range for address %.8X\n", src_addr);
- return;
+ } else {
+ if (realtime_graphics_debug) {
+ printf("BlitTemplate pattern data available in mapped range at $%.8X\n", src_addr);
}
}
switch (draw_mode) {
case DRAWMODE_JAM1:
for (uint16_t ys = 0; ys < h; ys++) {
- cur_byte = (invert) ? sptr[tmpl_x] ^ 0xFF : sptr[tmpl_x];
-
for (int xs = 0; xs < w; xs++) {
+ TEMPLATE_LOOPX;
if (w >= 8 && cur_bit == 0x80 && xs < w - 8) {
if (mask == 0xFF || format != RTGFMT_8BIT) {
SET_RTG_PIXELS(&dptr[xs << format], fg_color[format], format);
xs--;
cur_bit = 0x80;
}
- TEMPLATE_LOOPX;
}
TEMPLATE_LOOPY;
}
cur_byte = (invert) ? sptr[tmpl_x] ^ 0xFF : sptr[tmpl_x];
for (int xs = 0; xs < w; xs++) {
+ TEMPLATE_LOOPX;
if (w >= 8 && cur_bit == 0x80 && xs < w - 8) {
if (mask == 0xFF || format != RTGFMT_8BIT) {
SET_RTG_PIXELS2_COND(&dptr[xs << format], fg_color[format], bg_color[format], format);
xs--;
cur_bit = 0x80;
}
- TEMPLATE_LOOPX;
}
TEMPLATE_LOOPY;
}
cur_byte = (invert) ? sptr[tmpl_x] ^ 0xFF : sptr[tmpl_x];
for (int xs = 0; xs < w; xs++) {
+ TEMPLATE_LOOPX;
if (w >= 8 && cur_bit == 0x80 && xs < w - 8) {
INVERT_RTG_PIXELS(&dptr[xs << format], format)
xs += 7;
xs--;
cur_bit = 0x80;
}
- TEMPLATE_LOOPX;
}
TEMPLATE_LOOPY;
}
#include <time.h>
#include "irtg_structs.h"
#include "config_file/config_file.h"
+#include "gpio/ps_protocol.h"
#include "rtg.h"
#include "m68k.h"
gdebug("iBlitRectNoMaskComplete end\n");
break;
}
+ case RTGCMD_BLITTEMPLATE: {
+ // A0: BoardInfo *b, A1: RenderInfo *r, A2 Template *t
+ // D0: WORD x, D1: WORD y, D2: WORD w, D3: WORD h
+ // D4: UBYTE mask, D7: RGBFTYPE format
+ if (!r)
+ break;
+
+ uint16_t t_pitch = 0, x_offset = 0;
+ uint32_t src_addr = M68KR(M68K_REG_A2);
+ uint32_t fgcol = 0, bgcol = 0;
+ uint8_t draw_mode = 0;
+
+ struct P96Template *t = (struct P96Template *)get_mapped_data_pointer_by_address(cfg, M68KR(M68K_REG_A2));
+ if (t) {
+ t_pitch = be16toh(t->BytesPerRow);
+ fgcol = be32toh(t->FgPen);
+ bgcol = be32toh(t->BgPen);
+ x_offset = be16toh(t->XOffset);
+ draw_mode = t->DrawMode;
+ src_addr = be32toh(t->_p_Memory);
+ } else {
+ t_pitch = be16toh(ps_read_16(src_addr + (uint32_t)&t->BytesPerRow));
+ fgcol = be32toh(ps_read_32(src_addr + (uint32_t)&t->FgPen));
+ bgcol = be32toh(ps_read_32(src_addr + (uint32_t)&t->BgPen));
+ x_offset = be16toh(ps_read_16(src_addr + (uint32_t)&t->XOffset));
+ draw_mode = ps_read_8(src_addr + (uint32_t)&t->DrawMode);
+ src_addr = be32toh(ps_read_32(src_addr + (uint32_t)&t->_p_Memory));
+ }
+
+ cmd_mask = (uint8_t)M68KR(M68K_REG_D4);
+ rtg_address[1] = be32toh(r->_p_Memory);
+ rtg_address_adj[1] = rtg_address[1] - (PIGFX_RTG_BASE + PIGFX_REG_SIZE);
+
+ rtg_blittemplate(M68KR(M68K_REG_D0), M68KR(M68K_REG_D1), M68KR(M68K_REG_D2), M68KR(M68K_REG_D3), src_addr, fgcol, bgcol, CMD_PITCH, t_pitch, RGBF_D7, x_offset, cmd_mask, draw_mode);
+ break;
+ }
default:
printf("[!!!IRTG] Unnkonw/unhandled iRTG command %d.\n", cmd);
break;
}
void BlitTemplate (__REGA0(struct BoardInfo *b), __REGA1(struct RenderInfo *r), __REGA2(struct Template *t), __REGD0(WORD x), __REGD1(WORD y), __REGD2(WORD w), __REGD3(WORD h), __REGD4(UBYTE mask), __REGD7(RGBFTYPE format)) {
+#ifndef IRTG
if (!r || !t) return;
if (w < 1 || h < 1) return;
WRITEBYTE(RTG_U81, mask);
WRITEBYTE(RTG_U82, t->DrawMode);
WRITESHORT(RTG_COMMAND, RTGCMD_BLITTEMPLATE);
+#else
+ IWRITECMD(RTGCMD_BLITTEMPLATE);
+#endif
}
void BlitPattern (__REGA0(struct BoardInfo *b), __REGA1(struct RenderInfo *r), __REGA2(struct Pattern *p), __REGD0(WORD x), __REGD1(WORD y), __REGD2(WORD w), __REGD3(WORD h), __REGD4(UBYTE mask), __REGD7(RGBFTYPE format)) {