netlist: Macro-ized 74113 DIPs

This commit is contained in:
Aaron Giles 2020-08-02 12:41:12 +02:00 committed by couriersud
parent 8705fe505e
commit 2347096a88
6 changed files with 77 additions and 91 deletions

View File

@ -90,9 +90,7 @@ namespace devices
#endif
LIB_ENTRY(74107A)
LIB_ENTRY(74113)
LIB_ENTRY(74113_dip)
LIB_ENTRY(74113A)
LIB_ENTRY(74113A_dip)
LIB_ENTRY(74121)
LIB_ENTRY(74123)
LIB_ENTRY(74125)

View File

@ -91,72 +91,8 @@ namespace netlist
};
NETLIB_OBJECT(74113_dip)
{
NETLIB_CONSTRUCTOR(74113_dip)
, m_A(*this, "A")
, m_B(*this, "B")
{
register_subalias("1", m_A.m_CLK);
register_subalias("2", m_A.m_K);
register_subalias("3", m_A.m_J);
register_subalias("4", m_A.m_SETQ);
register_subalias("5", m_A.m_Q);
register_subalias("6", m_A.m_QQ);
register_subalias("7", "A.GND");
register_subalias("8", m_B.m_QQ);
register_subalias("9", m_B.m_Q);
register_subalias("10", m_B.m_SETQ);
register_subalias("11", m_B.m_J);
register_subalias("12", m_B.m_K);
register_subalias("13", m_B.m_CLK);
register_subalias("14", "A.VCC");
connect("A.GND", "B.GND");
connect("A.VCC", "B.VCC");
}
private:
NETLIB_SUB(74113) m_A;
NETLIB_SUB(74113) m_B;
};
NETLIB_OBJECT(74113A_dip)
{
NETLIB_CONSTRUCTOR(74113A_dip)
, m_A(*this, "A")
, m_B(*this, "B")
{
register_subalias("1", m_A.m_CLK);
register_subalias("2", m_A.m_K);
register_subalias("3", m_A.m_J);
register_subalias("4", m_A.m_SETQ);
register_subalias("5", m_A.m_Q);
register_subalias("6", m_A.m_QQ);
register_subalias("7", "A.GND");
register_subalias("8", m_B.m_QQ);
register_subalias("9", m_B.m_Q);
register_subalias("10", m_B.m_SETQ);
register_subalias("11", m_B.m_J);
register_subalias("12", m_B.m_K);
register_subalias("13", m_B.m_CLK);
register_subalias("14", "A.VCC");
connect("A.GND", "B.GND");
connect("A.VCC", "B.VCC");
}
private:
NETLIB_SUB(74113A) m_A;
NETLIB_SUB(74113A) m_B;
};
NETLIB_DEVICE_IMPL(74113, "TTL_74113", "+CLK,+J,+K,+CLRQ,@VCC,@GND")
NETLIB_DEVICE_IMPL(74113A, "TTL_74113A", "+CLK,+J,+K,+CLRQ,@VCC,@GND")
NETLIB_DEVICE_IMPL(74113_dip, "TTL_74113_DIP", "")
NETLIB_DEVICE_IMPL(74113A_dip, "TTL_74113A_DIP", "")
} //namespace devices
} // namespace netlist

View File

@ -62,23 +62,12 @@
#include "netlist/nl_setup.h"
#define TTL_74113(name, cCLK, cJ, cK, cCLRQ) \
NET_REGISTER_DEV(TTL_74113, name) \
NET_CONNECT(name, GND, GND) \
NET_CONNECT(name, VCC, VCC) \
NET_CONNECT(name, CLK, cCLK) \
NET_CONNECT(name, J, cJ) \
NET_CONNECT(name, K, cK) \
NET_CONNECT(name, CLRQ, cCLRQ)
// usage: TTL_74113(name, cCLK, cJ, cK, cCLRQ)
#define TTL_74113(...) \
NET_REGISTER_DEVEXT(TTL_74113, __VA_ARGS__)
#define TTL_74113A(name, cCLK, cJ, cK, cCLRQ) \
TTL_74113(name, cCLK, cJ, cK, cCLRQ)
#define TTL_74113_DIP(name) \
NET_REGISTER_DEV(TTL_74113_DIP, name)
#define TTL_74113A_DIP(name) \
NET_REGISTER_DEV(TTL_74113A_DIP, name)
// usage: TTL_74113A(name, cCLK, cJ, cK, cCLRQ)
#define TTL_74113A(...) \
NET_REGISTER_DEVEXT(TTL_74113, __VA_ARGS__)
#endif /* NLD_74113_H_ */

View File

@ -357,19 +357,11 @@
#define TTL_74113(...) \
NET_REGISTER_DEVEXT(TTL_74113, __VA_ARGS__)
// usage : TTL_74113_DIP(name)
#define TTL_74113_DIP(...) \
NET_REGISTER_DEVEXT(TTL_74113_DIP, __VA_ARGS__)
// usage : TTL_74113A(name, pCLK, pJ, pK, pCLRQ)
// auto connect: VCC, GND
#define TTL_74113A(...) \
NET_REGISTER_DEVEXT(TTL_74113A, __VA_ARGS__)
// usage : TTL_74113A_DIP(name)
#define TTL_74113A_DIP(...) \
NET_REGISTER_DEVEXT(TTL_74113A_DIP, __VA_ARGS__)
// ---------------------------------------------------------------------
// Source: src/lib/netlist/devices/nld_74123.cpp
// ---------------------------------------------------------------------
@ -1011,6 +1003,14 @@
#define TTL_74107A_DIP(...) \
NET_REGISTER_DEVEXT(TTL_74107A_DIP, __VA_ARGS__)
// usage : TTL_74113_DIP(name)
#define TTL_74113_DIP(...) \
NET_REGISTER_DEVEXT(TTL_74113_DIP, __VA_ARGS__)
// usage : TTL_74113A_DIP(name)
#define TTL_74113A_DIP(...) \
NET_REGISTER_DEVEXT(TTL_74113A_DIP, __VA_ARGS__)
// usage : TTL_74155A_GATE(name)
#define TTL_74155A_GATE(...) \
NET_REGISTER_DEVEXT(TTL_74155A_GATE, __VA_ARGS__)

View File

@ -1150,6 +1150,61 @@ static NETLIST_START(TTL_74107A_DIP)
)
NETLIST_END()
/*
* nld_74113.h
*
* 74113: Dual Master-Slave J-K Flip-Flops with Set and Complementary Outputs
* 74113A: Dual Negative-Edge-Triggered Master-Slave J-K Flip-Flops with Set and Complementary Outputs
*
* +----------+
* 1CLK |1 ++ 14| VCC
* 1K |2 13| 2CLK
* 1J |3 12| 2K
* 1SETQ |4 74113 11| 2J
* 1Q |5 10| 2SETQ
* 1QQ |6 9| 2Q
* GND |7 8| 2QQ
* +----------+
*/
static NETLIST_START(TTL_74113_DIP)
TTL_74113(A)
TTL_74113(B)
NET_C(A.VCC, B.VCC)
NET_C(A.GND, B.GND)
DIPPINS( /* +----------+ */
A.CLK, /* 1CLK |1 ++ 14| VCC */ A.VCC,
A.K, /* 1K |2 13| 2CLK */ B.CLK,
A.J, /* 1J |3 12| 2K */ B.K,
A.SETQ, /* 1SETQ |4 74113 11| 2J */ B.J,
A.Q, /* 1Q |5 10| 2SETQ */ B.SETQ,
A.QQ, /* 1QQ |6 9| 2Q */ B.Q,
A.GND, /* GND |7 8| 2QQ */ B.QQ
/* +----------+ */
)
NETLIST_END()
static NETLIST_START(TTL_74113A_DIP)
TTL_74113A(A)
TTL_74113A(B)
NET_C(A.VCC, B.VCC)
NET_C(A.GND, B.GND)
DIPPINS( /* +----------+ */
A.CLK, /* 1CLK |1 ++ 14| VCC */ A.VCC,
A.K, /* 1K |2 13| 2CLK */ B.CLK,
A.J, /* 1J |3 12| 2K */ B.K,
A.SETQ, /* 1SETQ |4 74113 11| 2J */ B.J,
A.Q, /* 1Q |5 10| 2SETQ */ B.SETQ,
A.QQ, /* 1QQ |6 9| 2Q */ B.Q,
A.GND, /* GND |7 8| 2QQ */ B.QQ
/* +----------+ */
)
NETLIST_END()
//- Identifier: TTL_74121_DIP
//- Title: DM74121 One-Shot with Clear and Complementary Outputs
//- Description: The DM74121 is a monostable multivibrator featuring both
@ -2576,6 +2631,8 @@ NETLIST_START(TTL74XX_lib)
LOCAL_LIB_ENTRY(TTL_7497_DIP)
LOCAL_LIB_ENTRY(TTL_74107_DIP)
LOCAL_LIB_ENTRY(TTL_74107A_DIP)
LOCAL_LIB_ENTRY(TTL_74113_DIP)
LOCAL_LIB_ENTRY(TTL_74113A_DIP)
LOCAL_LIB_ENTRY(TTL_74121_DIP)
LOCAL_LIB_ENTRY(TTL_74123_DIP)
LOCAL_LIB_ENTRY(TTL_9602_DIP)

View File

@ -327,6 +327,12 @@
#define TTL_74107A_DIP(name) \
NET_REGISTER_DEV(TTL_74107A_DIP, name)
#define TTL_74113_DIP(name) \
NET_REGISTER_DEV(TTL_74113_DIP, name)
#define TTL_74113A_DIP(name) \
NET_REGISTER_DEV(TTL_74113A_DIP, name)
#define TTL_74121_DIP(name) \
NET_REGISTER_DEV(TTL_74121_DIP, name)