JP2021060969A - トレースデータの取扱い - Google Patents
トレースデータの取扱い Download PDFInfo
- Publication number
- JP2021060969A JP2021060969A JP2020116776A JP2020116776A JP2021060969A JP 2021060969 A JP2021060969 A JP 2021060969A JP 2020116776 A JP2020116776 A JP 2020116776A JP 2020116776 A JP2020116776 A JP 2020116776A JP 2021060969 A JP2021060969 A JP 2021060969A
- Authority
- JP
- Japan
- Prior art keywords
- location
- program
- flow
- jump
- processor
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000012550 audit Methods 0.000 claims description 100
- 238000000034 method Methods 0.000 claims description 11
- 230000004044 response Effects 0.000 claims description 5
- 238000012544 monitoring process Methods 0.000 abstract 1
- 230000006870 function Effects 0.000 description 9
- 230000006399 behavior Effects 0.000 description 7
- 230000007246 mechanism Effects 0.000 description 7
- 238000001914 filtration Methods 0.000 description 5
- 238000013459 approach Methods 0.000 description 3
- 230000008859 change Effects 0.000 description 3
- 230000001960 triggered effect Effects 0.000 description 3
- 238000012545 processing Methods 0.000 description 2
- 206010000117 Abnormal behaviour Diseases 0.000 description 1
- 230000001174 ascending effect Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 238000010304 firing Methods 0.000 description 1
- 230000009191 jumping Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3466—Performance evaluation by tracing or monitoring
- G06F11/3495—Performance evaluation by tracing or monitoring for systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3466—Performance evaluation by tracing or monitoring
- G06F11/3471—Address tracing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0706—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
- G06F11/0721—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment within a central processing unit [CPU]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0766—Error or fault reporting or storing
- G06F11/0781—Error filtering or prioritizing based on a policy defined by the user or on a policy defined by a hardware/software module, e.g. according to a severity level
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3065—Monitoring arrangements determined by the means or processing involved in reporting the monitored data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3466—Performance evaluation by tracing or monitoring
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/362—Software debugging
- G06F11/3636—Software debugging by tracing the execution of the program
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/52—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3802—Instruction prefetching
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2201/00—Indexing scheme relating to error detection, to error correction, and to monitoring
- G06F2201/865—Monitoring of software
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- Computing Systems (AREA)
- Computer Security & Cryptography (AREA)
- Mathematical Physics (AREA)
- Debugging And Monitoring (AREA)
Abstract
Description
i)プロセッサが命令を要求するメモリ2内のロケーション。これらのロケーションからのデータに対する要求は、前記プロセッサからメモリへとバス5上を通過する際に、監査ユニットによって観察されてもよい。
ii)メモリからバス5を介してプロセッサへと通過する命令の内容。監査ユニットは、プログラムのフローは、通常、1つの命令から次の命令へとメモリ内の順序で進むと仮定してもよいが、このメモリからプロセッサへと送られるジャンプ命令を観察したときには、ジャンプ命令で特定されたロケーションまでプログラムのフローがジャンプすると推定してもよく、監査ユニットがリターン命令を観察したときには、当該サブルーチンへのジャンプが生じたロケーションの直ぐ後のロケーションまでプログラムのフローがジャンプすると推定してもよい。
iii)プロセッサが命令を実行したとき、プロセッサは監査ユニットに直接報告することができる。この報告は、命令が下げられた(retired)とき(つまり、遂行されたとき)に行ってもよい。
1.監査ユニットは、ポインタ82を確認することにより、ビン81,82が既に他のアドレスビンに使用されているかどうか確認する。考え得る状況としては以下の通りである。
可能性i)ポインタ82が空である(例えば、−1を示している)。これは、ビン81,82が使用中ではないということを示す。この場合、監査ユニットは、前回のジャンプに対するリターンアドレスの表示を保存しているアドレスビン80を特定するようにポインタ82の設定を行い、現在のジャンプはそのリターンアドレスを有するジャンプの1回目の繰り返しであることを示すためにカウンタ81を1に設定する。
可能性ii)ポインタ82が、前回のジャンプに対するリターンアドレスの表示を保存しているアドレスビン80を特定しており、当該アドレスビンが、現在使用されている最も上位のビンである。この場合、監査ユニットは、そのリターンアドレスを有する追加のジャンプが行われたことを示すためにカウンタ81をインクリメントする。カウンタが最大である場合、監査ユニットは下記の可能性iii)のように動作を続ける。
可能性iii)ポインタ82が、前回のジャンプに対するリターンアドレスとは異なるリターンアドレスを保存しているアドレスビンを特定しているか、または、そのアドレスビンが現在使用されている最も上位のビンではないか、または、上記ii)のようにカウンタが最大ではない。この場合、監査ユニットは、次の利用可能なビンのリターンアドレスの表示を保存するか、または、利用可能なビンがない場合には、前段落に記載される手順を用いてもよい。
1.カウンタが最大である場合につき上述したように、更なるアドレスビンが利用可能である場合、そのビンに、前のビンと同一のリターンアドレス識別子を入力することができる。これらのビンの両方とカウンタを関連付けることができる場合、これらのカウンタは、効率的に相加的に使用されている。
2.上記の状況が生じた場合、つまり、2つの連続するアドレスビンが同一のリターンアドレスを特定する場合、これらのビンと関連付けられたカウンタは、両カウンタからのビットを用いる1つのカウンタとして扱うことができる。1つのカウンタが、全体的なカウンタ合計におけるより上位のビットを表し、1つのカウンタが、カウンタ合計におけるより下位のビットを表すことができる。組み合わされた1つのカウンタは適宜インクリメントおよびデクリメントすることができる。両カウンタに用いられるポインタは、同一のアドレスビンを参照することができ、または同一のリターンアドレス識別子を含む2つの連続するアドレスビンを参照することができる。1つのカウンタに保持できる数量までカウンタがデクリメントされたとき、これらのビンのうちの上位のビンを空にして、そのカウンタを開放することができる。
Claims (13)
- プロセッサによって実行されるプログラムのフローを監視するプロセッサ監査ユニットであって、前記監査ユニットは、前記プログラムのフローにおけるジャンプの後に前記プログラムのフローがリターンすると予想されるロケーションを表す1セットの値を保存するように適合されており、
前記ユニットは、
第1モードにおいて、前記プログラムのフローにおけるジャンプを検出したとき、前記プログラムのフローが前記ジャンプからリターンすると予想されるロケーションを表すロケーション値を保存することができ、
第2モードにおいて、前記プログラムのフローにおけるジャンプを検出したとき、前記プログラムのフローが前記ジャンプからリターンすると予想されるロケーションを表すロケーション値と関連付けられたカウンタをインクリメントできる、
プロセッサ監査ユニット。 - 前記ユニットは、前記第1モードにおいて動作することにより、所定の数以下の数のロケーション値を同時に保存するように構成されている、請求項1に記載のプロセッサ監査ユニット。
- 前記ユニットは、前記プログラムのフローにおいて、前記第1モードの動作によってロケーション値が保存されたジャンプまたは前記第2モードの動作によってカウンタがインクリメントされたジャンプに対応するリターンを検出したとき、
(i)前記プログラムのフローがリターンした実際のロケーションと、(ii)前記ロケーション値のそれぞれによって示されるとおり、プログラムのフローがリターンすると予想されていたロケーションとを比較し、
これらのロケーションが一致しないという判断に応答して、前記実際のリターンロケーションの表示のログを取るように、または、離れた場所にいる使用者に前記実際のリターンロケーションを報告するように構成されている、
請求項1または2に記載のプロセッサ監査ユニット。 - 前記ユニットは、順序付きのロケーション値のセットを保存するように構成されている、請求項1から3のいずれか一項に記載のプロセッサ監査ユニット。
- 前記ユニットは、前記プログラムのフローにおいて、前記プログラムのフローが第1のロケーションにリターンすると予想されている第1のジャンプを検出したとき、最後に保存されたロケーション値が前記第1のロケーションを示している場合、前記第1モードで動作し、それ以外の場合、前記最後に保存されたロケーションと関連付けられたカウンタが最大でないときは、第2モードで動作して前記カウンタをインクリメントするように構成されている、請求項4に記載のプロセッサ監査ユニット。
- 前記第1のジャンプは回帰ジャンプである、請求項5に記載のプロセッサ監査ユニット。
- 前記監査ユニットは、各ロケーション値をそれぞれ保存する複数のストアと、ポインタとにアクセス可能であり、前記監査ユニットは、前記ポインタに前記ロケーション値のうちの1つを指定させることによって、カウンタと当該ロケーション値を関連付けるように構成されている、請求項1から6のいずれか一項に記載のプロセッサ監査ユニット。
- 前記監査ユニットは、各ロケーション値をそれぞれ保存する複数のストアと、前記ストアよりも少ない数の複数のカウンタと、各カウンタにつき1つ設けられた複数のポインタとにアクセス可能であり、前記監査ユニットは、カウンタに対応するポインタに前記ロケーション値のうちの1つを指定させることによって、前記カウンタと当該ロケーション値を関連付けるように構成されている、請求項7に記載のプロセッサ監査ユニット。
- 前記監査ユニットは、2つの連続するストアが同一のロケーション値を保存しているとき、これらのロケーション値と関連付けられたカウンタを、ビット単位で組み合わされた1つのカウンタとして扱うように構成されている、請求項2に従属する請求項8に記載のプロセッサ監査ユニット。
- 前記監査ユニットは、各ロケーション値をそれぞれ保存する複数のストアにアクセス可能であり、前記ストアのそれぞれと関連付けられたカウンタが設けられている、請求項1から7のいずれか一項に記載のプロセッサ監査ユニット。
- 前記監査ユニットは、2つの連続するストアが同一のロケーション値を保存しているとき、これらのロケーション値と関連付けられたカウンタを、ビット単位で組み合わされた1つのカウンタとして扱うように構成されている、請求項2に従属する請求項10に記載プロセッサ監査ユニット。
- 前記ジャンプまたは前記ジャンプのそれぞれは、サブルーチンコールによるものである、請求項1から11のいずれか一項に記載のプロセッサ監査ユニット。
- プロセッサによって実行されるプログラムのフローを監視するプロセッサ監査ユニットを動作させる方法であって、前記監査ユニットは、前記プログラムのフローにおけるジャンプの後に前記プログラムのフローがリターンすると予想されるロケーションを表す1セットの値を保存するように適合されており、
前記方法は、
第1モードにおいて、前記プログラムのフローにおけるジャンプを検出したとき、前記プログラムのフローが前記ジャンプからリターンすると予想されるロケーションを表すロケーション値を保存するステップと、
第2モードにおいて、前記プログラムのフローにおけるジャンプを検出したとき、前記プログラムのフローが前記ジャンプからリターンすると予想されるロケーションを表すロケーション値と関連付けられたカウンタをインクリメントするステップと、
を含む、方法。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB1909933.2 | 2019-07-10 | ||
GB1909933.2A GB2586954B (en) | 2019-07-10 | 2019-07-10 | Handling trace data |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2021060969A true JP2021060969A (ja) | 2021-04-15 |
JP7374863B2 JP7374863B2 (ja) | 2023-11-07 |
Family
ID=67623293
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2020116776A Active JP7374863B2 (ja) | 2019-07-10 | 2020-07-07 | トレースデータの取扱い |
Country Status (5)
Country | Link |
---|---|
US (1) | US11989111B2 (ja) |
EP (1) | EP3764236A1 (ja) |
JP (1) | JP7374863B2 (ja) |
CN (1) | CN112214340A (ja) |
GB (1) | GB2586954B (ja) |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS62296232A (ja) * | 1986-06-17 | 1987-12-23 | Matsushita Electric Ind Co Ltd | 高速ル−プ回路 |
JPS63200234A (ja) * | 1987-02-17 | 1988-08-18 | Toshiba Corp | デ−タ処理装置 |
US6973563B1 (en) * | 2002-01-04 | 2005-12-06 | Advanced Micro Devices, Inc. | Microprocessor including return prediction unit configured to determine whether a stored return address corresponds to more than one call instruction |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5732272A (en) * | 1995-07-31 | 1998-03-24 | Apple Computer, Inc. | Subroutine execution time tracer |
US6223338B1 (en) * | 1998-09-30 | 2001-04-24 | International Business Machines Corporation | Method and system for software instruction level tracing in a data processing system |
CN100451914C (zh) * | 2001-08-29 | 2009-01-14 | 联发科技股份有限公司 | 锁相环迅速加电方法和装置 |
JP4327416B2 (ja) * | 2002-06-17 | 2009-09-09 | 三菱電機株式会社 | トレースデータ処理装置、トレースデータ処理方法およびその方法を実行するためのプログラム |
US7987453B2 (en) * | 2004-03-18 | 2011-07-26 | International Business Machines Corporation | Method and apparatus for determining computer program flows autonomically using hardware assisted thread stack tracking and cataloged symbolic data |
US8214819B2 (en) * | 2004-07-09 | 2012-07-03 | Hewlett-Packard Development Company, L.P. | Determining call counts in a program |
US20090222646A1 (en) * | 2008-02-28 | 2009-09-03 | International Business Machines Corporation | Method and apparatus for detecting processor behavior using instruction trace data |
US9058421B2 (en) * | 2009-06-16 | 2015-06-16 | Freescale Semiconductor, Inc. | Trace correlation for profiling subroutines |
US10042776B2 (en) * | 2012-11-20 | 2018-08-07 | Arm Limited | Prefetching based upon return addresses |
US9305651B1 (en) * | 2014-09-22 | 2016-04-05 | Sandisk Technologies Inc. | Efficient wide range bit counter |
US9858411B2 (en) * | 2014-12-19 | 2018-01-02 | Intel Corporation | Execution profiling mechanism |
US10970388B2 (en) * | 2017-06-28 | 2021-04-06 | Webroot Inc. | Discrete processor feature behavior collection |
US10331447B2 (en) * | 2017-08-30 | 2019-06-25 | Qualcomm Incorporated | Providing efficient recursion handling using compressed return address stacks (CRASs) in processor-based systems |
US11061807B2 (en) * | 2018-12-28 | 2021-07-13 | Intel Corporation | Trace management during aborted speculative operations |
-
2019
- 2019-07-10 GB GB1909933.2A patent/GB2586954B/en active Active
-
2020
- 2020-06-26 EP EP20182426.5A patent/EP3764236A1/en active Pending
- 2020-07-07 JP JP2020116776A patent/JP7374863B2/ja active Active
- 2020-07-09 CN CN202010657648.1A patent/CN112214340A/zh active Pending
- 2020-07-10 US US16/925,445 patent/US11989111B2/en active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS62296232A (ja) * | 1986-06-17 | 1987-12-23 | Matsushita Electric Ind Co Ltd | 高速ル−プ回路 |
JPS63200234A (ja) * | 1987-02-17 | 1988-08-18 | Toshiba Corp | デ−タ処理装置 |
US6973563B1 (en) * | 2002-01-04 | 2005-12-06 | Advanced Micro Devices, Inc. | Microprocessor including return prediction unit configured to determine whether a stored return address corresponds to more than one call instruction |
Non-Patent Citations (1)
Title |
---|
LIU, CHEN ET AL.: "Leveraging microarchitectural side channel information to efficiently enhance program control flow i", 2014 INTERNATIONAL CONFERENCE ON HARDWARE/SOFTWARE CODESIGN AND SYSTEM SYNTHESIS (CODES+ISSS), JPN6023006372, 12 October 2014 (2014-10-12), pages 1 - 9, XP032695354, ISSN: 0004995295, DOI: 10.1145/2656075.2656092 * |
Also Published As
Publication number | Publication date |
---|---|
GB201909933D0 (en) | 2019-08-21 |
GB2586954B (en) | 2023-06-14 |
US11989111B2 (en) | 2024-05-21 |
JP7374863B2 (ja) | 2023-11-07 |
CN112214340A (zh) | 2021-01-12 |
US20210011833A1 (en) | 2021-01-14 |
EP3764236A1 (en) | 2021-01-13 |
GB2586954A (en) | 2021-03-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8286139B2 (en) | Call stack sampling for threads having latencies exceeding a threshold | |
US8141053B2 (en) | Call stack sampling using a virtual machine | |
US8132170B2 (en) | Call stack sampling in a data processing system | |
EP2230602B1 (en) | Processing apparatus and method for acquiring log information | |
US6182243B1 (en) | Selective data capture for software exception conditions | |
US5537541A (en) | System independent interface for performance counters | |
US8949671B2 (en) | Fault detection, diagnosis, and prevention for complex computing systems | |
US8473789B2 (en) | Memory leak monitoring system and associated methods | |
US8566795B2 (en) | Selectively obtaining call stack information based on criteria | |
JP5520371B2 (ja) | 多重仮想マシンのためのサポートを有する、トレース・データの時間ベース・コンテキスト・サンプリング | |
US20100017583A1 (en) | Call Stack Sampling for a Multi-Processor System | |
US20180039560A1 (en) | Dynamically identifying performance anti-patterns | |
US20190102278A1 (en) | Memory leak profiling events | |
US7844971B2 (en) | Method and apparatus for detecting cross-thread stack access in multithreaded programs | |
US20100185895A1 (en) | Failure-specific data collection and recovery for enterprise storage controllers | |
US20120246518A1 (en) | Operating a computer system | |
CN114328102A (zh) | 设备状态监控方法、装置、设备及计算机可读存储介质 | |
US8296552B2 (en) | Dynamically migrating channels | |
US9009537B2 (en) | Diagnostic data capture in a computing environment | |
US9910758B2 (en) | Computer flight recorder with active error detection | |
US10452534B2 (en) | Asynchronous operation query | |
JP2021060969A (ja) | トレースデータの取扱い | |
JP2009217617A (ja) | メモリリーク箇所の特定方法及び装置 | |
US20170192878A1 (en) | Separating Test Coverage In Software Processes Using Shared Memory | |
WO2020177495A1 (zh) | 一种数据库连接管理方法及装置、设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20201109 |
|
RD03 | Notification of appointment of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7423 Effective date: 20201109 |
|
RD04 | Notification of resignation of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7424 Effective date: 20201116 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20210202 |
|
A711 | Notification of change in applicant |
Free format text: JAPANESE INTERMEDIATE CODE: A711 Effective date: 20210203 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20220316 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20230221 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20230519 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20230606 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20230904 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20230925 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20231025 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 7374863 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |