Previous 199869 Revisions Next

r18455 Thursday 11th October, 2012 at 16:46:04 UTC by Curt Coder
pla.c: Fixed MOS8721. (nw)
[src/emu/machine]pla.c

trunk/src/emu/machine/pla.c
r18454r18455
3030
3131inline void pla_device::parse_fusemap()
3232{
33   memory_region *region = machine().root_device().memregion(tag());
3334   jed_data jed;
34   jedbin_parse(machine().root_device().memregion(tag())->base(), machine().root_device().memregion(tag())->bytes(), &jed);
35   
36   jedbin_parse(region->base(), region->bytes(), &jed);
37
38   //logerror("PLA '%s' %u fuses\n", tag(), jed.numfuses);
39
3540   UINT32 fusenum = 0;
3641   m_xor = 0;
3742
r18454r18455
5156      {
5257         m_or[term] |= !jed_get_fuse(&jed, fusenum++) << f;
5358      }
59
60      //logerror("PLA '%s' %3u COMP %08x TRUE %08x OR %08x\n", tag(), term, m_and_comp[term], m_and_true[term], m_or[term]);
5461   }
5562
5663   for (int f = 0; f < m_outputs; f++)
5764   {
5865      m_xor |= jed_get_fuse(&jed, fusenum++) << f;
5966   }
67
68   //logerror("PLA '%s' XOR %08x\n", tag(), m_xor);
6069}
6170
6271
r18454r18455
6675
6776inline bool pla_device::get_product(int term)
6877{
78   UINT32 input_comp = m_and_comp[term] | ~m_i;
6979   UINT32 input_true = m_and_true[term] | m_i;
70   UINT32 input_comp = m_and_comp[term] | ~m_i;
7180
72   return ((input_true & input_comp) & m_output_mask) == m_output_mask;
81   //logerror("PLA '%s' %3u COMP %08x TRUE %08x OR %08x : %u\n", tag(), term, ~input_comp & m_output_mask, ~input_true & m_output_mask, m_or[term], (((input_comp & input_true) & m_output_mask) == m_output_mask));
82
83   return ((input_comp & input_true) & m_output_mask) == m_output_mask;
7384}
7485
7586
r18454r18455
115126}
116127
117128mos8721_device::mos8721_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock)
118    : pla_device(mconfig, MOS8721, "MOS8721", tag, owner, clock, 27, 18, 48, 0x7ffffff)
129    : pla_device(mconfig, MOS8721, "MOS8721", tag, owner, clock, 27, 18, 379, 0x7ffffff) // TODO actual number of terms is unknown
119130{
120131}
121132

Previous 199869 Revisions Next


© 1997-2024 The MAME Team