some handmade changes (nw)

This commit is contained in:
Miodrag Milanovic 2015-12-21 16:01:14 +01:00
parent 1fefd835ce
commit a55ab6d615
69 changed files with 207 additions and 229 deletions

View File

@ -70,7 +70,7 @@ sns_rom_bsmempak_device::sns_rom_bsmempak_device(const machine_config &mconfig,
void sns_rom_bsx_device::device_start()
{
m_base_unit = auto_alloc(machine(), BSX_base(machine()));
m_base_unit = std::make_unique<BSX_base>(machine());
m_base_unit->init();
memset(m_cart_regs, 0x00, sizeof(m_cart_regs));

View File

@ -51,7 +51,7 @@ public:
virtual DECLARE_WRITE8_MEMBER(chip_write) override;
// base regs
BSX_base *m_base_unit;
std::unique_ptr<BSX_base> m_base_unit;
// cart regs
UINT8 m_cart_regs[16];

View File

@ -369,20 +369,20 @@ void SDD1_OL::OL_launch(UINT8 *ROM, UINT32 *mmc)
SDD1_emu::SDD1_emu(running_machine &machine)
: m_machine(machine)
{
m_IM = auto_alloc(machine, SDD1_IM());
m_GCD = auto_alloc(machine, SDD1_GCD(m_IM));
m_BG0 = auto_alloc(machine, SDD1_BG(m_GCD, 0));
m_BG1 = auto_alloc(machine, SDD1_BG(m_GCD, 1));
m_BG2 = auto_alloc(machine, SDD1_BG(m_GCD, 2));
m_BG3 = auto_alloc(machine, SDD1_BG(m_GCD, 3));
m_BG4 = auto_alloc(machine, SDD1_BG(m_GCD, 4));
m_BG5 = auto_alloc(machine, SDD1_BG(m_GCD, 5));
m_BG6 = auto_alloc(machine, SDD1_BG(m_GCD, 6));
m_BG7 = auto_alloc(machine, SDD1_BG(m_GCD, 7));
m_PEM = auto_alloc(machine, SDD1_PEM(m_BG0, m_BG1, m_BG2, m_BG3,
m_BG4, m_BG5, m_BG6, m_BG7));
m_CM = auto_alloc(machine, SDD1_CM(m_PEM));
m_OL = auto_alloc(machine, SDD1_OL(m_CM));
m_IM = std::make_unique<SDD1_IM>();
m_GCD = std::make_unique<SDD1_GCD>(m_IM.get());
m_BG0 = std::make_unique<SDD1_BG>(m_GCD.get(), 0);
m_BG1 = std::make_unique<SDD1_BG>(m_GCD.get(), 1);
m_BG2 = std::make_unique<SDD1_BG>(m_GCD.get(), 2);
m_BG3 = std::make_unique<SDD1_BG>(m_GCD.get(), 3);
m_BG4 = std::make_unique<SDD1_BG>(m_GCD.get(), 4);
m_BG5 = std::make_unique<SDD1_BG>(m_GCD.get(), 5);
m_BG6 = std::make_unique<SDD1_BG>(m_GCD.get(), 6);
m_BG7 = std::make_unique<SDD1_BG>(m_GCD.get(), 7);
m_PEM = std::make_unique<SDD1_PEM>(m_BG0.get(), m_BG1.get(), m_BG2.get(), m_BG3.get(),
m_BG4.get(), m_BG5.get(), m_BG6.get(), m_BG7.get());
m_CM = std::make_unique<SDD1_CM>(m_PEM.get());
m_OL = std::make_unique<SDD1_OL>(m_CM.get());
}
void SDD1_emu::SDD1emu_decompress(UINT8 *ROM, UINT32 *mmc, UINT32 in_buf, UINT16 out_len, UINT8 *out_buf)
@ -426,7 +426,7 @@ sns_rom_sdd1_device::sns_rom_sdd1_device(const machine_config &mconfig, const ch
void sns_rom_sdd1_device::device_start()
{
m_sdd1emu = auto_alloc(machine(), SDD1_emu(machine()));
m_sdd1emu = std::make_unique<SDD1_emu>(machine());
m_buffer.data = std::make_unique<UINT8[]>(0x10000);
m_buffer.ready = 0;

View File

@ -126,13 +126,19 @@ public:
running_machine &machine() const { return m_machine; }
SDD1_IM* m_IM;
SDD1_GCD* m_GCD;
SDD1_BG* m_BG0; SDD1_BG* m_BG1; SDD1_BG* m_BG2; SDD1_BG* m_BG3;
SDD1_BG* m_BG4; SDD1_BG* m_BG5; SDD1_BG* m_BG6; SDD1_BG* m_BG7;
SDD1_PEM* m_PEM;
SDD1_CM* m_CM;
SDD1_OL* m_OL;
std::unique_ptr<SDD1_IM> m_IM;
std::unique_ptr<SDD1_GCD> m_GCD;
std::unique_ptr<SDD1_BG> m_BG0;
std::unique_ptr<SDD1_BG> m_BG1;
std::unique_ptr<SDD1_BG> m_BG2;
std::unique_ptr<SDD1_BG> m_BG3;
std::unique_ptr<SDD1_BG> m_BG4;
std::unique_ptr<SDD1_BG> m_BG5;
std::unique_ptr<SDD1_BG> m_BG6;
std::unique_ptr<SDD1_BG> m_BG7;
std::unique_ptr<SDD1_PEM> m_PEM;
std::unique_ptr<SDD1_CM> m_CM;
std::unique_ptr<SDD1_OL> m_OL;
void SDD1emu_decompress(UINT8 *ROM, UINT32 *mmc, UINT32 in_buf, UINT16 out_len, UINT8 *out_buf);
@ -176,7 +182,7 @@ public:
UINT16 size; // $43x5-$43x6 -- DMA transfer size
} m_dma[8];
SDD1_emu* m_sdd1emu;
std::unique_ptr<SDD1_emu> m_sdd1emu;
struct
{

View File

@ -50,7 +50,7 @@ sns_rom_spc7110rtc_device::sns_rom_spc7110rtc_device(const machine_config &mconf
void sns_rom_spc7110_device::spc7110_start()
{
m_decomp = auto_alloc(machine(), SPC7110_Decomp(machine()));
m_decomp = std::make_unique<SPC7110_Decomp>(machine());
// The SPC7110 works in conjunction with 0x2000 of RAM, which is battery backed up (and hence emulated by our m_nvram)

View File

@ -130,7 +130,7 @@ public:
UINT8 m_r480b; // decompression control register
UINT8 m_r480c; // decompression status
SPC7110_Decomp* m_decomp;
std::unique_ptr<SPC7110_Decomp> m_decomp;
UINT8 m_r4811; // data pointer low
UINT8 m_r4812; // data pointer high

View File

@ -203,12 +203,10 @@ void mips3_device::device_stop()
if (m_drcfe != nullptr)
{
auto_free(machine(), m_drcfe);
m_drcfe = nullptr;
}
if (m_drcuml != nullptr)
{
auto_free(machine(), m_drcuml);
m_drcuml = nullptr;
}
}
@ -357,7 +355,7 @@ void mips3_device::device_start()
UINT32 flags = 0;
/* initialize the UML generator */
m_drcuml = auto_alloc(machine(), drcuml_state(*this, m_cache, flags, 8, 32, 2));
m_drcuml = std::make_unique<drcuml_state>(*this, m_cache, flags, 8, 32, 2);
/* add symbols for our stuff */
m_drcuml->symbol_add(&m_core->pc, sizeof(m_core->pc), "pc");
@ -403,7 +401,7 @@ void mips3_device::device_start()
m_drcuml->symbol_add(&m_fpmode, sizeof(m_fpmode), "fpmode");
/* initialize the front-end helper */
m_drcfe = auto_alloc(machine(), mips3_frontend(this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE));
m_drcfe = std::make_unique<mips3_frontend>(this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE);
/* allocate memory for cache-local state and initialize it */
memcpy(m_fpmode, fpmode_source, sizeof(fpmode_source));

View File

@ -409,8 +409,8 @@ private:
/* core state */
drc_cache m_cache; /* pointer to the DRC code cache */
drcuml_state * m_drcuml; /* DRC UML generator state */
mips3_frontend * m_drcfe; /* pointer to the DRC front-end state */
std::unique_ptr<drcuml_state> m_drcuml; /* DRC UML generator state */
std::unique_ptr<mips3_frontend> m_drcfe; /* pointer to the DRC front-end state */
UINT32 m_drcoptions; /* configurable DRC options */
/* internal stuff */

View File

@ -280,7 +280,7 @@ void mips3_device::code_flush_cache()
void mips3_device::code_compile_block(UINT8 mode, offs_t pc)
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
compiler_state compiler = { 0 };
const opcode_desc *seqhead, *seqlast;
const opcode_desc *desclist;
@ -553,7 +553,7 @@ static void cfunc_unimplemented(void *param)
void mips3_device::static_generate_entry_point()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
code_label skip = 1;
drcuml_block *block;
@ -601,7 +601,7 @@ void mips3_device::static_generate_entry_point()
void mips3_device::static_generate_nocode_handler()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -626,7 +626,7 @@ void mips3_device::static_generate_nocode_handler()
void mips3_device::static_generate_out_of_cycles()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -651,7 +651,7 @@ void mips3_device::static_generate_out_of_cycles()
void mips3_device::static_generate_tlb_mismatch()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* forward references */
@ -702,7 +702,7 @@ void mips3_device::static_generate_tlb_mismatch()
void mips3_device::static_generate_exception(UINT8 exception, int recover, const char *name)
{
code_handle *&exception_handle = recover ? m_exception[exception] : m_exception_norecover[exception];
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
UINT32 offset = 0x180;
code_label next = 1;
code_label skip = 2;
@ -805,7 +805,7 @@ void mips3_device::static_generate_memory_accessor(int mode, int size, int iswri
code_handle &exception_tlb = *m_exception[iswrite ? EXCEPTION_TLBSTORE : EXCEPTION_TLBLOAD];
code_handle &exception_tlbfill = *m_exception[iswrite ? EXCEPTION_TLBSTORE_FILL : EXCEPTION_TLBLOAD_FILL];
code_handle &exception_addrerr = *m_exception[iswrite ? EXCEPTION_ADDRSTORE : EXCEPTION_ADDRLOAD];
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
int tlbmiss = 0;
int label = 1;

View File

@ -537,8 +537,8 @@ protected:
/* core state */
drc_cache m_cache; /* pointer to the DRC code cache */
drcuml_state * m_drcuml; /* DRC UML generator state */
ppc_frontend * m_drcfe; /* pointer to the DRC front-end state */
std::unique_ptr<drcuml_state> m_drcuml; /* DRC UML generator state */
std::unique_ptr<ppc_frontend> m_drcfe; /* pointer to the DRC front-end state */
UINT32 m_drcoptions; /* configurable DRC options */
/* parameters for subroutines */

View File

@ -882,7 +882,7 @@ void ppc_device::device_start()
UINT32 flags = 0;
/* initialize the UML generator */
m_drcuml = auto_alloc(machine(), drcuml_state(*this, m_cache, flags, 8, 32, 2));
m_drcuml = std::make_unique<drcuml_state>(*this, m_cache, flags, 8, 32, 2);
/* add symbols for our stuff */
m_drcuml->symbol_add(&m_core->pc, sizeof(m_core->pc), "pc");
@ -928,7 +928,7 @@ void ppc_device::device_start()
m_drcuml->symbol_add(&m_fcmp_cr_table, sizeof(m_fcmp_cr_table), "fcmp_cr_table");
/* initialize the front-end helper */
m_drcfe = auto_alloc(machine(), ppc_frontend(this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE));
m_drcfe = std::make_unique<ppc_frontend>(this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE);
/* compute the register parameters */
for (int regnum = 0; regnum < 32; regnum++)
@ -1151,10 +1151,6 @@ void ppc_device::device_stop()
if (m_vtlb != nullptr)
vtlb_free(m_vtlb);
m_vtlb = nullptr;
/* clean up the DRC */
auto_free(machine(), m_drcfe);
auto_free(machine(), m_drcuml);
}

View File

@ -369,7 +369,7 @@ void ppc_device::code_compile_block(UINT8 mode, offs_t pc)
/* get a description of this sequence */
desclist = m_drcfe->describe_code(pc);
if (m_drcuml->logging() || m_drcuml->logging_native())
log_opcode_desc(m_drcuml, desclist, 0);
log_opcode_desc(m_drcuml.get(), desclist, 0);
bool succeeded = false;
while (!succeeded)
@ -641,10 +641,10 @@ void ppc_device::static_generate_entry_point()
block = m_drcuml->begin_block(20);
/* forward references */
alloc_handle(m_drcuml, &m_nocode, "nocode");
alloc_handle(m_drcuml, &m_exception_norecover[EXCEPTION_EI], "exception_ei_norecover");
alloc_handle(m_drcuml.get(), &m_nocode, "nocode");
alloc_handle(m_drcuml.get(), &m_exception_norecover[EXCEPTION_EI], "exception_ei_norecover");
alloc_handle(m_drcuml, &m_entry, "entry");
alloc_handle(m_drcuml.get(), &m_entry, "entry");
UML_HANDLE(block, *m_entry); // handle entry
/* reset the FPU mode */
@ -685,7 +685,7 @@ void ppc_device::static_generate_nocode_handler()
block = m_drcuml->begin_block(10);
/* generate a hash jump via the current mode and PC */
alloc_handle(m_drcuml, &m_nocode, "nocode");
alloc_handle(m_drcuml.get(), &m_nocode, "nocode");
UML_HANDLE(block, *m_nocode); // handle nocode
UML_GETEXP(block, I0); // getexp i0
UML_MOV(block, mem(&m_core->pc), I0); // mov [pc],i0
@ -709,7 +709,7 @@ void ppc_device::static_generate_out_of_cycles()
block = m_drcuml->begin_block(10);
/* generate a hash jump via the current mode and PC */
alloc_handle(m_drcuml, &m_out_of_cycles, "out_of_cycles");
alloc_handle(m_drcuml.get(), &m_out_of_cycles, "out_of_cycles");
UML_HANDLE(block, *m_out_of_cycles); // handle out_of_cycles
UML_GETEXP(block, I0); // getexp i0
UML_MOV(block, mem(&m_core->pc), I0); // mov <pc>,i0
@ -731,15 +731,15 @@ void ppc_device::static_generate_tlb_mismatch()
int isi, exit, label = 1;
/* forward references */
alloc_handle(m_drcuml, &m_exception[EXCEPTION_ISI], "exception_isi");
alloc_handle(m_drcuml.get(), &m_exception[EXCEPTION_ISI], "exception_isi");
if (m_cap & PPCCAP_603_MMU)
alloc_handle(m_drcuml, &m_exception[EXCEPTION_ITLBMISS], "exception_itlb_miss");
alloc_handle(m_drcuml.get(), &m_exception[EXCEPTION_ITLBMISS], "exception_itlb_miss");
/* begin generating */
block = m_drcuml->begin_block(20);
/* generate a hash jump via the current mode and PC */
alloc_handle(m_drcuml, &m_tlb_mismatch, "tlb_mismatch");
alloc_handle(m_drcuml.get(), &m_tlb_mismatch, "tlb_mismatch");
UML_HANDLE(block, *m_tlb_mismatch); // handle tlb_mismatch
UML_RECOVER(block, I0, MAPVAR_PC); // recover i0,PC
UML_SHR(block, I1, I0, 12); // shr i1,i0,12
@ -792,7 +792,7 @@ void ppc_device::static_generate_exception(UINT8 exception, int recover, const c
block = m_drcuml->begin_block(1024);
/* add a global entry for this */
alloc_handle(m_drcuml, &exception_handle, name);
alloc_handle(m_drcuml.get(), &exception_handle, name);
UML_HANDLE(block, *exception_handle); // handle name
/* exception parameter is expected to be the fault address in this case */
@ -981,7 +981,7 @@ void ppc_device::static_generate_memory_accessor(int mode, int size, int iswrite
block = m_drcuml->begin_block(1024);
/* add a global entry for this */
alloc_handle(m_drcuml, &handleptr, name);
alloc_handle(m_drcuml.get(), &handleptr, name);
UML_HANDLE(block, *handleptr); // handle *handleptr
/* check for unaligned accesses and break into two */
@ -1388,7 +1388,7 @@ void ppc_device::static_generate_swap_tgpr()
block = m_drcuml->begin_block(30);
/* generate a hash jump via the current mode and PC */
alloc_handle(m_drcuml, &m_swap_tgpr, "swap_tgpr");
alloc_handle(m_drcuml.get(), &m_swap_tgpr, "swap_tgpr");
UML_HANDLE(block, *m_swap_tgpr); // handle swap_tgpr
for (regnum = 0; regnum < 4; regnum++)
{
@ -1423,7 +1423,7 @@ void ppc_device::static_generate_lsw_entries(int mode)
/* allocate a handle */
sprintf(temp, "lsw%d", regnum);
alloc_handle(m_drcuml, &m_lsw[mode][regnum], temp);
alloc_handle(m_drcuml.get(), &m_lsw[mode][regnum], temp);
UML_HANDLE(block, *m_lsw[mode][regnum]); // handle lsw<regnum>
UML_LABEL(block, regnum); // regnum:
UML_ADD(block, I0, mem(&m_core->updateaddr), 0); // add i0,[updateaddr],0
@ -1477,7 +1477,7 @@ void ppc_device::static_generate_stsw_entries(int mode)
/* allocate a handle */
sprintf(temp, "stsw%d", regnum);
alloc_handle(m_drcuml, &m_stsw[mode][regnum], temp);
alloc_handle(m_drcuml.get(), &m_stsw[mode][regnum], temp);
UML_HANDLE(block, *m_stsw[mode][regnum]); // handle stsw<regnum>
UML_LABEL(block, regnum); // regnum:
UML_ADD(block, I0, mem(&m_core->updateaddr), 0); // add i0,[updateaddr],0

View File

@ -373,11 +373,11 @@ void rsp_device::device_start()
if (m_isdrc)
{
m_cop2 = auto_alloc(machine(), rsp_cop2_drc(*this, machine()));
m_cop2 = std::make_unique<rsp_cop2_drc>(*this, machine());
}
else
{
m_cop2 = auto_alloc(machine(), rsp_cop2(*this, machine()));
m_cop2 = std::make_unique<rsp_cop2>(*this, machine());
}
m_cop2->init();
m_cop2->start();
@ -393,7 +393,7 @@ void rsp_device::device_start()
/* initialize the UML generator */
UINT32 drc_flags = 0;
m_drcuml = auto_alloc(machine(), drcuml_state(*this, m_cache, drc_flags, 8, 32, 2));
m_drcuml = std::make_unique<drcuml_state>(*this, m_cache, drc_flags, 8, 32, 2);
/* add symbols for our stuff */
m_drcuml->symbol_add(&m_rsp_state->pc, sizeof(m_rsp_state->pc), "pc");
@ -411,7 +411,7 @@ void rsp_device::device_start()
m_drcuml->symbol_add(&m_numcycles, sizeof(m_numcycles), "numcycles");
/* initialize the front-end helper */
m_drcfe = auto_alloc(machine(), rsp_frontend(*this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE));
m_drcfe = std::make_unique<rsp_frontend>(*this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE);
/* compute the register parameters */
for (int regnum = 0; regnum < 32; regnum++)
@ -596,21 +596,6 @@ void rsp_device::device_stop()
if (m_exec_output)
fclose(m_exec_output);
m_exec_output = nullptr;
/* clean up the DRC */
if (m_drcuml)
{
auto_free(machine(), m_drcuml);
}
if (m_drcfe)
{
auto_free(machine(), m_drcfe);
}
if (m_cop2)
{
auto_free(machine(), m_cop2);
}
}
void rsp_device::device_reset()

View File

@ -217,8 +217,8 @@ private:
/* core state */
drc_cache m_cache; /* pointer to the DRC code cache */
drcuml_state * m_drcuml; /* DRC UML generator state */
rsp_frontend * m_drcfe; /* pointer to the DRC front-end state */
std::unique_ptr<drcuml_state> m_drcuml; /* DRC UML generator state */
std::unique_ptr<rsp_frontend> m_drcfe; /* pointer to the DRC front-end state */
UINT32 m_drcoptions; /* configurable DRC options */
/* internal stuff */
@ -269,7 +269,7 @@ protected:
direct_read_data *m_direct;
private:
rsp_cop2 *m_cop2;
std::unique_ptr<rsp_cop2> m_cop2;
UINT32 *m_dmem32;
UINT16 *m_dmem16;

View File

@ -78,9 +78,10 @@ class rsp_cop2
{
friend class rsp_device;
protected:
public:
rsp_cop2(rsp_device &rsp, running_machine &machine);
protected:
virtual void init();
virtual void start();

View File

@ -21,9 +21,9 @@
class rsp_cop2_drc : public rsp_cop2
{
friend class rsp_device;
public:
rsp_cop2_drc(rsp_device &rsp, running_machine &machine) : rsp_cop2(rsp, machine) { }
private:
virtual int generate_cop2(drcuml_block *block, rsp_device::compiler_state *compiler, const opcode_desc *desc) override;
virtual int generate_lwc2(drcuml_block *block, rsp_device::compiler_state *compiler, const opcode_desc *desc) override;
virtual int generate_swc2(drcuml_block *block, rsp_device::compiler_state *compiler, const opcode_desc *desc) override;

View File

@ -260,7 +260,7 @@ void cfunc_sp_set_status_cb(void *param)
void rsp_device::execute_run_drc()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
int execute_result;
/* reset the cache if dirty */
@ -350,7 +350,7 @@ void rsp_device::code_flush_cache()
void rsp_device::code_compile_block(offs_t pc)
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
compiler_state compiler = { 0 };
const opcode_desc *seqhead, *seqlast;
const opcode_desc *desclist;
@ -490,7 +490,7 @@ static void cfunc_fatalerror(void *param)
void rsp_device::static_generate_entry_point()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -518,7 +518,7 @@ void rsp_device::static_generate_entry_point()
void rsp_device::static_generate_nocode_handler()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -543,7 +543,7 @@ void rsp_device::static_generate_nocode_handler()
void rsp_device::static_generate_out_of_cycles()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -569,7 +569,7 @@ void rsp_device::static_generate_memory_accessor(int size, int iswrite, const ch
/* on entry, address is in I0; data for writes is in I1 */
/* on exit, read result is in I0 */
/* routine trashes I0-I1 */
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */

View File

@ -199,11 +199,6 @@ sh2_device::sh2_device(const machine_config &mconfig, const char *tag, device_t
void sh2_device::device_stop()
{
/* clean up the DRC */
if ( m_drcuml )
{
auto_free(machine(), m_drcuml);
}
}
@ -2536,7 +2531,7 @@ void sh2_device::device_start()
/* initialize the UML generator */
UINT32 flags = 0;
m_drcuml = auto_alloc(machine(), drcuml_state(*this, m_cache, flags, 1, 32, 1));
m_drcuml = std::make_unique<drcuml_state>(*this, m_cache, flags, 1, 32, 1);
/* add symbols for our stuff */
m_drcuml->symbol_add(&m_sh2_state->pc, sizeof(m_sh2_state->pc), "pc");
@ -2555,7 +2550,7 @@ void sh2_device::device_start()
m_drcuml->symbol_add(&m_sh2_state->mach, sizeof(m_sh2_state->macl), "mach");
/* initialize the front-end helper */
m_drcfe = auto_alloc(machine(), sh2_frontend(this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE));
m_drcfe = std::make_unique<sh2_frontend>(this, COMPILE_BACKWARDS_BYTES, COMPILE_FORWARDS_BYTES, SINGLE_INSTRUCTION_MODE ? 1 : COMPILE_MAX_SEQUENCE);
/* compute the register parameters */
for (int regnum = 0; regnum < 16; regnum++)

View File

@ -219,8 +219,8 @@ private:
sh2_ftcsr_read_delegate m_ftcsr_read_cb;
drc_cache m_cache; /* pointer to the DRC code cache */
drcuml_state * m_drcuml; /* DRC UML generator state */
sh2_frontend * m_drcfe; /* pointer to the DRC front-end state */
std::unique_ptr<drcuml_state> m_drcuml; /* DRC UML generator state */
std::unique_ptr<sh2_frontend> m_drcfe; /* pointer to the DRC front-end state */
UINT32 m_drcoptions; /* configurable DRC options */
internal_sh2_state *m_sh2_state;

View File

@ -586,7 +586,7 @@ void sh2_device::func_SUBV() {}
void sh2_device::code_flush_cache()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
/* empty the transient cache contents */
drcuml->reset();
@ -617,7 +617,7 @@ void sh2_device::code_flush_cache()
/* Execute cycles - returns number of cycles actually run */
void sh2_device::execute_run_drc()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
int execute_result;
// run any active DMAs now
@ -665,7 +665,7 @@ void sh2_device::execute_run_drc()
void sh2_device::code_compile_block(UINT8 mode, offs_t pc)
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
compiler_state compiler = { 0 };
const opcode_desc *seqhead, *seqlast;
const opcode_desc *desclist;
@ -781,7 +781,7 @@ void sh2_device::code_compile_block(UINT8 mode, offs_t pc)
void sh2_device::static_generate_entry_point()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
code_label skip = 1;
drcuml_block *block;
@ -861,7 +861,7 @@ void sh2_device::static_generate_entry_point()
void sh2_device::static_generate_nocode_handler()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -886,7 +886,7 @@ void sh2_device::static_generate_nocode_handler()
void sh2_device::static_generate_out_of_cycles()
{
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
/* begin generating */
@ -912,7 +912,7 @@ void sh2_device::static_generate_memory_accessor(int size, int iswrite, const ch
/* on entry, address is in I0; data for writes is in I1 */
/* on exit, read result is in I0 */
/* routine trashes I0 */
drcuml_state *drcuml = m_drcuml;
drcuml_state *drcuml = m_drcuml.get();
drcuml_block *block;
int label = 1;

View File

@ -399,7 +399,7 @@ void ymf271_device::update_lfo(YMF271Slot *slot)
slot->lfo_phase += slot->lfo_step;
slot->lfo_amplitude = m_lut_alfo[slot->lfowave][(slot->lfo_phase >> LFO_SHIFT) & (LFO_LENGTH-1)];
slot->lfo_phasemod = m_lut_plfo[slot->lfowave][slot->pms][(slot->lfo_phase >> LFO_SHIFT) & (LFO_LENGTH-1)];
slot->lfo_phasemod = m_lut_plfo[slot->lfowave][slot->pms].get()[(slot->lfo_phase >> LFO_SHIFT) & (LFO_LENGTH-1)];
calculate_step(slot);
}
@ -1508,7 +1508,7 @@ void ymf271_device::init_tables()
m_lut_waves[i] = std::make_unique<INT16[]>(SIN_LEN);
for (i = 0; i < 4*8; i++)
m_lut_plfo[i>>3][i&7] = auto_alloc_array(machine(), double, LFO_LENGTH);
m_lut_plfo[i>>3][i&7] = std::make_unique<double[]>(LFO_LENGTH);
for (i = 0; i < 4; i++)
m_lut_alfo[i] = std::make_unique<int[]>(LFO_LENGTH);
@ -1568,14 +1568,14 @@ void ymf271_device::init_tables()
for (j = 0; j < 4; j++)
{
m_lut_plfo[j][0][i] = pow(2.0, 0.0);
m_lut_plfo[j][1][i] = pow(2.0, (3.378 * plfo[j]) / 1200.0);
m_lut_plfo[j][2][i] = pow(2.0, (5.0646 * plfo[j]) / 1200.0);
m_lut_plfo[j][3][i] = pow(2.0, (6.7495 * plfo[j]) / 1200.0);
m_lut_plfo[j][4][i] = pow(2.0, (10.1143 * plfo[j]) / 1200.0);
m_lut_plfo[j][5][i] = pow(2.0, (20.1699 * plfo[j]) / 1200.0);
m_lut_plfo[j][6][i] = pow(2.0, (40.1076 * plfo[j]) / 1200.0);
m_lut_plfo[j][7][i] = pow(2.0, (79.307 * plfo[j]) / 1200.0);
m_lut_plfo[j][0].get()[i] = pow(2.0, 0.0);
m_lut_plfo[j][1].get()[i] = pow(2.0, (3.378 * plfo[j]) / 1200.0);
m_lut_plfo[j][2].get()[i] = pow(2.0, (5.0646 * plfo[j]) / 1200.0);
m_lut_plfo[j][3].get()[i] = pow(2.0, (6.7495 * plfo[j]) / 1200.0);
m_lut_plfo[j][4].get()[i] = pow(2.0, (10.1143 * plfo[j]) / 1200.0);
m_lut_plfo[j][5].get()[i] = pow(2.0, (20.1699 * plfo[j]) / 1200.0);
m_lut_plfo[j][6].get()[i] = pow(2.0, (40.1076 * plfo[j]) / 1200.0);
m_lut_plfo[j][7].get()[i] = pow(2.0, (79.307 * plfo[j]) / 1200.0);
}
// LFO amplitude modulation

View File

@ -122,7 +122,7 @@ private:
// lookup tables
std::unique_ptr<INT16[]> m_lut_waves[8];
double *m_lut_plfo[4][8];
std::unique_ptr<double[]> m_lut_plfo[4][8];
std::unique_ptr<int[]> m_lut_alfo[4];
double m_lut_ar[64];
double m_lut_dc[64];

View File

@ -2125,7 +2125,7 @@ int saturn_state::stv_vdp1_start ( void )
m_vdp1_vram = make_unique_clear<UINT32[]>(0x100000/4 );
m_vdp1.gfx_decode = std::make_unique<UINT8[]>(0x100000 );
stv_vdp1_shading_data = auto_alloc(machine(), struct stv_vdp1_poly_scanline_data);
stv_vdp1_shading_data = std::make_unique<struct stv_vdp1_poly_scanline_data>();
m_vdp1.framebuffer[0] = std::make_unique<UINT16[]>(1024 * 256 * 2 ); /* *2 is for double interlace */
m_vdp1.framebuffer[1] = std::make_unique<UINT16[]>(1024 * 256 * 2 );

View File

@ -1690,8 +1690,6 @@ device_debug::device_debug(device_t &device)
device_debug::~device_debug()
{
auto_free(m_device.machine(), m_trace);
// free breakpoints and watchpoints
breakpoint_clear_all();
watchpoint_clear_all();
@ -2759,12 +2757,11 @@ UINT32 device_debug::compute_opcode_crc32(offs_t pc) const
void device_debug::trace(FILE *file, bool trace_over, const char *action)
{
// delete any existing tracers
auto_free(m_device.machine(), m_trace);
m_trace = nullptr;
// if we have a new file, make a new tracer
if (file != nullptr)
m_trace = auto_alloc(m_device.machine(), tracer(*this, *file, trace_over, action));
m_trace = std::make_unique<tracer>(*this, *file, trace_over, action);
}

View File

@ -360,7 +360,7 @@ private:
// (0 = not tracing over,
// ~0 = not currently tracing over)
};
tracer * m_trace; // tracer state
std::unique_ptr<tracer> m_trace; // tracer state
// hotspots
struct hotspot_entry

View File

@ -49,7 +49,7 @@ public:
required_device<cquestsnd_cpu_device> m_soundcpu;
required_device<screen_device> m_screen;
required_shared_ptr<UINT16> m_generic_paletteram_16;
rgb_t *m_colormap;
std::unique_ptr<rgb_t[]> m_colormap;
DECLARE_WRITE16_MEMBER(palette_w);
DECLARE_READ16_MEMBER(line_r);
DECLARE_WRITE16_MEMBER(laserdisc_w);
@ -444,7 +444,7 @@ void cubeqst_state::machine_start()
/* TODO: Use resistor values */
int i;
m_colormap = auto_alloc_array(machine(), rgb_t, 65536);
m_colormap = std::make_unique<rgb_t[]>(65536);
for (i = 0; i < 65536; ++i)
{
UINT8 a, r, g, b, y;

View File

@ -247,7 +247,7 @@ void igs017_state::decrypt_program_rom(int mask, int a7, int a6, int a5, int a4,
{
int length = memregion("maincpu")->bytes();
UINT8 *rom = memregion("maincpu")->base();
UINT8 *tmp = auto_alloc_array(machine(), UINT8, length);
std::unique_ptr<UINT8[]> tmp = std::make_unique<UINT8[]>(length);
int i;
// decrypt the program ROM
@ -283,7 +283,7 @@ void igs017_state::decrypt_program_rom(int mask, int a7, int a6, int a5, int a4,
}
}
memcpy(tmp,rom,length);
memcpy(tmp.get(),rom,length);
// address lines swap
for (i = 0;i < length;i++)
@ -347,11 +347,11 @@ void igs017_state::tjsb_decrypt_sprites()
{
int length = memregion("sprites")->bytes();
UINT8 *rom = memregion("sprites")->base();
UINT8 *tmp = auto_alloc_array(machine(), UINT8, length);
std::unique_ptr<UINT8[]> tmp = std::make_unique<UINT8[]>(length);
int i, addr;
// address lines swap
memcpy(tmp, rom, length);
memcpy(tmp.get(), rom, length);
for (i = 0; i < length; i++)
{
addr = (i & ~0xff) | BITSWAP8(i,7,6,5,2,1,4,3,0);
@ -739,11 +739,11 @@ void igs017_state::lhzb2_decrypt_sprites()
{
int length = memregion("sprites")->bytes();
UINT8 *rom = memregion("sprites")->base();
UINT8 *tmp = auto_alloc_array(machine(), UINT8, length);
std::unique_ptr<UINT8[]> tmp = std::make_unique<UINT8[]>(length);
int i, addr;
// address lines swap
memcpy(tmp, rom, length);
memcpy(tmp.get(), rom, length);
for (i = 0; i < length; i++)
{
addr = (i & ~0xffff) | BITSWAP16(i,15,14,13,6,7,10,9,8,11,12,5,4,3,2,1,0);
@ -1053,11 +1053,11 @@ void igs017_state::spkrform_decrypt_sprites()
{
int length = memregion("sprites")->bytes();
UINT8 *rom = memregion("sprites")->base();
UINT8 *tmp = auto_alloc_array(machine(), UINT8, length);
std::unique_ptr<UINT8[]> tmp = std::make_unique<UINT8[]>(length);
int i, addr;
// address lines swap
memcpy(tmp, rom, length);
memcpy(tmp.get(), rom, length);
for (i = 0; i < length; i++)
{
if (i & 0x80000)

View File

@ -811,7 +811,7 @@ int namcos21_state::init_dsp()
pMem[0x8000] = 0xFF80;
pMem[0x8001] = 0x0000;
m_mpDspState = auto_alloc_clear(machine(), dsp_state);
m_mpDspState = make_unique_clear<dsp_state>();
return 0;
}

View File

@ -1384,7 +1384,7 @@ struct c404_t
struct render_t
{
namcos23_renderer *polymgr;
std::unique_ptr<namcos23_renderer> polymgr;
int cur;
int poly_count;
int count[2];
@ -2380,7 +2380,7 @@ VIDEO_START_MEMBER(namcos23_state,s23)
m_bgtilemap = &machine().tilemap().create(m_gfxdecode, tilemap_get_info_delegate(FUNC(namcos23_state::TextTilemapGetInfo),this), TILEMAP_SCAN_ROWS, 16, 16, 64, 64);
m_bgtilemap->set_transparent_pen(0xf);
m_bgtilemap->set_scrolldx(860, 860);
m_render.polymgr = auto_alloc(machine(), namcos23_renderer(*this));
m_render.polymgr = std::make_unique<namcos23_renderer>(*this);
}

View File

@ -99,7 +99,7 @@ public:
m_uart(*this, "ns16450_0"),
m_microtouch(*this, "microtouch") { }
UINT8 *m_banked_nvram;
std::unique_ptr<UINT8[]> m_banked_nvram;
required_device<ns16450_device> m_uart;
required_device<microtouch_device> m_microtouch;
@ -140,7 +140,7 @@ WRITE8_MEMBER(pcat_nit_state::pcat_nit_rombank_w)
space.install_readwrite_bank(0x000d8000, 0x000d9fff, "nvrambank" );
membank("nvrambank")->set_base(m_banked_nvram);
membank("nvrambank")->set_base(m_banked_nvram.get());
}
}
@ -413,8 +413,8 @@ ROM_END
DRIVER_INIT_MEMBER(pcat_nit_state,pcat_nit)
{
m_banked_nvram = auto_alloc_array(machine(), UINT8, 0x2000);
machine().device<nvram_device>("nvram")->set_base(m_banked_nvram, 0x2000);
m_banked_nvram = std::make_unique<UINT8[]>(0x2000);
machine().device<nvram_device>("nvram")->set_base(m_banked_nvram.get(), 0x2000);
}
GAME( 1993, streetg, 0, pcat_nit, pcat_nit, pcat_nit_state, pcat_nit, ROT0, "New Image Technologies", "Street Games (Revision 4)", MACHINE_NOT_WORKING|MACHINE_NO_SOUND )

View File

@ -302,7 +302,7 @@ public:
DECLARE_WRITE32_MEMBER(cmd_callback);
std::unique_ptr<UINT8[]> m_texture;
rollext_renderer* m_renderer;
std::unique_ptr<rollext_renderer> m_renderer;
INTERRUPT_GEN_MEMBER(vblank_interrupt);
DECLARE_DRIVER_INIT(rollext);
@ -339,7 +339,7 @@ void rollext_state::video_start()
preprocess_texture_data();
m_renderer = auto_alloc(machine(), rollext_renderer(*m_screen));
m_renderer = std::make_unique<rollext_renderer>(*m_screen);
m_renderer->set_texture_ram(m_texture.get());
m_renderer->set_palette_ram((UINT16*)&m_palette_ram[0]);
}

View File

@ -119,7 +119,7 @@ public:
UINT8 m_dsw_select;
UINT8 m_rombank;
int m_palette_base;
UINT8 *m_janptr96_nvram;
std::unique_ptr<UINT8[]> m_janptr96_nvram;
UINT8 m_suzume_bank;
UINT8 m_gfx_adr_l;
UINT8 m_gfx_adr_m;
@ -883,7 +883,7 @@ WRITE8_MEMBER(royalmah_state::janptr96_rombank_w)
WRITE8_MEMBER(royalmah_state::janptr96_rambank_w)
{
membank("bank2")->set_base(m_janptr96_nvram + 0x1000 + 0x1000 * data);
membank("bank2")->set_base(m_janptr96_nvram.get() + 0x1000 + 0x1000 * data);
}
READ8_MEMBER(royalmah_state::janptr96_unknown_r)
@ -4901,9 +4901,9 @@ DRIVER_INIT_MEMBER(royalmah_state,ippatsu)
DRIVER_INIT_MEMBER(royalmah_state,janptr96)
{
m_janptr96_nvram = auto_alloc_array(machine(), UINT8, 0x1000 * 9);
membank("bank3")->set_base(m_janptr96_nvram);
machine().device<nvram_device>("nvram")->set_base(m_janptr96_nvram, 0x1000 * 9);
m_janptr96_nvram = std::make_unique<UINT8[]>(0x1000 * 9);
membank("bank3")->set_base(m_janptr96_nvram.get());
machine().device<nvram_device>("nvram")->set_base(m_janptr96_nvram.get(), 0x1000 * 9);
}
GAME( 1981, royalmj, 0, royalmah, royalmah, driver_device, 0, ROT0, "Nichibutsu", "Royal Mahjong (Japan, v1.13)", 0 )

View File

@ -145,8 +145,8 @@ public:
UINT16 m_dsp_ram[0x1000];
UINT16 m_io_share_ram[0x2000];
UINT32 *m_screen_ram;
UINT32 *m_pal_ram;
std::unique_ptr<UINT32[]> m_screen_ram;
std::unique_ptr<UINT32[]> m_pal_ram;
UINT32 m_video_address;
@ -183,15 +183,15 @@ void taitopjc_state::video_exit()
void taitopjc_state::video_start()
{
m_screen_ram = auto_alloc_array(machine(), UINT32, 0x40000);
m_pal_ram = auto_alloc_array(machine(), UINT32, 0x8000);
m_screen_ram = std::make_unique<UINT32[]>(0x40000);
m_pal_ram = std::make_unique<UINT32[]>(0x8000);
machine().add_notifier(MACHINE_NOTIFY_EXIT, machine_notify_delegate(FUNC(taitopjc_state::video_exit), this));
}
UINT32 taitopjc_state::screen_update_taitopjc(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
{
UINT8 *s = (UINT8*)m_screen_ram;
UINT8 *s = (UINT8*)m_screen_ram.get();
int x,y,t,u;
bitmap.fill(0x000000, cliprect);

View File

@ -593,7 +593,7 @@ public:
UINT32 m_displist_addr;
int m_count;
taitotz_renderer *m_renderer;
std::unique_ptr<taitotz_renderer> m_renderer;
DECLARE_DRIVER_INIT(batlgr2a);
DECLARE_DRIVER_INIT(batlgr2);
DECLARE_DRIVER_INIT(pwrshovl);
@ -747,7 +747,7 @@ void taitotz_state::video_start()
m_texture_ram = std::make_unique<UINT32[]>(0x800000);
/* create renderer */
m_renderer = auto_alloc(machine(), taitotz_renderer(*this, width, height, m_texture_ram.get()));
m_renderer = std::make_unique<taitotz_renderer>(*this, width, height, m_texture_ram.get());
//machine().add_notifier(MACHINE_NOTIFY_EXIT, machine_notify_delegate(FUNC(taitotz_exit), &machine()));
}

View File

@ -177,7 +177,7 @@ public:
double m_joystick_x2_time;
double m_joystick_y2_time;
apple2_memmap_config m_mem_config;
apple2_meminfo *m_current_meminfo;
std::unique_ptr<apple2_meminfo[]> m_current_meminfo;
int m_fdc_diskreg;
const UINT8 *m_a2_videoram, *m_a2_videoaux, *m_textgfx_data;
UINT32 m_a2_videomask, m_textgfx_datalen;

View File

@ -96,12 +96,12 @@ public:
offs_t m_adsp_incs;
offs_t m_adsp_size;
dmadac_sound_device *m_dmadac[SOUND_CHANNELS];
rgb_t *m_palette;
std::unique_ptr<rgb_t[]> m_palette;
std::unique_ptr<UINT32[]> m_polydata_buffer;
UINT32 m_polydata_count;
int m_lastscan;
int m_video_changed;
gaelco3d_renderer *m_poly;
std::unique_ptr<gaelco3d_renderer> m_poly;
DECLARE_WRITE16_MEMBER(irq_ack_w);
DECLARE_WRITE32_MEMBER(irq_ack32_w);
DECLARE_WRITE16_MEMBER(sound_data_w);

View File

@ -81,7 +81,7 @@ public:
struct gs_tempsprite *m_spritelist;
struct gs_tempsprite *m_sprite_ptr_pre;
bitmap_ind16 m_tmpbitmaps;
galastrm_renderer *m_poly;
std::unique_ptr<galastrm_renderer> m_poly;
int m_rsxb;
int m_rsyb;

View File

@ -340,7 +340,7 @@ public:
DECLARE_CUSTOM_INPUT_MEMBER(acc_down_r);
DECLARE_CUSTOM_INPUT_MEMBER(brake_down_r);
hng64_poly_renderer* m_poly_renderer;
std::unique_ptr<hng64_poly_renderer> m_poly_renderer;
TIMER_CALLBACK_MEMBER(hng64_3dfifo_processed);

View File

@ -90,7 +90,7 @@ public:
UINT16 m_page_control;
UINT8 m_video_changed;
emu_timer *m_scanline_timer;
midvunit_renderer *m_poly;
std::unique_ptr<midvunit_renderer> m_poly;
DECLARE_WRITE32_MEMBER(midvunit_dma_queue_w);
DECLARE_READ32_MEMBER(midvunit_dma_queue_entries_r);
DECLARE_READ32_MEMBER(midvunit_dma_trigger_r);

View File

@ -82,7 +82,7 @@ public:
UINT8 *m_cvsd_protection_base;
UINT8 m_autoerase_enable;
UINT32 m_palette_mask;
pen_t * m_pen_map;
std::unique_ptr<pen_t[]> m_pen_map;
std::unique_ptr<UINT16[]> m_local_videoram;
UINT8 m_videobank_select;
UINT8 m_yawdim_dma;

View File

@ -78,7 +78,7 @@ public:
std::unique_ptr<UINT8[]> m_pointram;
int m_pointram_idx;
UINT16 m_pointram_control;
dsp_state *m_mpDspState;
std::unique_ptr<dsp_state> m_mpDspState;
int m_mbNeedsKickstart;
UINT32 m_pointrom_idx;
UINT8 m_mPointRomMSB;

View File

@ -293,7 +293,7 @@ public:
struct stv_vdp1_poly_scanline scanline[512];
};
struct stv_vdp1_poly_scanline_data* stv_vdp1_shading_data;
std::unique_ptr<struct stv_vdp1_poly_scanline_data> stv_vdp1_shading_data;
struct stv_vdp2_sprite_list
{

View File

@ -55,7 +55,7 @@ public:
optional_shared_ptr<UINT16> m_cchip2_ram; // for megablst only
/* video-related */
struct f2_tempsprite *m_spritelist;
std::unique_ptr<struct f2_tempsprite[]> m_spritelist;
int m_sprite_type;
UINT16 m_spritebank[8];

View File

@ -22,7 +22,7 @@ public:
UINT8 m_bg_hshift;
tilemap_t *m_bg_tilemap1;
tilemap_t *m_bg_tilemap2;
rgb_t *m_palette_ptr;
std::unique_ptr<rgb_t[]> m_palette_ptr;
DECLARE_WRITE8_MEMBER(tiamc1_control_w);
DECLARE_WRITE8_MEMBER(tiamc1_videoram_w);
DECLARE_WRITE8_MEMBER(tiamc1_bankswitch_w);

View File

@ -46,7 +46,7 @@ public:
UINT8 m_blitter_window_enable;
UINT8 m_cocktail;
UINT8 m_port_select;
rgb_t *m_palette_lookup;
std::unique_ptr<rgb_t[]> m_palette_lookup;
UINT8 m_blitterram[8];
UINT8 m_blitter_xor;
UINT8 m_blitter_remap_index;

View File

@ -310,7 +310,7 @@ public:
OHCIIsochronousTransferDescriptor isochronous_transfer_descriptor;
} ohcist;
UINT8 pic16lc_buffer[0xff];
nv2a_renderer *nvidia_nv2a;
std::unique_ptr<nv2a_renderer> nvidia_nv2a;
bool debug_irq_active;
int debug_irq_number;
required_device<cpu_device> m_maincpu;

View File

@ -72,7 +72,7 @@ void apple2_state::apple2_update_memory()
{
for (i = 0; m_mem_config.memmap[i].end; i++)
;
m_current_meminfo = auto_alloc_array(machine(), apple2_meminfo, i);
m_current_meminfo = std::make_unique<apple2_meminfo[]>(i);
full_update = 1;
}

View File

@ -172,7 +172,7 @@ UINT16 ns10_decrypter_device::decrypt(UINT16 cipherword)
void ns10_decrypter_device::device_start()
{
_active = false;
_reducer = auto_alloc(machine(), gf2_reducer());
_reducer = std::make_unique<gf2_reducer>();
}
void ns10_decrypter_device::init(int iv)

View File

@ -44,7 +44,7 @@ private:
bool _active;
const ns10_crypto_logic& _logic;
static const int initSbox[16];
const gf2_reducer *_reducer;
std::unique_ptr<const gf2_reducer>_reducer;
void device_start() override;
void init(int iv);

View File

@ -119,7 +119,7 @@ void nand_device::device_start()
m_accumulated_status = 0;
m_mp_opcode = 0;
m_mode_3065 = 0;
m_pagereg = auto_alloc_array(machine(), UINT8, m_page_total_size);
m_pagereg = std::make_unique<UINT8[]>(m_page_total_size);
#ifdef SMARTMEDIA_IMAGE_SAVE
m_image_format = 0;
@ -151,7 +151,7 @@ bool smartmedia_image_device::smartmedia_format_1()
m_num_pages = get_UINT32BE(custom_header.num_pages);
m_log2_pages_per_block = get_UINT32BE(custom_header.log2_pages_per_block);
m_data_ptr = auto_alloc_array(machine(), UINT8, m_page_total_size*m_num_pages);
m_data_uid_ptr = auto_alloc_array(machine(), UINT8, 256 + 16);
m_data_uid_ptr = std::make_unique<UINT8[]>(256 + 16);
m_mode = SM_M_INIT;
m_pointer_mode = SM_PM_A;
m_page_addr = 0;
@ -160,7 +160,7 @@ bool smartmedia_image_device::smartmedia_format_1()
if (!is_readonly())
m_status |= 0x80;
m_accumulated_status = 0;
m_pagereg = auto_alloc_array(machine(), UINT8, m_page_total_size);
m_pagereg = std::make_unique<UINT8[]>(m_page_total_size);
memset( m_id, 0, sizeof( m_id));
m_id_len = 0;
m_col_address_cycles = 1;
@ -178,7 +178,7 @@ bool smartmedia_image_device::smartmedia_format_1()
m_id_len = 3;
fread(m_id, m_id_len);
fread(&m_mp_opcode, 1);
fread(m_data_uid_ptr, 256 + 16);
fread(m_data_uid_ptr.get(), 256 + 16);
}
fread(m_data_ptr, m_page_total_size*m_num_pages);
@ -246,7 +246,7 @@ bool smartmedia_image_device::smartmedia_format_2()
}
m_data_ptr = auto_alloc_array(machine(), UINT8, m_page_total_size*m_num_pages);
m_data_uid_ptr = auto_alloc_array(machine(), UINT8, 256 + 16);
m_data_uid_ptr = std::make_unique<UINT8[]>(256 + 16);
m_mode = SM_M_INIT;
m_pointer_mode = SM_PM_A;
m_page_addr = 0;
@ -255,7 +255,7 @@ bool smartmedia_image_device::smartmedia_format_2()
if (!is_readonly())
m_status |= 0x80;
m_accumulated_status = 0;
m_pagereg = auto_alloc_array(machine(), UINT8, m_page_total_size);
m_pagereg = std::make_unique<UINT8[]>(m_page_total_size);
m_id_len = 3;
memcpy( m_id, custom_header.data1, m_id_len);
m_mp_opcode = 0;
@ -265,10 +265,10 @@ bool smartmedia_image_device::smartmedia_format_2()
for (i=0;i<8;i++)
{
memcpy( m_data_uid_ptr + i * 32, custom_header.data2, 16);
memcpy( m_data_uid_ptr.get() + i * 32, custom_header.data2, 16);
for (j=0;j<16;j++) m_data_uid_ptr[i*32+16+j] = custom_header.data2[j] ^ 0xFF;
}
memcpy( m_data_uid_ptr + 256, custom_header.data3, 16);
memcpy( m_data_uid_ptr.get() + 256, custom_header.data3, 16);
fread(m_data_ptr, m_page_total_size*m_num_pages);
@ -343,7 +343,7 @@ void smartmedia_image_device::call_unload()
m_byte_addr = 0;
m_status = 0xC0;
m_accumulated_status = 0;
m_pagereg = auto_alloc_array(machine(), UINT8, m_page_total_size);
m_pagereg = std::make_unique<UINT8[]>(m_page_total_size);
memset( m_id, 0, sizeof( m_id));
m_id_len = 0;
m_mp_opcode = 0;
@ -440,7 +440,7 @@ void nand_device::command_w(UINT8 data)
m_page_addr = 0;
m_addr_load_ptr = 0;
m_program_byte_count = 0;
memset(m_pagereg, 0xff, m_page_total_size);
memset(m_pagereg.get(), 0xff, m_page_total_size);
break;
case 0x10: // Page Program (2nd cycle)
case 0x15:

View File

@ -160,8 +160,8 @@ protected:
// 0 means no card loaded
int m_log2_pages_per_block; // log2 of number of pages per erase block (usually 4 or 5)
UINT8 *m_data_ptr; // FEEPROM data area
UINT8 *m_data_uid_ptr;
UINT8* m_data_ptr; // FEEPROM data area
std::unique_ptr<UINT8[]> m_data_uid_ptr;
sm_mode_t m_mode; // current operation mode
pointer_sm_mode_t m_pointer_mode; // pointer mode
@ -173,7 +173,7 @@ protected:
int m_status; // current status
int m_accumulated_status; // accumulated status
UINT8 *m_pagereg; // page register used by program command
std::unique_ptr<UINT8[]> m_pagereg; // page register used by program command
UINT8 m_id[5]; // chip ID
UINT8 m_mp_opcode; // multi-plane operation code

View File

@ -86,7 +86,7 @@ void dump_decrypted(running_machine& machine, UINT8* decrypt)
void subsino_decrypt(running_machine& machine, void (*bitswaps)(UINT8 *decrypt, int i), const UINT8 *xors, int size)
{
int i;
UINT8 *decrypt = auto_alloc_array(machine, UINT8, 0x10000);
std::unique_ptr<UINT8[]> decrypt = std::make_unique<UINT8[]>(0x10000);
UINT8* region = machine.root_device().memregion("maincpu")->base();
for (i=0;i<0x10000;i++)
@ -94,7 +94,7 @@ void subsino_decrypt(running_machine& machine, void (*bitswaps)(UINT8 *decrypt,
if (i<size)
{
decrypt[i] = region[i]^xors[i&7];
bitswaps(decrypt, i);
bitswaps(decrypt.get(), i);
}
else
{
@ -102,5 +102,5 @@ void subsino_decrypt(running_machine& machine, void (*bitswaps)(UINT8 *decrypt,
}
}
// dump_decrypted(machine, decrypt);
memcpy(region, decrypt, 0x10000);
memcpy(region, decrypt.get(), 0x10000);
}

View File

@ -1427,7 +1427,7 @@ ADDRESS_MAP_END
void xbox_base_state::machine_start()
{
nvidia_nv2a = auto_alloc(machine(), nv2a_renderer(machine()));
nvidia_nv2a = std::make_unique<nv2a_renderer>(machine());
memset(pic16lc_buffer, 0, sizeof(pic16lc_buffer));
pic16lc_buffer[0] = 'B';
pic16lc_buffer[4] = 0; // A/V connector, 2=vga

View File

@ -68,14 +68,14 @@ gaelco3d_renderer::gaelco3d_renderer(gaelco3d_state &state)
void gaelco3d_state::video_start()
{
m_poly = auto_alloc(machine(), gaelco3d_renderer(*this));
m_poly = std::make_unique<gaelco3d_renderer>(*this);
m_palette = auto_alloc_array(machine(), rgb_t, 32768);
m_palette = std::make_unique<rgb_t[]>(32768);
m_polydata_buffer = std::make_unique<UINT32[]>(MAX_POLYDATA);
/* save states */
save_pointer(NAME(m_palette), 32768);
save_pointer(NAME(m_palette.get()), 32768);
save_pointer(NAME(m_polydata_buffer.get()), MAX_POLYDATA);
save_item(NAME(m_polydata_count));
save_item(NAME(m_lastscan));
@ -208,7 +208,7 @@ void gaelco3d_renderer::render_noz_noperspective(INT32 scanline, const extent_t
float voz_step = object.voz_dx * zbase;
int zbufval = (int)(-object.z0 * zbase);
offs_t endmask = m_texture_size - 1;
const rgb_t *palsource = m_state.m_palette + object.color;
const rgb_t *palsource = m_state.m_palette.get() + object.color;
UINT32 tex = object.tex;
UINT16 *dest = &m_screenbits.pix16(scanline);
UINT16 *zbuf = &m_zbuffer.pix16(scanline);
@ -246,7 +246,7 @@ void gaelco3d_renderer::render_normal(INT32 scanline, const extent_t &extent, co
float uoz_dx = object.uoz_dx;
float voz_dx = object.voz_dx;
offs_t endmask = m_texture_size - 1;
const rgb_t *palsource = m_state.m_palette + object.color;
const rgb_t *palsource = m_state.m_palette.get() + object.color;
UINT32 tex = object.tex;
float z0 = object.z0;
UINT16 *dest = &m_screenbits.pix16(scanline);
@ -296,7 +296,7 @@ void gaelco3d_renderer::render_alphablend(INT32 scanline, const extent_t &extent
float uoz_dx = object.uoz_dx;
float voz_dx = object.voz_dx;
offs_t endmask = m_texture_size - 1;
const rgb_t *palsource = m_state.m_palette + object.color;
const rgb_t *palsource = m_state.m_palette.get() + object.color;
UINT32 tex = object.tex;
float z0 = object.z0;
UINT16 *dest = &m_screenbits.pix16(scanline);

View File

@ -21,7 +21,7 @@ void galastrm_state::video_start()
{
m_spritelist = auto_alloc_array(machine(), struct gs_tempsprite, 0x4000);
m_poly = auto_alloc(machine(), galastrm_renderer(*this));
m_poly = std::make_unique<galastrm_renderer>(*this);
m_screen->register_screen_bitmap(m_tmpbitmaps);
m_screen->register_screen_bitmap(m_poly->screenbits());

View File

@ -1285,7 +1285,7 @@ void hng64_state::video_start()
m_additive_tilemap_debug = 0;
// Rasterizer creation
m_poly_renderer = auto_alloc(machine(), hng64_poly_renderer(*this));
m_poly_renderer = std::make_unique<hng64_poly_renderer>(*this);
// 3d information
m_dl = std::make_unique<UINT16[]>(0x100);

View File

@ -70,7 +70,7 @@ void kaneko16_sprite_device::static_set_gfxdecode_tag(device_t &device, const ch
void kaneko16_sprite_device::device_start()
{
m_first_sprite = auto_alloc_array(machine(), struct kan_tempsprite, 0x400);
m_first_sprite = std::make_unique<struct kan_tempsprite[]>(0x400);
m_sprites_regs = make_unique_clear<UINT16[]>(0x20/2);
m_screen->register_screen_bitmap(m_sprites_bitmap);
@ -358,7 +358,7 @@ void kaneko16_sprite_device::kaneko16_draw_sprites(_BitmapClass &bitmap, const r
int max = (m_screen->width() > 0x100) ? (0x200<<6) : (0x100<<6);
int i = 0;
struct kan_tempsprite *s = m_first_sprite;
struct kan_tempsprite *s = m_first_sprite.get();
/* These values are latched from the last sprite. */
int x = 0;
@ -451,7 +451,7 @@ void kaneko16_sprite_device::kaneko16_draw_sprites(_BitmapClass &bitmap, const r
/* Let's finally draw the sprites we buffered, in reverse order
(for pdrawgfx) */
for (s--; s >= m_first_sprite; s--)
for (s--; s >= m_first_sprite.get(); s--)
{
int curr_pri = s->priority;

View File

@ -81,7 +81,7 @@ private:
UINT16 m_sprite_flipy;
std::unique_ptr<UINT16[]> m_sprites_regs;
struct kan_tempsprite *m_first_sprite;
std::unique_ptr<struct kan_tempsprite[]> m_first_sprite;
int m_keep_sprites;
bitmap_ind16 m_sprites_bitmap;

View File

@ -70,7 +70,7 @@ void midvunit_state::video_start()
{
m_scanline_timer = timer_alloc(TIMER_SCANLINE);
m_poly = auto_alloc(machine(), midvunit_renderer(*this));
m_poly = std::make_unique<midvunit_renderer>(*this);
save_item(NAME(m_video_regs));
save_item(NAME(m_dma_data));

View File

@ -44,7 +44,7 @@ VIDEO_START_MEMBER(midyunit_state,common)
/* allocate memory */
m_cmos_ram = std::make_unique<UINT16[]>((0x2000 * 4)/2);
m_local_videoram = make_unique_clear<UINT16[]>(0x80000/2);
m_pen_map = auto_alloc_array(machine(), pen_t, 65536);
m_pen_map = std::make_unique<pen_t[]>(65536);
machine().device<nvram_device>("nvram")->set_base(m_cmos_ram.get(), 0x2000 * 4);

View File

@ -27,11 +27,11 @@ neosprite_base_device::neosprite_base_device(const machine_config &mconfig, cons
void neosprite_base_device::device_start()
{
m_videoram = auto_alloc_array(machine(), UINT16, 0x8000 + 0x800);
m_videoram_drawsource = m_videoram;
m_videoram = std::make_unique<UINT16[]>(0x8000 + 0x800);
m_videoram_drawsource = m_videoram.get();
/* clear allocated memory */
memset(m_videoram, 0x00, (0x8000 + 0x800) * sizeof(UINT16));
memset(m_videoram.get(), 0x00, (0x8000 + 0x800) * sizeof(UINT16));
create_sprite_line_timer();
create_auto_animation_timer();
@ -48,7 +48,7 @@ void neosprite_base_device::device_start()
m_auto_animation_frame_counter = 0;
/* register for state saving */
save_pointer(NAME(m_videoram), 0x8000 + 0x800);
save_pointer(NAME(m_videoram.get()), 0x8000 + 0x800);
save_item(NAME(m_vram_offset));
save_item(NAME(m_vram_read_buffer));
save_item(NAME(m_vram_modulo));
@ -772,16 +772,16 @@ void neosprite_midas_device::device_start()
{
neosprite_base_device::device_start();
m_videoram_buffer = auto_alloc_array(machine(), UINT16, 0x8000 + 0x800);
m_videoram_drawsource = m_videoram_buffer;
m_videoram_buffer = std::make_unique<UINT16[]>(0x8000 + 0x800);
m_videoram_drawsource = m_videoram_buffer.get();
memset(m_videoram_buffer, 0x00, (0x8000 + 0x800) * sizeof(UINT16));
memset(m_videoram_buffer.get(), 0x00, (0x8000 + 0x800) * sizeof(UINT16));
}
void neosprite_midas_device::buffer_vram()
{
memcpy(m_videoram_buffer, m_videoram, (0x8000 + 0x800) * sizeof(UINT16));
memcpy(m_videoram_buffer.get(), m_videoram.get(), (0x8000 + 0x800) * sizeof(UINT16));
}
inline void neosprite_midas_device::draw_fixed_layer_2pixels(UINT32*&pixel_addr, int offset, UINT8* gfx_base, const pen_t* char_pens)

View File

@ -51,7 +51,7 @@ public:
void set_screen(screen_device* screen);
void set_pens(const pen_t* pens);
UINT16 *m_videoram;
std::unique_ptr<UINT16[]> m_videoram;
UINT16 *m_videoram_drawsource;
UINT16 m_vram_offset;
@ -133,7 +133,7 @@ public:
virtual void draw_pixel(int romaddr, UINT32* dst, const pen_t *line_pens) override;
UINT16* m_videoram_buffer;
std::unique_ptr<UINT16[]> m_videoram_buffer;
void buffer_vram();
virtual void draw_fixed_layer_2pixels(UINT32*&pixel_addr, int offset, UINT8* gfx_base, const pen_t* char_pens) override;
virtual void set_sprite_region(UINT8* region_sprites, UINT32 region_sprites_size) override;

View File

@ -224,8 +224,8 @@ void ppu2c0x_device::device_start()
/* allocate a screen bitmap, videomem and spriteram, a dirtychar array and the monochromatic colortable */
m_bitmap = std::make_unique<bitmap_ind16>(VISIBLE_SCREEN_WIDTH, VISIBLE_SCREEN_HEIGHT);
m_spriteram = make_unique_clear<UINT8[]>(SPRITERAM_SIZE);
m_colortable = auto_alloc_array(machine(), pen_t, ARRAY_LENGTH(default_colortable));
m_colortable_mono = auto_alloc_array(machine(), pen_t, ARRAY_LENGTH(default_colortable_mono));
m_colortable = std::make_unique<pen_t[]>(ARRAY_LENGTH(default_colortable));
m_colortable_mono = std::make_unique<pen_t[]>(ARRAY_LENGTH(default_colortable_mono));
/* initialize the color tables */
for (int i = 0; i < ARRAY_LENGTH(default_colortable_mono); i++)
@ -257,8 +257,8 @@ void ppu2c0x_device::device_start()
save_item(NAME(m_draw_phase));
save_item(NAME(m_tilecount));
save_pointer(NAME(m_spriteram.get()), SPRITERAM_SIZE);
save_pointer(NAME(m_colortable), ARRAY_LENGTH(default_colortable));
save_pointer(NAME(m_colortable_mono), ARRAY_LENGTH(default_colortable_mono));
save_pointer(NAME(m_colortable.get()), ARRAY_LENGTH(default_colortable));
save_pointer(NAME(m_colortable_mono.get()), ARRAY_LENGTH(default_colortable_mono));
save_item(NAME(*m_bitmap));
}
@ -571,12 +571,12 @@ void ppu2c0x_device::draw_background( UINT8 *line_priority )
if (m_regs[PPU_CONTROL1] & PPU_CONTROL1_DISPLAY_MONO)
{
color_mask = 0xf0;
color_table = m_colortable_mono;
color_table = m_colortable_mono.get();
}
else
{
color_mask = 0xff;
color_table = m_colortable;
color_table = m_colortable.get();
}
/* cache the background pen */

View File

@ -190,8 +190,8 @@ public:
std::unique_ptr<bitmap_ind16> m_bitmap; /* target bitmap */
std::unique_ptr<UINT8[]> m_spriteram; /* sprite ram */
pen_t *m_colortable; /* color table modified at run time */
pen_t *m_colortable_mono; /* monochromatic color table modified at run time */
std::unique_ptr<pen_t[]> m_colortable; /* color table modified at run time */
std::unique_ptr<pen_t[]> m_colortable_mono; /* monochromatic color table modified at run time */
int m_scanline; /* scanline count */
ppu2c0x_scanline_delegate m_scanline_callback_proc; /* optional scanline callback */
ppu2c0x_hblank_delegate m_hblank_callback_proc; /* optional hblank callback */

View File

@ -36,7 +36,7 @@ void taitof2_state::taitof2_core_vh_start (int sprite_type, int hide, int flip_h
m_spriteram_delayed = make_unique_clear<UINT16[]>(m_spriteram.bytes() / 2);
m_spriteram_buffered = make_unique_clear<UINT16[]>(m_spriteram.bytes() / 2);
m_spritelist = auto_alloc_array_clear(machine(), struct f2_tempsprite, 0x400);
m_spritelist = make_unique_clear<struct f2_tempsprite[]>(0x400);
for (i = 0; i < 8; i ++)
{
@ -487,7 +487,7 @@ void taitof2_state::draw_sprites( screen_device &screen, bitmap_ind16 &bitmap, c
/* pdrawgfx() needs us to draw sprites front to back, so we have to build a list
while processing sprite ram and then draw them all at the end */
struct f2_tempsprite *sprite_ptr = m_spritelist;
struct f2_tempsprite *sprite_ptr = m_spritelist.get();
/* must remember enable status from last frame because driftout fails to
reactivate them from a certain point onwards. */
@ -775,7 +775,7 @@ void taitof2_state::draw_sprites( screen_device &screen, bitmap_ind16 &bitmap, c
/* this happens only if primsks != NULL */
while (sprite_ptr != m_spritelist)
while (sprite_ptr != m_spritelist.get())
{
sprite_ptr--;

View File

@ -416,7 +416,7 @@ void tc0780fpa_device::device_start()
m_texture = std::make_unique<UINT8[]>(0x400000);
m_poly_fifo = std::make_unique<UINT16[]>(POLY_FIFO_SIZE);
m_renderer = auto_alloc(machine(), tc0780fpa_renderer(*this, *m_screen, m_texture.get()));
m_renderer = std::make_unique<tc0780fpa_renderer>(*this, *m_screen, m_texture.get());
save_pointer(NAME(m_texture.get()), 0x400000);
save_pointer(NAME(m_poly_fifo.get()), POLY_FIFO_SIZE);

View File

@ -69,7 +69,7 @@ private:
std::unique_ptr<UINT16[]> m_poly_fifo;
int m_poly_fifo_ptr;
tc0780fpa_renderer *m_renderer;
std::unique_ptr<tc0780fpa_renderer> m_renderer;
UINT16 m_tex_address;
UINT16 m_tex_offset;

View File

@ -95,7 +95,7 @@ PALETTE_INIT_MEMBER(tiamc1_state, tiamc1)
int r, g, b, ir, ig, ib;
float tcol;
m_palette_ptr = auto_alloc_array(machine(), rgb_t, 256);
m_palette_ptr = std::make_unique<rgb_t[]>(256);
for (col = 0; col < 256; col++) {
ir = (col >> 3) & 7;

View File

@ -276,7 +276,7 @@ void williams_state::create_palette_lookup()
2, resistances_b, weights_b, 0, 0);
/* build a palette lookup */
m_palette_lookup = auto_alloc_array(machine(), rgb_t, 256);
m_palette_lookup = std::make_unique<rgb_t[]>(256);
for (i = 0; i < 256; i++)
{
int r = combine_3_weights(weights_r, BIT(i,0), BIT(i,1), BIT(i,2));