SU1670688A1 - Device for checking programs - Google Patents
Device for checking programs Download PDFInfo
- Publication number
- SU1670688A1 SU1670688A1 SU894696516A SU4696516A SU1670688A1 SU 1670688 A1 SU1670688 A1 SU 1670688A1 SU 894696516 A SU894696516 A SU 894696516A SU 4696516 A SU4696516 A SU 4696516A SU 1670688 A1 SU1670688 A1 SU 1670688A1
- Authority
- SU
- USSR - Soviet Union
- Prior art keywords
- input
- group
- output
- outputs
- inputs
- Prior art date
Links
Landscapes
- Debugging And Monitoring (AREA)
Abstract
Изобретение относитс к вычислительной технике и может быть использовано в средствах контрол времени выполнени программ. Целью изобретени вл етс увеличение глубины контрол хода выполнени программ путем учета времени выполнени циклических участков программ с фиксированным числом повторений циклов. Устройство содержит блок 1 пам ти, блок 2 регистров, группу 3 счетчиков, группу 4 триггеров, регистр 5 адреса, счетчик 6 адреса, мультиплексор 7, дешифратор 8, первую 9 и вторую 10 группу элементов И, группу 11 элементов ИЛИ, первый 12 и второй 13 элементы И, второй 14 и первый 15 элементы ИЛИ. Устройство позвол ет ускорить процедуру отладки программ за счет оперативного внесени коррекции в программу. 2 ил.The invention relates to computing and can be used in the means of monitoring the execution time of programs. The aim of the invention is to increase the depth of monitoring the progress of program execution by taking into account the execution time of cyclic program sections with a fixed number of loop repetitions. The device contains a block of 1 memory, a block of 2 registers, a group of 3 counters, a group of 4 flip-flops, a register of 5 addresses, a counter of 6 addresses, a multiplexer 7, a decoder 8, the first 9 and the second 10 groups of elements AND, a group of 11 elements OR, the first 12 and the second 13 elements are And, the second 14 and the first 15 elements are OR. The device allows you to speed up the debugging of programs by promptly making corrections to the program. 2 Il.
Description
Ю iQ4 00 00Yu iQ4 00 00
||
Изобретение относитс к вычислительной технике и может быть использовано в средствах контрол времени выполнени программы.The invention relates to computing and can be used in the means of controlling the time of program execution.
Известно устройство дл контрол и отладки программы, содержащее блок пам ти , регистр, счетчик, элементы И и ИЛИ.A device for monitoring and debugging a program is known, which contains a memory block, a register, a counter, AND and OR elements.
Известно также аналогичное устройство .A similar device is also known.
Общим недостатком этих устройств вл етс низка глубина контрол .A common drawback of these devices is the low depth of control.
Известно устройство с программируемым электрическим блоком и блоком контрол , содержащее счетчик адреса, элемент И, элемент ИЛИ. выход которого вл етс выходом сигнала ошибки устройства, а первый тактовый вход устройства соединен со счетным входом счетчика адреса.A device with a programmable electrical unit and a control unit is known that contains an address counter, an AND element, an OR element. the output of which is the output of the device error signal, and the first clock input of the device is connected to the counting input of the address counter.
Недостатком данного устройства вл етс низка глубина контрол хода выполнени программ вследствие того, что невозможно определить фиксированный участок программы, на котором нарушаетс алгоритм ее выполнени .The disadvantage of this device is the low depth of monitoring the progress of the programs due to the fact that it is impossible to determine a fixed portion of the program in which the algorithm for its execution is violated.
Цель изобретени - увеличение глубины контрол хода выполнени программ путем учета времени выполнени циклических участков программ с фиксированным числом повторений циклов.The purpose of the invention is to increase the depth of monitoring the progress of programs by taking into account the time of the execution of cyclic program sections with a fixed number of repetitions of cycles.
На фиг.1 представлена структурно-функциональна схема устройства; на фиг.2 - временна диаграмма работы устройства.Figure 1 shows the structural-functional diagram of the device; figure 2 - timing diagram of the device.
Устройство содержит блок 1 пам ти, блок 2 регистров, группу 3 счетчиков, группу 4 триггеров, регистр 5 адреса, счетчик 6 адреса, мультиплексор 7, дешифратор 8, первую 9 и вторую 10 группы элементов И, группу 11 элементов ИЛИ, первый 12 и второй 13 элементы И, второй 14 и первый 15 элементы ИЛИ, вход 16 адреса, второй тактовый вход 17, третий тактовый вход 18, вход 19 задани режима, первый тактовый вход 20, установочный вход 21, вход 22 задани кода переменных программ, вход 23 задани начального кода, вход 24 записи, выход 25 адреса, информационный выход 26 и выход 27 сигнала ошибки.The device contains a block of 1 memory, a block of 2 registers, a group of 3 counters, a group of 4 flip-flops, a register of 5 addresses, a counter of 6 addresses, a multiplexer 7, a decoder 8, the first 9 and the second 10 groups of elements And, a group of 11 elements OR, the first 12 and the second 13 elements are AND, the second 14 and the first 15 elements are OR, the input 16 of the address, the second clock input 17, the third clock input 18, the mode setting input 19, the first clock input 20, setup input 21, the input 22 of the program variable code, input 23 setting the start code, entry 24 of entry, exit 25 of address, information exit 26 and exit 27 of signal ala errors.
Устройство работает в двух режимах: в режиме начальной установки и режиме контрол хода выполнени программы.The device operates in two modes: in the initial installation mode and the program progress monitoring mode.
Перед началом работы устройства все элементы пам ти устанавливаютс в исходное (нулевое) состо ние (цепи установки в исходное на схеме не показаны).Before the operation of the device, all the memory elements are set to the initial (zero) state (the installation circuits to the initial one are not shown in the diagram).
Режим начальной установки.Initial installation mode.
На вход 23 устройства подаютс значени кодов начальной установки группы 3 счетчиков. По сигналу, поданному на вход 21, значени этих кодов записывают в блок 2 регистров и группу 3 счетчиков. Это необходимо дл того, чтобы в каждый из счетчиков записывать такую установку, чтобы оставша с емкость счетчика определ ла возможное число по влений соответствующей произвольной переменной в ходе выполнени программы.The input values of the device 23 are supplied to the codes of the initial installation of a group of 3 meters. According to the signal fed to the input 21, the values of these codes are written into a block of 2 registers and a group of 3 counters. This is necessary in order to record such an installation in each of the counters so that the remaining capacity of the counter determines the possible number of occurrences of the corresponding arbitrary variable during the execution of the program.
Необходимость хранени кодов начальной установки в блоке 2 регистров обусловлена следующим. В ходе выполнени The need to store the initial installation codes in block 2 of registers is due to the following. During the execution
0 программы люба из переменных может характеризовать обработку программой внутреннего цикла, в котором она должна быть обработана строго фиксированное число раз.0 programs, any of the variables can characterize the processing by the program of the inner loop, in which it must be processed a fixed number of times.
5При этом данный внутренний цикл быть использован произвольное число раз. Дл увеличени глубины диагностики - определени теста зацикливани и момента его поступлени , необходимо в мо0 мент окончани цикла соответствующий счетчик привести в исходное состо ние, т, е. записать в него код начальной установки.5At this, this inner loop can be used an arbitrary number of times. To increase the diagnostics depth — the definition of the loop test and the moment it arrives, it is necessary to reset the corresponding counter at the time of the end of the cycle, i.e., write the initial installation code into it.
По сигналу, поданному на вход 19, код адреса со счетчика 6 через мультиплексор 7The signal applied to the input 19, the address code from counter 6 through multiplexer 7
5 подают на вход адреса блока 1 пам ти.5 is fed to the input of the address of memory block 1.
По каждому из сформированных адресов , использу вход 22 устройства и вход 24 записи, производ т запись информации в блок 1 пам ти. В соответствии с адресомFor each of the generated addresses, using the input 22 of the device and the input 24 of the record, information is recorded in block 1 of the memory. According to the address
0 записываетс и код переменной. Если пере- .менна встречаетс в цикле последний раз, поле метки кода переменной дополн етс единицей, во всех остальных случа х - нулем ,0 is recorded and the variable code. If the variable is encountered in the loop for the last time, the label field of the variable code is complemented by one, in all other cases it is zero,
5После заполнени блока 1 пам ти на5After filling the memory block 1 on
вход 19 устройства подают управл ющий сигнал, обеспечивающий подачу адреса с выхода регистра 5 адреса через мультиплексор 7 на вход адреса блока 1 пам ти. Устрой0 ство готово к работе в режиме контрол хода выполнени программы.the input 19 of the device supplies a control signal providing the address from the output of the register 5 of the address through the multiplexer 7 to the input of the address of the block 1 of the memory. The device is ready to work in the mode of monitoring the progress of the program.
Режим контрол хода выполнени программы .The mode of monitoring the progress of the program.
С приходом первого тактового импульсаWith the arrival of the first clock pulse
5 на вход 17 устройства адрес обрабатываемой в данный момент программной переменной с входа 16 записываетс в регистр 5. Данный адрес через мультиплексор 7 поступает на вход адреса блока 1 пам ти, на5, at the device input 17, the address of the program variable currently being processed is input from register 16 to register 5. This address is fed through multiplexer 7 to the input address of memory block 1,
0 информационном выходе которого формируетс код переменной, а на выходе пол метки - -нулевой сигнал. В результате на выходе элемента ИЛИ 14 формируетс единичный сигнал, благодар которому на вы5 ходе элемента И 12 также формируетс единичный сигнал, вследствие которого на выходе элемента 12 также формируетс единичный сигнал, который поступает на вход грурпы 9 элементов И и готовит его к работе. Кроме того, код переменной с выхода блока0 the information output of which forms the variable code, and the output of the label field is a zero signal. As a result, a single signal is generated at the output of the OR 14 element, whereby a single signal is also generated at the output of the And 12 element, as a result of which a single signal is also generated at the output of the 12 element, which enters the input group 9 of the And elements and prepares it for operation. In addition, the variable code from the block output
Iпам ти поступает на информационный вход дешифратора. С приходом на вход 18 устройства тактового импульса на выходе дешифратора 8, соответствующем коду переменной , формируетс единичный сигнал, который через открытый элемент И группыIt goes to the information input of the decoder. With the arrival at the input 18 of the device of a clock pulse, at the output of the decoder 8, corresponding to the variable code, a single signal is generated, which through the open element AND of the group
9 элементов И поступает на соответствующий счетный вход счетчика группы 3 счетчиков .9 elements And goes to the corresponding counting input of the counter of the group of 3 meters.
Таким образом фиксируетс факт обра- ботки программной переменной. Устройство работает аналогично до тех пор, пока в одном из тактов на выходе т-го разр да блока 1 пам ти не по витс единичный сигнал (свидетельствующий о том, что число по влений переменной прин ло максимальное значение).Thus, the fact of processing a program variable is fixed. The device operates similarly until a single signal appears at one of the cycles at the output of the t-th bit of memory 1 (indicating that the number of occurrences of the variable has reached its maximum value).
В результате единичный сигнал формируетс на выходе элемента И 13. Данный сигнал обеспечивает прохождение инфор- мэции с соответствующего выхода дешифратора через группу 9 элементов И и группуAs a result, a single signal is formed at the output of element AND 13. This signal ensures the passage of information from the corresponding output of the decoder through a group of 9 elements AND and a group
I1элементов ИЛИ на вход управлени группы 3 счетчиков. Это приводит к тому, что в соответствующий счетчик группы 3 записы- ваетс из блока 2 регистров код начальной установки.I1 elements OR to the input of the control of a group of 3 meters. This leads to the fact that the initial setup code is written to the corresponding counter of group 3 from block 2 of registers.
Далее работа устройства аналогична описанному.Further, the operation of the device is similar to that described.
Если в один из счетчиков группы 3 запи- сываетс число больше допустимого (в ре- зультате заклинивани ), то сигналом переполнени данного счетчика переводитс в единичное состо ние соответствующий ему триггер группы 4 триггеров. Кроме того, сигнал переполнени черезэлемент ИЛИ 15 поступает на выход 27 устройства и обеспечивает прерывание выполнени программы , использу выходы 25 и 26 устройства, можно определить в каком месте програм- мы произошло зацикливание.If a number more than the allowed number is written to one of the counters of group 3 (as a result of jamming), then the overflow signal of this counter translates to the one state its corresponding trigger group of 4 flip-flops. In addition, the overflow signal through the OR element 15 is fed to the output 27 of the device and interrupts the execution of the program, using the outputs 25 and 26 of the device, it is possible to determine where in the program a loop has occurred.
Claims (1)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
SU894696516A SU1670688A1 (en) | 1989-04-18 | 1989-04-18 | Device for checking programs |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
SU894696516A SU1670688A1 (en) | 1989-04-18 | 1989-04-18 | Device for checking programs |
Publications (1)
Publication Number | Publication Date |
---|---|
SU1670688A1 true SU1670688A1 (en) | 1991-08-15 |
Family
ID=21450046
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
SU894696516A SU1670688A1 (en) | 1989-04-18 | 1989-04-18 | Device for checking programs |
Country Status (1)
Country | Link |
---|---|
SU (1) | SU1670688A1 (en) |
-
1989
- 1989-04-18 SU SU894696516A patent/SU1670688A1/en active
Non-Patent Citations (1)
Title |
---|
Авторское свидетельство СССР Ns 1056202. кл. G 06 F 11/00. 1983. Авторское свидетельство СССР Nf 1213480, кл. G06 F 11/00, 1986. За вка GB № 2065939, кл. G 06 F 11 /26, 1984. * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5745498A (en) | Rapid compare of two binary numbers | |
US4752928A (en) | Transaction analyzer | |
US4636967A (en) | Monitor circuit | |
SU1670688A1 (en) | Device for checking programs | |
RU2099777C1 (en) | Device which searches for alternating fails in microprocessor systems | |
SU741269A1 (en) | Microprogramme processor | |
SU443414A1 (en) | Device for controlling the operational information storage | |
RU2030784C1 (en) | Device for search for faults occurring intermittently in microprocessing systems | |
SU375777A1 (en) | CONVERTER "CODE - TIME INTERVAL" | |
SU473180A1 (en) | Device for testing comparison circuits | |
SU1001181A1 (en) | On-line storage monitoring device | |
SU1173414A1 (en) | Program control device | |
SU455244A2 (en) | Information processing device | |
SU857997A1 (en) | Device for testing computer input-output channel | |
SU1569904A1 (en) | Device for checking memory units | |
SU1280636A1 (en) | Device for debugging programs | |
SU1755284A1 (en) | Device for checking information | |
SU1513457A1 (en) | Program debugging device | |
SU1275452A1 (en) | Device for debugging programs | |
SU1608675A1 (en) | Device for monitoring running of programs in computer | |
SU754486A1 (en) | Read-only memory checking device | |
SU1128266A1 (en) | Device for collecting statistical data concerning operation of computer programs | |
SU797078A1 (en) | Pulse counting device | |
SU1683019A2 (en) | Program debugger | |
SU1091072A2 (en) | Device for measuring angular speed |