JPWO2018235149A1 - ストレージ装置及び記憶領域管理方法 - Google Patents
ストレージ装置及び記憶領域管理方法 Download PDFInfo
- Publication number
- JPWO2018235149A1 JPWO2018235149A1 JP2019524735A JP2019524735A JPWO2018235149A1 JP WO2018235149 A1 JPWO2018235149 A1 JP WO2018235149A1 JP 2019524735 A JP2019524735 A JP 2019524735A JP 2019524735 A JP2019524735 A JP 2019524735A JP WO2018235149 A1 JPWO2018235149 A1 JP WO2018235149A1
- Authority
- JP
- Japan
- Prior art keywords
- area
- real
- pool
- garbage
- size
- 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
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0662—Virtualisation aspects
- G06F3/0665—Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0661—Format or protocol conversion arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0253—Garbage collection, i.e. reclamation of unreferenced memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/04—Addressing variable-length words or parts of words
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/10—Address translation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0604—Improving or facilitating administration, e.g. storage management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0608—Saving storage space on storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0629—Configuration or reconfiguration of storage systems
- G06F3/0631—Configuration or reconfiguration of storage systems by allocating resources to storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/064—Management of blocks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0689—Disk arrays, e.g. RAID, JBOD
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1041—Resource optimization
- G06F2212/1044—Space efficiency improvement
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/65—Details of virtual memory and virtual address translation
- G06F2212/657—Virtual address space management
Abstract
Description
(S420−1)コントローラ31は、ライト対象データ(ライト要求に従うデータ)を圧縮伸張回路390により圧縮する。
(S420−2)コントローラ31は、圧縮データ(圧縮伸張回路390による圧縮後のデータ)をキャッシュメモリ32に格納する。
(S420−3)コントローラ31は、プール管理テーブル610を参照し、圧縮データのサイズ以上のサイズの空きサブプールページを特定する。特定される空きサブプールページのサイズは、例えば、圧縮データのサイズ以上のサイズのうちの最小のサイズでよい。
(S420−4)コントローラ31は、圧縮データのサイズと、特定した空きサブプールページのサイズとに差があれば、その差の分のゼロデータ(パディング用データの一例)を圧縮データに追加することにより、ライト用の圧縮データをキャッシュメモリ32上に生成する。
(S420−5)コントローラ31は、特定した空きサブプールページを、ライト先仮想ページに割り当てる(例えば、当該サブプールページの情報を、未使用キュー630から使用キュー620に移す)。結果として、当該サブプールページは、使用サブプールページとなる。
(S420−6)コントローラ31は、ライト要求に対する完了をホスト計算機10に返した後の任意のタイミングで(又は完了を返す前に)、キャッシュメモリ32上のライト用の圧縮データを、割り当てたサブプールページに書き込む。その際、コントローラ31は、プール管理テーブル610及びプールボリュームテーブル660を参照し、当該サブプールページに対応する物理アドレスに圧縮データを書き込む。
(S430−1)コントローラ31は、プールボリュームテーブル660を参照し、ライト先仮想ページに割り当てられているサブプールページ(以降、図10の説明で「割当て済サブプールページ」)から圧縮旧データをキャッシュメモリ32に読み出し、読み出した圧縮旧データを圧縮伸張回路390により伸張することで旧データをキャッシュメモリ32上に得る。
(S430−2)コントローラ31は、キャッシュメモリ32における旧データに新データ(ライト要求に従うライト対象データ)を上書きする。
(S430−3)コントローラ31は、新データを圧縮伸張回路390により圧縮することによりキャッシュメモリ32上に圧縮新データを得る。
(S450−1)コントローラ31は、プール管理テーブル610を参照し、圧縮新データのサイズ以上のサイズの空きサブプールページを特定する。特定される空きサブプールページのサイズは、例えば、圧縮新データのサイズ以上のサイズのうちの最小のサイズでよい。
(S450−2)コントローラ31は、圧縮新データのサイズと、特定した空きサブプールページのサイズとに差があれば、その差の分のゼロデータ(パディング用データの一例)を圧縮新データに追加することにより、ライト用の圧縮新データをキャッシュメモリ32上に生成する。
(S450−3)コントローラ31は、特定した空きサブプールページを、割当て済サブプールページに代えてライト先仮想ページに割り当てる。具体的には、例えば、コントローラ31は、当該サブプールページの情報を、未使用キュー630から使用キュー620に移し、割当て済サブプールページの情報を使用キュー620から未使用キュー630に移し、割当て済サブプールページに対応したガベージフラグ634を“ガベージ”とする。結果として、)。結果として、当該サブプールページは、使用サブプールページとなり、割当て済サブプールページはガベージとなる。
(S450−4)コントローラ31は、ライト要求に対する完了をホスト計算機10に返した後の任意のタイミングで(又は完了を返す前に)、キャッシュメモリ32上のライト用の圧縮新データを、割り当てたサブプールページに書き込む。
(S460−1)コントローラ31は、サブプールページ選択処理を行う。
(S460−2)コントローラ31は、圧縮新データのサイズと、サブプールページ選択処理において選択されたサブプールページ(ガベージ又は空きサブプールページ)のサイズとに差があれば、その差の分のゼロデータ(パディング用データの一例)を圧縮新データに追加することにより、ライト用の圧縮新データをキャッシュメモリ32上に生成する。
(S460−3)コントローラ31は、選択されたサブプールページが空きサブプールページの場合、(S450−3)及び(S450−4)と同様の処理を行う。
(S460−4)コントローラ31は、選択されたサブプールページがガベージの場合、次の処理を行う。すなわち、コントローラ31は、選択されたサブプールページがガベージを、割当て済サブプールページに代えてライト先仮想ページに割り当てる。具体的には、例えば、コントローラ31は、当該サブプールページ(ガベージ)の情報を、未使用キュー630から使用キュー620に移し、割当て済サブプールページの情報を使用キュー620から未使用キュー630に移し、割当て済サブプールページに対応したガベージフラグ634を“ガベージ”とする。結果として、当該ガベージは、使用サブプールページとなり、割当て済サブプールページはガベージとなる。その後、コントローラ31は、(S450−4)と同様の処理を行う。
(x)ガベージを探す処理が、処理コストの増加につながる。
(y)図11を行うと、(x)に加えて、無駄に大きいサイズのガベージが再利用される可能性があるため、サブプールページ内に無駄な領域が増えてしまうおそれがある。
Claims (10)
- 1以上の物理記憶資源と、
前記1以上の物理記憶資源に対するI/O(Input/Output)を制御するコントローラと
を有し、
前記コントローラが、前記1以上の物理記憶資源のうちの少なくとも一部に基づく論理記憶空間であるプールを管理し、
前記プールは、実領域サイズの異なる複数の実領域群を含み、
前記複数の実領域群の各々は、実領域サイズが同じ1以上の実領域であり、
前記コントローラが、論理アドレス空間である仮想ボリュームを提供し、
前記コントローラが、前記仮想ボリュームのアドレス範囲である仮想領域に対するデータを、圧縮してから、その仮想領域に割り当てられる実領域に書き込むようになっており、
前記仮想ボリュームのうちのライト先仮想領域に実領域が割当て済の場合、前記コントローラが、
(A)圧縮されたライト対象データである圧縮新データのサイズが、割当て済の実領域のサイズより大きいか否かを判定し、
(B)(A)の判定結果が真の場合、
(b1)前記圧縮新データのサイズ以上のサイズの1以上の実領域であってガベージとしての実領域であるガベージ領域を含む1以上の実領域があるか否かを判定し、
(b2)(b1)の判定結果が真の場合、ガベージ領域を含む1以上の実領域を選択し、選択した1以上の実領域を、前記割当て済の実領域に代えて前記ライト先仮想領域に割り当て、前記割当て済の実領域をガベージ領域として管理する、
ストレージ装置。 - (b2)において、選択されるガベージ領域は、前記圧縮新データのサイズ以上のサイズのガベージ領域のうち、最もサイズの小さいガベージ領域である、
請求項1記載のストレージ装置。 - 前記圧縮新データのサイズ以上のサイズのうちの最小のサイズのガベージ領域が見つかった場合、(b1)の判定結果が真であり、
前記圧縮新データのサイズ以上のサイズのうちの最小のサイズのガベージ領域が見つからなかった場合、(b1)の判定結果が偽である、
請求項1記載のストレージ装置。 - 前記コントローラが、
(X)プール総使用量が閾値を超えているか否かを判定し、
前記プール総使用量は、プール総使用容量又はプール総使用割合であり、
前記プール総使用容量は、使用実領域の総容量であり、
各使用実領域は、いずれかの仮想領域に割り当てられている実領域であり、
前記プール総使用割合は、プール容量に対するプール総使用容量の割合であり、
(Y)(X)の判定結果が真の場合、(A)の判定を行い、
(Z)(X)の判定結果が偽の場合、ライト先仮想領域に割り当てられる1以上の実領域として、前記圧縮新データのサイズ以上のサイズの1以上の空き実領域を選択する、
請求項1記載のストレージ装置。 - 前記選択された1以上の実領域のうち、ガベージ領域以外の実領域は、空き実領域である、
請求項1記載のストレージ装置。 - 仮想ボリュームのうちのライト先仮想領域に実領域が割当て済の場合、以下の(A)及び(B)を行う、
(A)圧縮されたライト対象データである圧縮新データのサイズが、割当て済の実領域のサイズより大きいか否かを判定する、
(B)(A)の判定結果が真の場合、
(b1)前記圧縮新データのサイズ以上のサイズの1以上の実領域であってガベージとしての実領域であるガベージ領域を含む1以上の実領域があるか否かを判定する、
(b2)(b1)の判定結果が真の場合、ガベージ領域を含む1以上の実領域を選択し、選択した1以上の実領域を、前記割当て済の実領域に代えて前記ライト先仮想領域に割り当て、前記割当て済の実領域をガベージ領域として管理する、
記憶領域管理方法。 - (b2)において、選択されるガベージ領域は、前記圧縮新データのサイズ以上のサイズのガベージ領域のうち、最もサイズの小さいガベージ領域である、
請求項6記載の記憶領域管理方法。 - 前記圧縮新データのサイズ以上のサイズのうちの最小のサイズのガベージ領域が見つかった場合、(b1)の判定結果が真であり、
前記圧縮新データのサイズ以上のサイズのうちの最小のサイズのガベージ領域が見つからなかった場合、(b1)の判定結果が偽である、
請求項6記載の記憶領域管理方法。 - (X)プール総使用量が閾値を超えているか否かを判定し、
前記プール総使用量は、プール総使用容量又はプール総使用割合であり、
前記プール総使用容量は、使用実領域の総容量であり、
各使用実領域は、いずれかの仮想領域に割り当てられている実領域であり、
前記プール総使用割合は、プール容量に対するプール総使用容量の割合であり、
(Y)(X)の判定結果が真の場合、(A)の判定を行い、
(Z)(X)の判定結果が偽の場合、ライト先仮想領域に割り当てられる1以上の実領域として、前記圧縮新データのサイズ以上のサイズの1以上の空き実領域を選択する、
請求項1記載のストレージ装置。 - 前記選択された1以上の実領域のうち、ガベージ領域以外の実領域は、空き実領域である、
請求項6記載の記憶領域管理方法。
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/JP2017/022613 WO2018235149A1 (ja) | 2017-06-20 | 2017-06-20 | ストレージ装置及び記憶領域管理方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPWO2018235149A1 true JPWO2018235149A1 (ja) | 2019-11-07 |
JP6696052B2 JP6696052B2 (ja) | 2020-05-20 |
Family
ID=64736915
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019524735A Active JP6696052B2 (ja) | 2017-06-20 | 2017-06-20 | ストレージ装置及び記憶領域管理方法 |
Country Status (4)
Country | Link |
---|---|
US (1) | US10846023B2 (ja) |
JP (1) | JP6696052B2 (ja) |
CN (1) | CN110199265B (ja) |
WO (1) | WO2018235149A1 (ja) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11907206B2 (en) * | 2021-07-19 | 2024-02-20 | Charles Schwab & Co., Inc. | Memory pooling in high-performance network messaging architecture |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5450577A (en) * | 1993-12-14 | 1995-09-12 | At&T Corp. | Zero-defect data integrity in high-capacity transaction systems |
US5537658A (en) * | 1995-06-07 | 1996-07-16 | International Business Machines Corporation | Distributed directory method and structure for direct access storage device (DASD) data compression |
US5764880A (en) * | 1996-09-10 | 1998-06-09 | International Business Machines Corporation | Method and system for rebuilding log-structured arrays |
JP2002207634A (ja) * | 2001-01-10 | 2002-07-26 | Fuji Xerox Co Ltd | 記憶領域管理方法及び記憶装置 |
CN107247565B (zh) * | 2009-03-18 | 2020-06-09 | 株式会社日立制作所 | 存储控制装置以及虚拟卷的控制方法 |
JP5080611B2 (ja) * | 2010-05-14 | 2012-11-21 | 株式会社日立製作所 | ThinProvisioningが適用されたストレージ装置 |
CN102929884B (zh) * | 2011-08-10 | 2016-05-04 | 阿里巴巴集团控股有限公司 | 一种收缩虚拟磁盘镜像文件的方法及装置 |
US8527544B1 (en) | 2011-08-11 | 2013-09-03 | Pure Storage Inc. | Garbage collection in a storage system |
WO2015128955A1 (ja) * | 2014-02-26 | 2015-09-03 | 株式会社日立製作所 | 記憶デバイス、記憶デバイスを有する装置、及び記憶制御方法 |
-
2017
- 2017-06-20 WO PCT/JP2017/022613 patent/WO2018235149A1/ja active Application Filing
- 2017-06-20 JP JP2019524735A patent/JP6696052B2/ja active Active
- 2017-06-20 CN CN201780083601.5A patent/CN110199265B/zh active Active
- 2017-06-20 US US16/330,944 patent/US10846023B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
CN110199265A (zh) | 2019-09-03 |
CN110199265B (zh) | 2022-11-01 |
US10846023B2 (en) | 2020-11-24 |
JP6696052B2 (ja) | 2020-05-20 |
WO2018235149A1 (ja) | 2018-12-27 |
US20190243582A1 (en) | 2019-08-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP7091203B2 (ja) | メモリシステムおよび制御方法 | |
TWI674502B (zh) | 記憶體系統及控制方法 | |
US10884630B2 (en) | Storage system | |
JP5792313B2 (ja) | ストレージシステム | |
JP4684864B2 (ja) | 記憶装置システム及び記憶制御方法 | |
US9811465B2 (en) | Computer system and cache control method | |
JP6785204B2 (ja) | メモリシステムおよび制御方法 | |
US9792073B2 (en) | Method of LUN management in a solid state disk array | |
US20150095554A1 (en) | Storage processor managing solid state disk array | |
JP5080611B2 (ja) | ThinProvisioningが適用されたストレージ装置 | |
KR20150105323A (ko) | 데이터 스토리지 방법 및 시스템 | |
JP2019079464A (ja) | メモリシステムおよび制御方法 | |
JP6678230B2 (ja) | ストレージ装置 | |
KR102434170B1 (ko) | 하이브리드 메모리 시스템 | |
CN108228482B (zh) | 用于管理存储系统中的缓存设备的方法和系统 | |
KR102443600B1 (ko) | 하이브리드 메모리 시스템 | |
US8954658B1 (en) | Method of LUN management in a solid state disk array | |
KR102202107B1 (ko) | 사용자 개별 서비스 환경을 위한 스토리지 장치 제어 방법 및 스토리지 컨트롤러 | |
JP2021034091A (ja) | メモリシステムおよび制御方法 | |
US20080109630A1 (en) | Storage system, storage unit, and storage management system | |
JP2022034455A (ja) | 計算機システムおよび管理方法 | |
JP6696052B2 (ja) | ストレージ装置及び記憶領域管理方法 | |
US11144445B1 (en) | Use of compression domains that are more granular than storage allocation units | |
JP7102482B2 (ja) | メモリシステムおよび制御方法 | |
JP7337228B2 (ja) | メモリシステムおよび制御方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20190228 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20190228 |
|
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: 20200408 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20200422 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6696052 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |