JP2021521575A - 改良されたデータ制御及びアクセスの方法及びシステム - Google Patents

改良されたデータ制御及びアクセスの方法及びシステム Download PDF

Info

Publication number
JP2021521575A
JP2021521575A JP2021513372A JP2021513372A JP2021521575A JP 2021521575 A JP2021521575 A JP 2021521575A JP 2021513372 A JP2021513372 A JP 2021513372A JP 2021513372 A JP2021513372 A JP 2021513372A JP 2021521575 A JP2021521575 A JP 2021521575A
Authority
JP
Japan
Prior art keywords
data
storage device
host controller
computing system
computing
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
Application number
JP2021513372A
Other languages
English (en)
Other versions
JP7288045B2 (ja
Inventor
エドワード フェッセル トニー
エドワード フェッセル トニー
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Cigent Technology Inc
Original Assignee
Cigent Technology Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Cigent Technology Inc filed Critical Cigent Technology Inc
Publication of JP2021521575A publication Critical patent/JP2021521575A/ja
Priority to JP2022113269A priority Critical patent/JP7448593B2/ja
Priority to JP2023038294A priority patent/JP7487372B2/ja
Application granted granted Critical
Publication of JP7288045B2 publication Critical patent/JP7288045B2/ja
Priority to JP2024011526A priority patent/JP2024054167A/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/42User authentication using separate channels for security data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/70Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer
    • G06F21/78Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure storage of data
    • G06F21/79Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure storage of data in semiconductor storage media, e.g. directly-addressable memories
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6218Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/70Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer
    • G06F21/78Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure storage of data
    • G06F21/80Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure storage of data in storage media based on magnetic or optical technology, e.g. disks with sectors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • G06F3/0659Command handling arrangements, e.g. command buffers, queues, command scheduling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/083Network architectures or network communication protocols for network security for authentication of entities using passwords
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0861Network architectures or network communication protocols for network security for authentication of entities using biometrical features, e.g. fingerprint, retina-scan
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • H04L63/107Network architectures or network communication protocols for network security for controlling access to devices or network resources wherein the security policies are location-dependent, e.g. entities privileges depend on current location or allowing specific operations only from locally connected terminals
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • H04L63/108Network architectures or network communication protocols for network security for controlling access to devices or network resources when the policy decisions are valid for a limited amount of time
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • H04L63/1408Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic by monitoring network traffic
    • H04L63/1416Event detection, e.g. attack signature detection
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W12/00Security arrangements; Authentication; Protecting privacy or anonymity
    • H04W12/60Context-dependent security
    • H04W12/61Time-dependent
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W12/00Security arrangements; Authentication; Protecting privacy or anonymity
    • H04W12/60Context-dependent security
    • H04W12/63Location-dependent; Proximity-dependent
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2463/00Additional details relating to network architectures or network communication protocols for network security covered by H04L63/00
    • H04L2463/082Additional details relating to network architectures or network communication protocols for network security covered by H04L63/00 applying multi-factor authentication

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Software Systems (AREA)
  • Computing Systems (AREA)
  • Human Computer Interaction (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Bioethics (AREA)
  • Databases & Information Systems (AREA)
  • Biomedical Technology (AREA)
  • Storage Device Security (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

データをバックアップする方法は、データストレージデバイスのホストコントローラ内のドライバにより、データストレージデバイス内の1つ以上のデータファイルを識別する脅威イベントのインディケーションを受信することと、ドライバにより、脅威イベントを遅延させることと、ドライバにより、脅威イベントを許可する前に、データストレージデバイス内の1つ以上のデータファイルをバックアップすることと、を含む。

Description

本開示は、コンピューティングデバイスにおけるデータの使用及びアクセスの監視及び制御に関し、具体的には、ホストコントローラドライバ及びソフトウェアデバイスを使用して、データストレージレベルでのデータへのアクセスを監視し、その制御を行って、重要なデータの攻撃、悪用、及び消失を阻止することに関する。
コンピューティングデバイス内のデータは、非常に重要な場合がある。多くの場合、データの消失は、攻撃による場合でも、偶発的な削除による場合でも、極めて重大であり、ある場合には、完全に取り返しのつかないことである。データ保護のほとんどの解決策は、オペレーティングシステムレベルで実行され、オペレーティングシステムで発生する攻撃を監視し、データを定期的にバックアップして、何らかの事態が発生した場合にリカバリできるようにするために、ソフトウェアアプリケーションが使用される。しかしながら、このようなアプリケーションは、オペレーティングシステムレベルで発生し、そのために検出可能な消失又は攻撃に対してのみ有用である。例えば、オペレーティングシステム自体を攻撃してオペレーティングシステムの起動を阻止するようなネットワークデバイスから来る攻撃は、オペレーティングシステムがアクティブなときにのみ実行されるアプリケーションプログラムでは防ぐことができず、オリジナルのデータと同様にデータバックアップを攻撃することができる。
したがって、オペレーティングシステムよりも下のレベルで実施されるデータ監視及び制御を可能にする解決策が必要とされている。
本開示は、データストレージデバイスのホストコントローラ、及び/又はコンピューティングデバイスのオペレーティングシステムとは別個に動作する別のハードウェアデバイスにおける実装を介して、データストレージレベルで発生するデータアクセス監視及び制御のシステム及び方法の記述を提供する。このようなデバイスは、データストレージデバイスの個々のデータセクタ及びブロックへのアクセスを監視して、データ自体の内容に関係なく、その使用及びアクセスを監視することができる。このタイプの実装では、オペレーティングシステムが侵害されている可能性がある場合に、データのバックアップ、攻撃の停止、及びその他のアクションを実行でき、これには、ユーザが変化を認識していなくても、侵害されていない異なるオペレーティングシステムの実行を選択することも含まれる。この結果、オペレーティングシステムレベルではできない、より高いレベルのデータ保護、監視、及び制御が実施される。
データフローを制御する方法は、オペレーティングシステムのユーザに基づいてユーザパーミッションを識別することと、データストレージデバイスのホストコントローラにより、識別されたパーミッションに基づいてデータの取得を制御することと、を含む。
オペレーティングシステムの自動復元の方法は、データストレージデバイスの第1のデータセクタ内に第1のオペレーティングシステムファイルのセットを記憶することと、データストレージデバイスの第2のデータセクタ内に第2のオペレーティングシステムファイルのセットを記憶することと、データストレージデバイスのホストコントローラにより、復元コマンドを受信することと、データストレージデバイスのホストコントローラ内のドライバに送信されたデータ取得要求に、第1のオペレーティングシステムファイルのセットの要求内にある第2のオペレーティングシステムファイルのセットを応答することと、を含む。
データをバックアップする方法は、データストレージデバイスのホストコントローラにより、データストレージデバイス内の1つ以上のデータファイルを識別する脅威イベントのインディケーションを受信することと、ドライバにより、脅威イベントを遅延させることと、ドライバにより、脅威イベントを許可する前に、データストレージデバイス内の1つ以上のデータファイルをバックアップすることと、を含む。
コンピューティングネットワークにおいて相互接続されたセキュリティを提供する方法は、コンピューティングネットワークにより、複数のコンピューティングデバイスを接続することと、複数のコンピューティングデバイスのそれぞれにより、複数のコンピューティングデバイス内の、他のコンピューティングデバイスのそれぞれとの間に、代替のセキュアな通信チャネルを確立することと、複数のコンピューティングデバイスの1つにより、脅威イベントを検出することと、複数のコンピューティングデバイスの1つにより、検出された脅威イベントの通知を、複数のコンピューティングデバイス内の他のコンピューティングデバイスのそれぞれに送信することと、を含む。
異常なシステムアクティビティを検出する方法は、データストレージデバイスのホストコントローラにより、コンピューティングシステムのユーザによって実行される複数のアクションを経時的にログに記録することと、ホストコントローラにより、ログに記録された複数のアクションに基づいて、複数の使用アクションを含むユーザのユーザフィンガープリントを判定することと、ホストコントローラにより、ユーザフィンガープリントに含まれない実行されたアクションに基づいて、異常なシステムアクティビティを検出することと、を含む。
データアクセスを制御する方法は、ハードウェアデバイスにより、データストレージデバイスのホストコントローラとの第1の通信チャネルと、別のデバイスとの第2の通信チャネルとを確立することと、ハードウェアデバイスにより、第1及び第2の通信チャネルを使用して、データストレージデバイスから別のデバイスに送信されるデータを制御することと、を含む。
データアクセスを制御する方法は、データストレージデバイスのホストコントローラにより、1つ以上の確立された規則の遵守を検出することと、ホストコントローラにより、検出された遵守に基づいて、データストレージデバイス内のデータへのアクセスを制御することと、を含む。
データの使用を監視する方法は、データストレージデバイスのファイルシステムレベルで、データストレージデバイスからホストデバイスに転送されたデータ量を検出することを含む。
データ保護をトリガする方法は、ストレージプラットホームコントローラとインタフェース接続された入力回路により、所定のコマンドの有無を検出することと、ストレージプラットホームコントローラにより、検出の結果として所定のアクションを実行することと、を含む。
データストレージアクセスを追跡する方法は、データストレージデバイスのホストコントローラにより、データストレージデバイスの1つ以上のセクタへのアクセスを追跡することを含む。
使用されないフラッシュメモリをクリアする方法は、フラッシュメモリ・ストレージデバイスにおいて、複数のデータ記憶ブロック内の1つ以上のインアクティブなブロックを検出することと、1つ以上のインアクティブなブロックにおいてデータ除去のための1つ以上のアクションを実行することと、を含む。
使用されないフラッシュメモリをクリアする方法は、フラッシュメモリ・ストレージデバイスにおいて、ウェアレベリング・プロセスを実行することと、新たなデータが1つ以上のブロックに転送されることなく、古いデータが1つ以上のブロックから転送されるウェアレベリング・プロセスに含まれる、1つ以上のブロックのデータ除去のための1つ以上のアクションを実行することと、を含む。
データアクセスを制御する方法は、データストレージデバイスのファイルシステム又はセクタ/ブロックレベルにおいて、1つ以上のデータファイルへのアクセスのための2要素認証を必要とすることを含み、この2要素認証は、事前設定された基準に基づく期間内に要求される。
拡張現実(augmented reality)を用いた認証方法は、場所、位置、及びオブジェクトデータを用いて、その場所又は位置におけるユーザの存在をユーザによりキャプチャされた画像データをチェックすること、及び指定されたオブジェクトを見ることにより、ユーザを認証することを含み、ある場合には、拡張現実表示において、追加の認証情報がオブジェクトに、又はオブジェクトの上に表示されてもよい。
タイピングヒューリスティックによるユーザ認証の方法は、タイピングキーストロークから判定されるタイピングパターンに基づいて、ユーザのキーを生成することを含み、ここでは、ユーザがタイピングしたときに新たなキーが生成され、登録されたキーに対する新たなキーの比較がユーザの認証に使用される。
本開示の範囲は、以下の例示的な実施形態の詳細な説明を添付の図面と併せて読むことによって最も良く理解される。図面には、以下の図面が含まれる。
図1は、例示的な実施形態に係る、データストレージデバイスのホストコントローラを含む実装によりデータアクセス及び使用を監視及び制御するように構成されたコンピューティングデバイスのハイレベルアーキテクチャを示すブロック図である。 図2は、例示的な実施形態に係る、データストレージデバイスに送受信されるデータパケットを観察及び制御するために、図1のコンピューティングデバイスにおいて使用可能なハードウェアデバイスを示すブロック図である。 図3は、例示的な実施形態に係る、図1のコンピューティングシステムのデータストレージデバイスのメインコントローラにより実施されるプロセスを示すフロー図である。 図4は、例示的な実施形態に係る、図3に示されるプロセスの一部としてのコマンドパケットの解析のプロセスを示すフロー図である。 図5は、例示的な実施形態に係る、図3に示されるプロセスの一部としてのベンダコマンドの処理のプロセスを示すフロー図である。 図6は、例示的な実施形態に係る、図3に示されるメインコントローラプロセスの一部としてのコマンドの処理のプロセスを示すフロー図である。 図7は、例示的な実施形態に係る、図3に示されるメインコントローラプロセスにおけるアイドルプロセスを示すフロー図である。 図8は、例示的な実施形態に係る、図6に示されるプロセスにおけるコマンドの実施を示すフロー図である。 図9は、例示的な実施形態に係る、コンピュータシステムアーキテクチャを示すブロック図である。
本開示の更なる適用範囲は、以下に提供される詳細な説明から明らかになるのであろう。例示的な実施形態の詳細な説明は、例示の目的のみを意図しており、したがって、必ずしも本開示の範囲を限定することを意図していないことを理解されたい。
<コンピューティングシステムにおけるデータアクセスの監視及び制御>
図1は、コンピューティングシステム100の一実施形態を示す。図1に示されるコンピューティングシステム100の実施形態は、例示としてのみ提供され、本明細書で説明される機能の実行に適したコンピューティングシステム100の取り得るすべての構成を網羅するものではないことは、当業者には明らかであろう。例えば、図9に示され、以下で詳細に説明されるコンピュータシステム900は、コンピューティングシステム100の適切な一構成とされ得る。
コンピューティングシステム100は、複数のモジュール、エンジン、デバイス、メモリ、及び、データストレージデバイス106へのアクセスの監視及びそこに記憶されたデータの使用を含む、本明細書で説明されるような機能の実行のために特別に構成された他のコンポーネントから構成されてもよい。データストレージデバイス106は、ハードディスクドライブ、ソリッドステートドライブ、コンパクトディスク、デジタルビデオディスク、磁気テープなどを含む、データの記憶に適した任意のタイプのデバイスであってもよい。データストレージデバイス106は、ホストコントローラ108を含んでもよい。ホストコントローラ108は、データストレージデバイス106内のデータを読み出し及び書き込みするように構成された、データストレージデバイス106内のハードウェア、ソフトウェア、又はそれらの組み合わせで実現されるアプリケーションプログラムであってもよい。ホストコントローラは、データストレージデバイス106内の1つ以上のデータファイル、セクタ、又はブロックへのアクセスの阻止、セクタ又はブロックの変更からのロックなどを含む、データストレージデバイス106に記憶されたデータのアクセス及び変更に関連付けられた任意の機能を実行するように構成されてもよい。本明細書で説明されるように、データストレージデバイス106に記憶されたデータに関してコンピューティングシステム100で実行されるアクションは、ホストコントローラ108により、又はホストコントローラ108と連携して、実行されてもよい。例えば、図3〜図8に示されるプロセスは、ホストコントローラ108又はその中にインストールされたアプリケーションプログラム(例えば、ドライバ)により、別のハードウェアデバイス(例えば、以下で詳細に説明される中継装置118)により、或いはそれらの組み合わせにより、実行されてもよい。ある場合には、データストレージデバイス106は、ホストコントローラ108によって使用されるメモリを含み、ホストコントローラ108の機能及びコマンドを実行する際に使用されるデータを記憶してもよく、このようなメモリは、コンピューティングシステム100のモジュール及びエンジンによって使用されるデータストレージデバイス106のデータストレージとは別であってもよい。
ホストコントローラ108は、コンピューティングシステム100のデータストレージレベルで動作するように構成されてもよい。換言すれば、コンピューティングシステム100は、オペレーティングシステム(OS)アプリケーション120を含むことができ、これはコンピューティングシステム100の処理装置により実行され、コンピューティングシステム100のユーザ、及びソフトウェアアプリケーションプログラムが実行され得るプラットホームへのインタフェースを提供することができ、ここで、ホストコントローラ108は、OSアプリケーション120とは別個に動作することができる。例えば、OSアプリケーションは、以下で詳細に説明される通信モジュール104を介して、そのホストコントローラ108と通信することにより(例えば、情報をやり取りすることにより)、データストレージデバイス106にアクセスすることができる。例えば、OSアプリケーション120は、プログラムコードとしてデータストレージデバイス106に記憶され、独自のファイル、或いはホストコントローラ108からの対応するデータの要求によりOS上で実行されるアプリケーションプログラムによって使用されるファイルにアクセスすることができる。
ある実施形態では、コンピューティングシステム100は、データストレージデバイス106に加えてメモリ110を含んでもよい。メモリ110は、OSアプリケーション120の実行及び使用においてコンピューティングシステム100によって使用され得る、リードオンリーメモリ、ランダムアクセスメモリ、又は他のタイプのメモリである、別のデータストレージデバイスであってもよい。ある場合には、ホストコントローラ108は、メモリ110のホストコントローラとしても動作するように構成されてもよく、或いはメモリ110に記憶されたデータへのアクセス及びその使用を監視するように構成されてもよい。メモリ110は、本明細書で説明される機能を実行する際にコンピューティングシステム100によって使用されるデータを記憶するように構成されてもよい。メモリ110は、データストレージデバイス106と同様に、適切なデータフォーマット方法及びスキーマを使用してデータを記憶するように構成されてもよく、任意の適切なタイプのメモリであってもよい。メモリ110は、例えば、暗号化キー及びアルゴリズム、通信プロトコル及び規格、データフォーマット規格及びプロトコル、処理装置のモジュール及びアプリケーションプログラムのプログラムコード、並びに、当業者には明らかなように本明細書で開示される機能の実施においてコンピューティングシステム100によって使用されるのに適した他のデータを含むことができる。ある実施形態では、メモリ110は、そこに記憶された構造化データセットの記憶、特定、変更、更新、アクセスなどのために構造化クエリ言語を使用するリレーショナルデータベースで構成されてもよく、或いはそれを含んでいてもよい。
ある実施形態では、コンピューティングシステム100は、フラッシュメモリ112を含んでもよい。フラッシュメモリ112は、データストレージデバイス106とは別のソリッドステートメモリデバイス(例えば、該当する場合は、メモリ110)であってもよく、ある場合には、コンピューティングシステム100から取り外し可能であってもよい。フラッシュメモリ112は、その中のデータの記憶を実施するために可動機械部品を使用せずに動作することができるので、フラッシュメモリ112は、そのデータの記憶及びアクセスのためにホストコントローラ108によって実行される、異なるアクション及び/又は変更されたアクションの対象とされてもよい。ある実施形態では、データストレージデバイス106のホストコントローラ108は、フラッシュメモリ112のホストコントローラ108として動作してもよい。他の実施形態では、フラッシュメモリ112は、別のホストコントローラ108を有してもよい。本明細書で説明されるように、ホストコントローラ108によって実行される機能はいずれも、コンピューティングシステム100のそれぞれのメモリ及びデータストレージデバイスのホストコントローラによって実行されてもよい。
コンピューティングシステム100は、受信装置102を含んでもよい。受信装置102は、1つ以上のネットワークプロトコルを介して、1つ以上のネットワークでデータを受信するように構成されてもよい。ある実施例では、受信装置102は、無線周波数、ローカルエリアネットワーク、ワイヤレスエリアネットワーク、セルラ通信ネットワーク、ブルートゥース、インターネットなどの1つ以上の通信方法を介して、コンピューティングシステム100のローカルネットワーク上に配置され、或いは、コンピューティングシステムの外部に配置される、他のコンピューティングシステムからデータを受信するように構成されてもよい。ある実施形態では、受信装置102は、例えばローカルエリアネットワークを介してデータを受信する第1の受信装置及びインターネットを介してデータを受信する第2の受信装置などの、異なるネットワークを介してデータを受信する異なる受信装置など、複数のデバイスから構成されてもよい。受信装置102は、電子的に送信されたデータ信号を受信することができ、データは、データ信号において重畳され、或いは符号化され、受信装置102によるデータ信号の受信を介して復号化され、解析され、読み出され、或いは取得されてもよい。ある実施例では、受信装置102は、受信されたデータ信号を解析して、その上に重畳されたデータを取得するための、解析モジュールを含んでもよい。例えば、受信装置102は、データ信号を受信し、受信されたデータ信号を本明細書で説明される方法及びシステムを実行するために処理装置によって実行される機能で使用可能な入力に変換するように構成された解析プログラムを含んでもよい。
コンピューティングシステム100は、送信装置124を含んでもよい。送信装置124は、1つ以上のネットワークプロトコルを介して、1つ以上のネットワークでデータを送信するように構成されてもよい。ある実施例では、送信装置124は、無線周波数、ローカルエリアネットワーク、ワイヤレスエリアネットワーク、セルラ通信ネットワーク、ブルートゥース、インターネットなどの1つ以上の通信方法を介して、コンピューティングシステム100のローカルネットワーク上に配置され、或いは、コンピューティングシステムの外部に配置される、コンピューティングシステムにデータを送信するように構成されてもよい。ある実施形態では、送信装置124は、例えばローカルエリアネットワークを介してデータを送信する第1の送信装置及びインターネットを介してデータを送信する第2の送信装置などの、異なるネットワークを介してデータを送信する異なる送信装置など、複数のデバイスから構成されてもよい。送信装置124は、受信側コンピューティングデバイスによって解析され得るデータが重畳されたデータ信号を電子的に送信することができる。ある実施例では、送信装置124は、データを送信に適したデータ信号に重畳し、符号化し、或いはフォーマットする1つ以上のモジュールを含んでもよい。
コンピューティングシステム100は、通信モジュール104を含んでもよい。通信モジュール104は、本明細書で説明される機能を実行する際に使用され、モジュール、エンジン、データベース、メモリ、及びコンピューティングシステム100の他のコンポーネント(例えば、コンピューティングシステム100の「デバイス」又は「ホストデバイス」とも称される)の間でデータを送信するように構成されてもよい。通信モジュール104は、1つ以上の通信タイプで構成され、コンピューティングデバイス内の通信のための様々な通信方法を使用することができる。例えば、通信モジュール104は、バス、コンタクトピンコネクタ、ワイヤなどで構成されてもよい。ある実施形態では、通信モジュール104は、コンピューティングシステム100の内部コンポーネントと、外部接続データベース、表示装置、入力装置などのコンピューティングシステム100の外部コンポーネントとの間で通信するように構成されてもよい。コンピューティングシステム100は、処理装置を含んでもよい。処理装置は、当業者には明らかなように、本明細書で説明されるコンピューティングシステム100の機能を実行するように構成されてもよい。ある実施形態では、処理装置は、処理装置の1つ以上の機能を実行するように特別に構成された複数のエンジン及び/又はモジュールを含み、且つ/又はそれらで構成されてもよい。本明細書で使用されるように、「モジュール」という用語は、特に、入力を受信し、入力を使用して1つ以上のプロセスを実行し、出力を提供するようにプログラムされた、ソフトウェア又はハードウェアであってもよい。様々なモジュールによって実行される入力、出力、及びプロセスは、本開示に基づいて当業者には明らかであろう。
上述のように、コンピューティングシステム100は、OSアプリケーション120を含んでもよい。OSアプリケーション120は、OSアプリケーション120をプラットホームとして使用して実行されるアプリケーションプログラムと、データストレージデバイス106及びコンピューティングシステムの他のメモリとの間の連絡機構として動作するシステムソフトウェアであってもよい。ある実施形態では、コンピューティングシステム100は、その中に記憶された複数のOSアプリケーション120を有してもよく、それらはそれぞれ、データストレージデバイス106及び/又はコンピューティングシステム100の他のメモリに記憶されてもよい。このような実施形態では、単一のOSアプリケーション120がコンピューティングシステム100の実行時に実行されてもよく、それはコンピューティングシステム100のベーシックインプット/アウトプットシステム(BIOS)によって選択されてもよい。以下で詳細に説明されるように、ホストコントローラ108は、コンピューティングシステム100で動作するOSアプリケーション120の選択を変更し、或いはデータ記憶操作を通じて、選択されたOSアプリケーション102を変更して、コンピューティングシステム100への攻撃を防ぐように、或いは効率的な動作を保証するように構成されてもよい。
コンピューティングシステム100は、ファイルシステムコントローラ122を含んでもよい。ファイルシステムコントローラ122は、OSアプリケーション120の一部であってもよく、コンピューティングシステム102のユーザ又はOSアプリケーション102のアプリケーションプログラムがデータストレージデバイス106のファイルシステム又はコンピューティングシステム102の他のメモリ110にアクセスするためのインタフェースを(例えばアプリケーションプログラミングインタフェースとして)提供するように構成してもよい。ある場合には、ファイルシステムコントローラ122は、(例えば通信モジュール104を介して)それぞれのデータストレージデバイス106のホストコントローラ108と通信して、そこに記憶されたデータの取得又は変更をしてもよい。例えば、OSアプリケーション102を使用して動作するアプリケーションプログラムは、データストレージデバイス106に記憶されたデータへのアクセスのために、ファイルシステムコントローラ122と相互に作用することができ、ここで、ファイルシステムコントローラ122は、読み出し又は書き込みを行うデータに関する命令をホストコントローラ108に提供することができ、ホストコントローラ108は、データストレージデバイス106内の必要な機能を実行して、要求された動作を実行することができる。
ある実施形態では、コンピューティングシステム100は、中継装置118(interposition device)を含んでもよい。中継装置118は、データストレージデバイス106及びコンピューティングシステム100の他のハードウェアコンポーネントとは別のハードウェアデバイスであってもよく、通信モジュール104を使用してコンピューティングシステム100を通過するような、データストレージデバイス106に送受信されるデータパケットを監視するように構成されてもよい。中継装置118の実装については、図2のハードウェアデバイス200に関して以下で詳細に説明する。ある実施形態では、中継装置118は、データストレージデバイス106のホストコントローラ108に実装されてもよい。他の実施形態では、中継装置118は、ホストコントローラ108と直接的に通信して、データストレージデバイス106に送受信されるデータパケットを監視してもよい。
コンピューティングシステム100は、1つ以上の入力装置を含んでもよく、或いはそれとインタフェース接続されてもよい。入力装置は、コンピューティングシステム100の内部にあってもよく、コンピューティングシステム100の外部にあってもよく、データの送受信のために1つ以上の接続(例えば、有線又は無線)を介して接続されてもよい。入力装置は、コンピューティングシステム100のユーザからの入力を受け付けるように構成されてもよく、それは、後続処理のために、コンピューティングシステム100の別のモジュール又はエンジンに(例えば通信モジュール204を介して)提供されてもよい。入力装置は、キーボード、マウス、クリックホイール、スクロールホイール、マイクロフォン、タッチスクリーン、トラックパッド、カメラ、光学撮像素子など、本明細書で説明される機能を実行するための入力を受け付けるのに適した、任意のタイプの入力装置を含んでもよい。入力装置は、例えば、キーストローク情報、物理的環境の光学画像、及び本明細書で説明されるような用途の、他のデータを受信するように構成されてもよい。
コンピューティングシステム100は、表示装置を含んでもよく、或いは表示装置とインタフェース接続されてもよい。表示装置は、コンピューティングシステム100の内部にあってもよく、コンピューティングシステム100の外部にあってもよく、データの送受信のために1つ以上の接続(例えば、有線又は無線)を介して接続されてもよい。表示装置は、コンピューティングシステム100のユーザに対してデータを表示するように構成されてもよい。表示装置は、液晶ディスプレイ、発光ダイオードディスプレイ、薄膜トランジスタディスプレイ、静電容量式タッチディスプレイ、陰極線管ディスプレイ、光投影ディスプレイなど、本明細書で説明される機能の一部としてデータを表示するのに適した任意のタイプの表示装置であってもよい。ある実施例では、コンピューティングシステム100は、複数の表示装置を含んでもよい。表示装置は、例えば、認証情報、物理領域の拡張現実表示、OSアプリケーション120の一部としてのファイルシステムなどを表示するように構成されてもよい。
<中継装置>
図2は、コンピューティングシステム100において中継装置118として動作可能なハードウェアデバイス200を示す。図2に示されるハードウェアデバイス200の実施形態は、例示としてのみ提供され、本明細書で説明される機能の実行に適したハードウェアデバイス200の取り得るすべての構成を網羅するものではないことは、当業者には明らかであろう。
ハードウェアデバイス200は、マイクロコントローラ202を含んでもよい。マイクロコントローラ202は、本明細書で説明される中継装置118の機能を実行するように構成された集積回路であってもよく、例えば、コンピューティングシステム100内のデータストレージデバイス106に送受信されるデータパケットを監視するように構成された、プログラムされた処理装置(programmed processing device)であってもよい。ハードウェアデバイス200は、シリアルアドバンストテクノロジアタッチメント(シリアルATアタッチメント、SATA)ドライブ210を含んでもよく、ハードウェアデバイス200に関連付けられた機能を実行する際にハードウェアデバイス200により使用されるデータを記憶するように構成されてもよい。例えば、SATAドライブ210は、データパケットの移動の監視などの、マイクロコントローラ202により実行されるプログラムコードを記憶するように構成されてもよい。また、SATAドライブ210は、例えば、コンピューティングシステム100のユーザによるレビュのためのデータログ、データ送信に関連付けられた警告を送信するための規則、コンピューティングシステム100における潜在的な攻撃を識別するためのアルゴリズム等、データパケット監視に関する情報を記憶するように構成されてもよい。
ハードウェアデバイス200は、SATAを用いて、ホスト208とインタフェース接続するように構成されてもよい。SATAホスト208は、例えば、通信モジュール104又はデータストレージデバイス106であってもよく、ハードウェアデバイス200は、SATAホスト208又はそこから受信されたデータを介して、データストレージデバイス106へのデータパケットの送受信を監視してもよい。ハードウェアデバイス200は、例えばマイクロコントローラ202によって指示されることで実行されるハードウェアデバイス200の機能に応じて、SATAドライブ210とSATAホスト208との間を切り替えるように構成される、ポートセレクタ206を含んでもよい。
ある実施形態では、マイクロコントローラ202は、パラレルATアタッチメント(PATA)を介して通信するように構成されてもよい。このような実施形態では、ハードウェアデバイス200は、PATA/SATAブリッジ204を含むことができ、PATAを使用してマイクロコントローラ202とインタフェース接続し、SATAを使用してポートセレクタとインタフェース接続し、マイクロコントローラ202とSATAドライブ210とSATAホスト208との間で交換される通信を可能にするように構成されてもよい。ハードウェアデバイス200は、SATAドライブ210に、その動作のために電力を供給するように構成されたコンポーネントである、駆動電源212を含んでもよい。駆動電源212は、マイクロコントローラ202に接続され、そこから動作の命令を受信してもよく、それにより、SATAドライブ210に動作(停止)させてもよい。ある実施形態では、ハードウェアデバイス200は、ハードウェアデバイス200のコンポーネント、コンピューティングシステム100のコンポーネント、ハードウェアデバイス200とコンピューティングシステム100とのインタフェース接続、ハードウェアデバイス200の実施形態のタイプなど、ハードウェアデバイス200における必要性に応じて、ハードウェアデバイス200内の電圧の安定化のために、+3.3電圧レギュレータ及び/又は+1.8電圧レギュレータ216を含んでもよい。
上述のように、ハードウェアデバイス200は、コマンドパケット及びデータパケットを、データストレージデバイス106及びコンピューティングシステム100の他のメモリ110に送受信されるときに検査し、中継するように構成された、コンピューティングシステム100の中継装置118として動作してもよい。ハードウェアデバイス200は、データストレージデバイス106宛てのすべてのインバウンド及びアウトバウンドのデータストレージを観察、制御、及びルーティングするように構成されてもよい。このような動作は、本明細書で説明されるコンピューティングシステム100に関連付けられた機能の実施のための他の動作と併せて実施されてもよい。例えば、ホストコントローラ108は、以下に説明されるように、データアクセスに関連付けられたユーザアクションのルーチンに基づいて、データストレージデバイス106に記憶されたデータの潜在的な攻撃又は他の悪用を監視するように構成されてもよく、データストレージデバイス106のハードウェアデバイスのインバウンド及びアウトバウンドの通信の観察を使用して、データアクセスが識別されてもよい。
<ホストコントローラ及び中継装置の例示的な機能>
上述のように、コンピューティングシステム100のホストコントローラ108及び中継装置118は、データストレージデバイス106に記憶されたデータへのアクセス及び使用を監視して、データの悪用、データに対する攻撃の試みを阻止し、データのバックアップを容易にするように、或いはコンピューティングシステム100に記憶されたデータを保護するように構成されてもよい。
一実施形態では、ホストコントローラ108は、データストレージデバイス106からファイルシステムコントローラ122などのデバイス要求側に流れるデータであって、コンピューティングシステム102のユーザにより、表示、又は他の方法での使用を要求されたデータを制御するように構成されてもよい。このような実施形態では、ホストコントローラ108は、ファイルシステムコントローラ122によって送信されるリクエストを理解し、ファイルシステムコントローラ122に提供されるデータを変更して、これにより、データストレージデバイス106に記憶された基礎となるデータに変更を加えることなく、ホストコントローラ108によってデータのユーザのビューが変更されるように構成されてもよい。例えば、コンピューティングシステム100のユーザは、認証プロセス(例えばOSアプリケーション120を使用したログイン)を実施してもよく、コンピューティングシステム100のそれぞれのユーザは、そのユーザが閲覧又は他の方法でアクセス可能なデータに関して、ユーザに関連付けられたパーミッションのレベルを有してもよい。ホストコントローラ108は、このパーミッションのレベルに基づいて、ユーザが許可されているデータのみを見ることができるように、データストレージデバイス106に記憶されたデータに関してファイルシステムコントローラ122に提供される情報を変更してもよい。ユーザが閲覧を許可されていないデータは、ホストコントローラ108による変更なしにデータストレージデバイス106に記憶され続けてもよいが、ファイルシステムコントローラ122は、それに関連付けられた情報をユーザに提示しない。例えば、データは、ユーザの観点からは存在しないが、データストレージデバイス106に安全に記憶されている。したがって、このような例では、データストレージデバイス106は、権限を有する者による場合を除いて、データの削除又は誤用から保護することができる。
ホストコントローラ108は、コンピューティングシステム100の起動に使用されるOSアプリケーション120を自動的に選択するように構成されてもよい。例えば、コンピューティングシステム100が(例えばホストコントローラ108、中継装置118、又は他のコンポーネントを介して)、OSアプリケーション120の動作の不良又はOSアプリケーション120の侵害などの、デフォルトのOSアプリケーション120に関する潜在的な問題を検出した場合、ホストコントローラ108は、コンピューティングシステム100で使用される、リカバリOSアプリケーション120を自動的に選択するように構成されてもよい。ある場合では、リカバリOSアプリケーション120は、基礎となるデータストレージデバイスの動作を介して選択されてもよい。例えば、ホストコントローラ108は、デフォルトのOSアプリケーション120を記憶するために使用されるデータセクタ及び/又はブロックを、リカバリOSアプリケーション120を記憶するものと切り替えて、コンピューティングシステム100が、通常動作を試みるときに、リカバリOSアプリケーション120を実行するようにしてもよい。このような実施形態では、リカバリOSアプリケーション120は、自動的に実行され、これにより、侵害されたOSアプリケーション120がコンピューティングシステム100に有害な変更を加えることを阻止し、ユーザに侵害を取り除く機会を提供することができる。
OSアプリケーション120を自動的に選択する能力は、OSアプリケーション120のリストア又はリフレッシュを実行するために、ホストコントローラ108によって使用されてもよい。例えば、ホストコントローラ108は、データストレージデバイス106内の所定の位置に記憶されたOSアプリケーション120のスナップショット又は保存された状態(saved state)を有してもよい。OSアプリケーション120に潜在的な問題(例えば、検出された攻撃、OSアプリケーション120の動作エラー)が特定された場合、或いはコンピューティングシステム100のユーザによって要求された場合、ホストコントローラ108は、(例えば、潜在的な問題の前に)保存されたOSアプリケーション120が代わりに実行されるように、OSアプリケーション120を保存された状態に自動的に切り替えることができる。このような場合、ホストコントローラ108は、コンピューティングシステム102のアイドルサイクル中に、交換後の侵害されたOSアプリケーション120を上書きして、侵害を取り除き、コンピューティングシステム100を更に保護することもできる。このような実装では、OSアプリケーション120は、ユーザの知識又は行動なしに復元されてもよい。ある実施形態では、リストアは、変更のログを使用して実行されてもよい。例えば、ホストコントローラ108は、データストレージデバイス106に関して実行されたすべての動作のログを維持することができ、復元動作は、データストレージデバイス106(及びその中に記憶されたOSアプリケーション120)を以前の状態に戻すために、データストレージデバイス106に記憶されたデータを変更、移動、又は置換するなど、(例えば事前定義された復元ポイントに戻るように)所定の期間におけるすべての動作を逆行させることを含んでもよい。
ある実施形態では、ホストコントローラ108は、データストレージデバイス106に記憶されたデータを自動的にバックアップするように構成されてもよい。そのような実施形態では、ホストコントローラ108は、コンピューティングシステム100内で発生した、データに脅威をもたらす可能性があるイベントを監視するように(例えば、中継装置118などの別のコンポーネントによって直接的又は間接的に通知されるように)構成されてもよい。例えば、未知の通信、ファイル削除又は変更の要求、データの暗号化又は復号化などは、潜在的なネガティブイベントとしてホストコントローラ108によって識別され得る。このようなイベントが検出されると、イベントは、ホストコントローラ108がデータをバックアップしている間に、一時停止されてもよく、或いは遅延させられてもよい。ある場合には、バックアップされるデータは、予め判定されてもよい。例えば、(例えば、OSアプリケーション120に不可欠なもの、ユーザによって選択されたものなど)試みられているアクションに関係なくバックアップされるデータが存在してもよい。他の場合では、バックアップされるデータは、イベントにより影響を受けるデータであってもよい。例えば、イベントが特定のデータブロックの削除である場合、これらのデータブロックがバックアップされてもよい。ホストコントローラ108は、データストレージデバイス106内の所定の位置にデータをバックアップしてもよく、バックアップが完了するとイベントを発生させてもよい。このような実施形態では、コンピューティングシステム100に記憶されたデータは、起こり得る潜在的なイベントに関わらず、保護されたままとされてもよい。ある場合には、バックアップされるデータが、イベント又はそれによって影響され得るデータの種類に基づいて異なるように、或いは実行されるアクションがイベントの種類に基づいて異なるようになど、複数のポリシーが実装されてもよい。
ある実施形態では、コンピューティングシステム100は、他のコンピューティングシステムのネットワークの一部であってもよい。このような実施形態では、潜在的な脅威イベント又はネガティブイベントは、ネットワーク内の他のコンピューティングシステムによって検出されてもよい。このような場合には、ホストコントローラ108は、(例えば、ホストコントローラ108又は他のコンピューティングシステム内の中継装置118などにより、本明細書で説明される機能を使用して検出される)これらの潜在的な脅威イベントに関する情報を他のコンピューティングシステムから受信してもよく、それに基づいて本明細書で説明されるアクションを実行してもよい。ある実施例では、ホストコントローラ108又はコンピューティングシステム100の他のハードウェアコンポーネントは、ネットワーク内の他のコンピューティングシステムの対応するコンポーネントとの代替のセキュアな通信チャネルを確立してもよい。このようなチャネルは、ネットワークで発生し、ネットワークを侵害する可能性がある脅威イベントが代替のセキュアなチャネルにアクセスできないように、或いは影響を与えることができないように、ネットワークの通信チャネルとは別であってもよい。ある場合には、セキュアチャネルは、そのチャネルを使用する通信をセキュアにする技術(例えば、暗号化)を使用して、そのネットワーク自体の上で動作してもよい。他の場合では、別のプロトコル及び/又は通信パスが使用されてもよい。ある場合には、他のコンピューティングシステムは、他のコンピューティングシステム100であってもよく、或いは、動き検出器、近接ドアセンサ、バイオメトリックスキャナ、セットトップボックス、ビデオゲームシステム、ウェアラブルコンピューティングデバイスなど、コンピューティングシステム100とのセキュアな通信チャネルを確立し、脅威イベントを検出することができる任意のタイプのコンピューティングデバイスであってもよい。
ある実施形態では、ホストコントローラ108は、データストレージデバイス106へのアクセスに関して、ユーザ又はコンピューティングシステム100の他の動作に関連付けられた過去の使用データのセットを作成するように構成されてもよい。過去の使用データは、データストレージデバイス106のデータのアクセス、取得、変更、又は書き込みなど、データストレージデバイス106に関連して実行されるアクションのログであってもよい。ログは、数秒のスパン、データストレージデバイス106の全寿命、又はそれらの間の任意の長さの時間をカバーしてもよい。ログは、データの読み出し、データの書き込み、データの上書き、データの変更などを含む、データストレージデバイス106に関連付けられた任意のアクションをカバーしてもよく、影響を受けるセクタ及び/又はブロックを指定し、そして、それらがどのように影響を受けるかを指定してもよい。ログを使用して、ホストコントローラ108は、コンピューティングシステム100の典型的な使用特性の「フィンガープリント」又は「スナップショット」を構築してもよく、ある場合には、コンピューティングシステム100のユーザに直接関連付けられてもよい(例えば、それぞれのユーザは個人的なアクションに基づいて独自のフィンガープリントを持つことができる)。このようなスナップショットは、それぞれのユーザ又はコンピューティングシステム100全体の署名を判定するために、そして、データストレージデバイス106を使用するときに、どのようなアクションが標準的又は「通常」と見なされるかを判定するために、考慮されてもよい。ユーザの署名に基づいて標準と考えられるものから外れているイベントが試みられるとき、そのイベントは脅威イベントであると判定されてもよい。それから、ホストコントローラ108は、脅威イベントが検出されたときに、(例えば、データの自動的なバックアップ、代替のセキュアなチャネルを使用した他のコンピューティングデバイスの通知、データの暗号化、ファイルシステムデータの変更など)任意の好適なアクションを実行してもよい。ある実施形態では、ホストコントローラ108には、既知のウイルス、ランサムウェア、又は他の望ましくないエージェントのための署名が提供されてもよく、署名は、ネガティブなアクションが実行される前に、このようなエージェントの存在を検出するために使用されてもよい。
ある実施形態では、ホストコントローラ108は、確立された規則への遵守(compliance)に基づいて、データストレージデバイス106へのアクセスを制御するように構成されてもよい。ある実施例では、規則は、追加のハードウェアコンポーネントの使用、又はコンピューティングシステム100に依存する他の局面を含んでもよい。例えば、規則は、コンピューティングシステム100が(例えば、全地球測位システムに基づく)特定の地理的領域に位置することを要求してもよく、それは、ホストコントローラ108、コンピューティングシステム100の標準コンポーネント、コンピューティングシステム100の一部であるが、コンピューティングシステム100の他のコンポーネントとは独立して動作する別のハードウェアコンポーネント、或いはOSアプリケーション120によるアクセスが不可能である別のハードウェアコンポーネントによって識別されてもよい。他の実施例では、ホストコントローラ108は、データストレージデバイス106へのアクセスのためにセキュリティドングルの存在を要求してもよく、また、(例えば、ファイルシステムコントローラ122により提示されるデータのビューを変更することに関して上述されたように)セキュリティドングルから受信したクレデンシャルに基づいて、データの閲覧又は使用を阻止してもよい。他の実施例では、規則は、コンピューティングシステム100と別のデバイスとの間の物理的な接続を要求してもよい。ある場合には、確立された規則に従わないことで、ホストコントローラ108により脅威イベントとして識別されてもよく、それに応じて必要なアクションが実行されてもよい。
ある実施形態では、ホストコントローラ108は、データストレージデバイス106から転送された(例えば、読み出された)データ量を監視するように構成されてもよい。ホストコントローラ108は、データストレージデバイス106から読み出されたデータ量を追跡し続け、データ量に基づいてアクションを実行してもよい。例えば、読み出されるデータの量の限界が設定されてもよく、限界に達すると、データへのアクセスが阻止又は制限されてもよく、或いは、限界に達したことが脅威イベントとして見なされてもよい。データストレージデバイス106から読み出されたデータ量は、ユーザのフィンガープリント又は署名の一部と見なされてもよい。ある場合には、データの量は、時間ごと、日ごと、週ごと、月ごとなどの期間にどれだけのデータがアクセスされるかを測定するなど、期間に関連付けて監視されてもよい。ある実施形態ではホストコントローラ108は、データストレージデバイス106の特定のセクタ及び/又はブロックから転送されるデータ量を監視してもよく、限界又は規則は、セクタ及び/又はブロックに応じて異なってもよい。例えば、OSアプリケーション120のプログラムコード又はバックアップデータを記憶するために使用されるブロックから読み出されるデータには制限がないが、他のデータを記憶するために使用されるブロックには制限が設定されてもよい。ある場合には、ホストコントローラ108は、ファイルシステムコントローラ122と通信して、アクセスされたデータの監視に使用可能な、ファイルタイプ情報など、アクセスされたデータに関する追加の情報を受信してもよい。例えば、(ビデオ、画像、音楽などの)メディアファイルについて読み出されるデータ量に制限が設定され、一方で、(ダイナミックリンクライブラリ、システムファイルなどの)オペレーティングシステムファイルについては設定されなくてもよい。
ある実施形態では、コンピューティングシステム100は、データストレージデバイス106に記憶されたデータへのアクセスを制御する際にホストコントローラ108によって使用される、独立した機械的及び/又は電気的なコンポーネントを含んでもよい。独立コンポーネントは、コンピューティングシステム100のユーザが、独立コンポーネントの使用を(例えば、該当する、追加の状態の間に)アクティブ化又はインアクティブ化するように構成可能であり、データストレージデバイス106内のデータへのアクセスが、独立コンポーネントの状態に基づいて、ホストコントローラ108により制御されてもよい。例えば、ホストコントローラ108とは別の任意の他のコンポーネントとインタフェース接続されていないボタンがコンピューティングシステム100に含められてもよく、このボタンが押されると、データストレージデバイス106の所定の領域へのアクセスが阻止されてもよい。ボタン、スイッチ、センサ、加速度計、バイオメトリックスキャナ、光学撮像素子、マイクロフォンなど、任意の適切なタイプの機械的及び/又は電気的コンポーネントが使用されてもよい。ある実施例では、独立コンポーネントによって検出されたアクションは、ホストコントローラ108によって脅威イベントと見なされてもよい。例えば、バイオメトリックスキャナは、登録されたユーザのバイオメトリクスが読み出されたときに、データストレージデバイス106の一部へのアクセスを制御するために使用されてもよいが、権限のないユーザがバイオメトリックスキャナを使用して認証を試みた場合に、脅威イベントが検出されてもよい。
ある実施形態では、ホストコントローラ108は、データストレージデバイス106がフラッシュメモリを使用するときに、追加の機能を実行するように構成されてもよい。フラッシュメモリの性質のために、データは、ウェアレベリング(wear leveling)・アルゴリズムを使用するフラッシュメモリの摩耗及び劣化のために、フラッシュメモリ内のブロック間で移動されることがある。伝統的に、摩耗したブロックは、そのブロックから別のブロックにデータを移動させるが、オリジナルのブロックは消去されず、したがって残されたデータが侵害の対象となる。ある実施形態では、ホストコントローラ108は、フラッシュメモリ112に対して実行されるウェアレベリング・プロセスの一部として、これらのオリジナルのブロックの完全消去を実行するように構成されてもよい。ホストコントローラ108は、ブロックの使用を監視してもよく、ブロックは、その中に記憶されたデータの状態及びフラッシュメモリ112内でのその使用に基づいて、アクティブ又はインアクティブとしてラベル付けされてもよい。ホストコントローラ108は、所定の期間に、インアクティブブロック内のデータの完全消去を実行して、その侵害を阻止し、データブロックの寿命を延ばすことができる。完全消去は、書き込みの繰り返し、データにおいてより小さな部分のアドレス指定、ブランク又は解読不可能なデータによるデータの上書き、及び古いブロック又はインアクティブなブロック内のデータを確実にクリアするために使用される他の技術を使用することによって達成されてもよい。ある実施例では、ホストコントローラ108は、使用するブロックのタイプ(例えば、インアクティブブロック、使い古されたブロック(worn blocks)など)又は消去プロセスのタイプを指定した、コンピューティングシステム100のユーザによるコマンド入力に応答して、ブロックの完全消去を実行するように構成されてもよい。
ある実施形態では、ホストコントローラ108は、データストレージデバイス106に記憶されたデータファイルへのアクセスを制御するために2要素認証を使用するように構成されてもよい。2要素認証は、(i)ユーザが何を知っているか(例:パスワード)と(ii)ユーザが何を持っているか(例:ドングル)とに依存する2つの異なるタイプの認証を要求することにより、認証ルーチンのセキュリティを高める方法である。ある場合には、ユーザは、バイオメトリックスキャナ、パスワード、第三者認証サービス、セキュリティドングル、スマートデバイスなど、いずれか又はすべてのタイプの認証を設定してもよい。ある実施例では、ユーザは、アクセスするために2要素認証が必要なデータファイルを選択してもよい。このような場合には、使用される2要素認証のタイプは、制御されるアクセスによって異なってもよい。例えば、ユーザは、データストレージデバイス106に記憶されたすべての画像にアクセスするために、パスワード及びセキュリティドングルから成る2要素認証を要求してもよく、特定のフォルダ内のファイルにアクセスするために、指紋スキャン及び異なるセキュリティドングルから成る2要素認証を要求してもよい。2要素認証は、特定のファイル又はフォルダ、ファイルの種類、特定の取得条件を満たすファイル又はフォルダなどに対して設定されてもよい。ある場合には、2要素認証が要求されるときの基準が、ユーザによって設定されてもよい。例えば、ユーザは、(例えば、特定の2要素認証の規則のセットについて)2要素認証が常に要求されること、2要素認証が所定の期間(例えば、午後5時から午前6時の間)にのみ要求されること、特定のタイムフレーム(例えば、次の1時間、翌日、翌週など)に要求されること、或いはコンピューティングデバイス100によって攻撃が検出された場合(例えば、直接的に検知した場合、又は外部システム又はデバイスによって通知された場合)又はコンピューティングデバイス100が攻撃の危険にさらされている可能性があると判定された場合(例えば、上述のように識別された場合)にのみ2要素認証が要求されること、を指定してもよい。ユーザは、基準、保護タイプ、及び2要素認証タイプの任意の組合せを有してもよく、データストレージデバイス106に対してアクティブな複数の保護のセットを有してもよい。ある場合には、データストレージデバイスは、データストレージデバイス106がオペレーティングシステムから取り外された場合に(例えば、ホストコントローラ108がアクセスされることで、或いはオペレーティングシステムがホストコントローラの代わりに2要素認証を管理するために使用されることで)データへのアクセスを阻止するなどの、ユーザが2要素認証プロセスを終了できない限り、1つ以上のセクタへのアクセスを制限する、ファームウェア変更を有してもよい。
ある実施形態では、コンピューティングシステム100は、例えば上述の2要素認証における要素のうちの1つとして、認証プロセスの一部に拡張現実を使用するように構成されてもよい。このような実施形態では、位置的、物理的、及び視覚的な入力の組合せが、コンピューティングシステム100におけるユーザの認証に使用されてもよい。このような入力は、ジオロケーション、ローカル環境、ローカル位置、及びオブジェクトの入力を含んでもよい。ジオロケーション入力は、全地球測位システムの使用により提供されるような、地理的座標(例えば、緯度及び経度)を含んでもよい。ローカル環境入力は、(例えば、オフィス、自宅、特定のオフィス、野球場など)ユーザのすぐ周囲の環境を識別する広範な視覚的な手がかりを含んでもよい。ローカル位置入力は、(例えば、オフィスのコーナー、特定のオフィスの中央、野球場のファーストベース上など)ローカル環境におけるユーザの位置を識別するために、ローカル環境に関連付けられた、より具体的な環境特徴を含んでもよい。オブジェクト入力は、(例えば、取り付けられた写真、名刺、カウチのコーナー、壁金庫の裏、壁のステッカーなど)ユーザのローカル位置から見ることができるローカル環境における特定のオブジェクト又はその特徴に関するデータを含んでもよい。これらの入力のシリーズは、ユーザの認証に使用するための認証データのセットとして使用されてもよい。例えば、ユーザは、カメラを(例えば、スマートフォン、ウェアラブルコンピューティングデバイス、又は他の適切なデバイス上に)所有してもよく、カメラを使用して画像データをキャプチャし、画像がキャプチャされた地理的位置を特定して、コンピューティングシステム100に送信してもよい。次に、コンピューティングシステム100は、地理的位置を使用してユーザが登録されたジオロケーションにいるか否かを識別し、そして、画像データから、ユーザがローカル環境内の正しいローカル位置にいるか否かを判定し、ユーザが特定のオブジェクトを見ているか否かを判定してもよい。例えば、認証は、ユーザが自宅にいて、自宅のオフィスにいて、オフィスの特定の壁にある特定のステッカーを見ることを要求してもよい。
ある場合には、拡張現実の使用が2要素認証の一部として使用されてもよい。このような場合、指定されたジオロケーションの、指定された環境における、指定されたオブジェクトのユーザによる目視の認証は、オブジェクトの目視に加えて提供され認証されるパスワード又は他の情報のような、追加データの提供と組み合わされてもよい。ある実施例では、オブジェクトの目視は、認証の2番目の要素に使用されるデータを明らかにするために使用されてもよい。例えば、ユーザは、カメラ又は他の光学撮像装置を使用して、コンピューティングシステム100に送信される画像データをキャプチャしてもよく、コンピューティングシステム100は、カメラによってキャプチャされ、コンピューティングシステム100に送信されるものを表示するスマートフォンなど、キャプチャされた光学画像のリアルタイム表示をユーザに提供する表示装置を含んでもよい。ユーザがコンピューティングシステム100によって判定された正しいオブジェクトを見ている場合、コンピューティングシステム100は、パスワード又は他のデータを、標準的な拡張現実技術を使用して、正しいオブジェクトに重ねてデータを表示可能な、デバイスに送信してもよい。例えば、上記の例では、パスワードのリストがユーザの自宅のオフィスの特定のステッカーに表示され、ユーザは、リストから適切なパスワードを第2の認証要素として提供してもよい。したがって、ユーザが正しいパスワードを識別することができる唯一の方法は、正しい環境の正しい位置にいて、正しいオブジェクトを見ていることである(パスワードは、例えば、静的であってもよく、或いは、動的で、ユーザへの表示のために送信する前にコンピューティングシステム100によって生成されてもよい)。
ある実施形態では、タイピングヒューリスティックが、コンピューティングシステム100における認証要素として使用されてもよい。コンピューティングシステム100は、そのユーザによって入力されたキーストロークを受け付けるために、コンピューティングシステム100とインタフェース接続された入力装置として、キーボードを含んでもよく、或いは、コンピューティングシステム100は、ユーザの認証要求の一部としてキーストローク情報を受信してもよい。キーストローク情報は、少なくとも、ユーザによってキーボード上で押下されたキーを含んでもよく、また、それぞれのキーストロークに関するタイムスタンプ情報を含んでもよく、(例えば、それぞれのキーを押下するために使用される)タイピング圧力、それぞれのキーストロークの押下及び/又は解放時間(例えば、ユーザがキーを押下し、或いは一旦押下されたキーを解放するのにどれだけの時間がかかるか)などの、任意の他の使用可能な情報を含んでもよい。コンピューティングシステム100は、キーストローク情報を受信し、ユーザのタイピングパターンを識別してもよい(例えば、任意の適切なプロセスを通じてユーザを識別してもよい)。タイピングパターンは、タイピング速度、キーストローク速度、キーストローク圧力、キーストローク間の時間(例えば、一般的なキーストローク、及び/又は、ある特定の文字から別の文字へといった特定のキーストローク)、タイピング精度などの、ユーザのタイピングヒューリスティックの評価であってもよい。タイピングパターンは、ユーザの認証キーを生成するために使用されてもよく、認証キーは、タイピングヒューリスティックをハッシュ化することにより生成される値のような、タイピングパターンを示すデータ値であってもよい。認証キーは、コンピューティングシステム100との後続の相互アクションにおいてユーザを認証するために使用されてもよい。例えば、一例では、タイピングヒューリスティックは、コンピューティングシステム100のユーザ(或いは、例えば、認証のためにコンピューティングシステム100を使用する他の外部デバイスのユーザ)が電子メールを書く任意の時点でキャプチャされてもよい。ユーザが電子メールメッセージのコンテンツをタイプすると、そのキーストロークがキャプチャされ、そのタイピングヒューリスティックが送信前にコンピューティングシステム100によって評価されてもよい。コンピューティングシステム100は、電子メールのタイピングパターンに基づいて新たなキーを生成し、登録プロセス中にユーザのために生成された認証キーと比較してもよい。比較が成功すると、電子メールをタイプしたユーザは、登録ユーザと判定され、電子メールが正常に送信されてもよい。比較が失敗すると、タイプパターンの違いにより他人が登録されたユーザであると主張していることを示すような、認証失敗を示すエラーメッセージが電子メールの代わりに(或いは、例えば、電子メールとともに)送信されてもよい。ある実施例では、タイピングヒューリスティックは、上述のユーザフィンガープリントと組み合わされてもよい。
<例示的なホストコントローラプロセス>
図3は、コンピューティングシステム100におけるデータストレージデバイス106の動作に関して、データストレージデバイス106のホストコントローラ108によって実行されるプロセス300を示す。図3に示すプロセス300は一例であり、ホストコントローラ108がその動作中に追加及び/又は代替のプロセスを使用し得ることは、当業者には明らかであろう。
ステップ302において、ホストコントローラ108は、インタフェース(例えば、ファイルシステムコントローラ122、中継装置118などと通信するためのアプリケーションプログラミングインタフェース)のアクティベーション、記憶ブロック及びセクタの読み出し及びログへの記録、任意のベンダ機能のアクティベーション、コンピューティングシステム100又はネットワーク内の他のコンポーネントとのセキュアチャネルの確立などを含む、プラットホームの初期化を実施してもよい。ステップ304において、データストレージデバイス106の動作のためのホストコントローラ108によるコマンドの標準的な処理を含む、コマンド処理ループが開始されてもよい。
ステップ306において、ホストコントローラ108は、ホストコントローラ108、中継装置118、又はデータをホストコントローラ108と通信する他のデバイスにより検出され得る脅威イベントなどの、セキュリティイベントが発生したか否かを判定してもよい。例えば、脅威イベントは、独立コンポーネントに関連付けられたコマンドの有無、データアクセスリミットへの到達、セキュアチャネルを使用して通信される他のコンピューティングデバイスによる脅威イベントの検出などであってもよい。セキュリティイベントが検出された場合、ステップ308において、ホストコントローラ108は、構成可能な応答テーブルに従って適切な応答を実行してもよい。構成可能な応答テーブルは、検出されたイベントに対する応答のリストを含んでもよく、応答は、例えば、データのバックアップ、データの暗号化、OSアプリケーション120の復元、他のコンピューティングシステム100への通知、データの消去、データへのアクセスの阻止、(例えば、0x00s、ランダムデータなどの)代替のデータの返送を含んでもよい。ホストコントローラ106により追跡されているイベントのプロンプトがある場合、適切な応答が実行されると、セキュリティイベントのプロンプトがリストから除去されてもよい。
脅威イベントではないイベントが発生した場合、ステップ310において、イベント(本明細書ではコマンドパケットとも称される)が解析される。コマンドパケットの解析は、図4に示されるプロセス400を使用して実行されてもよい。ステップ402において、データの読み出し、データの変更、データの上書き、データの移動などのコマンドである、コマンドパケットが審査されてもよい。ステップ404において、ホストコントローラ108は、コマンドの要求者又はそれに関連付けられたアクションなどに基づいて、コマンドのコマンドタイプを判定してもよい。例えば、コマンドは、ファイルシステムコントローラ122から受信した標準読み出しコマンドであってもよく、或いは、データストレージデバイス106の一部としてベンダアクションから発行されたコマンドであってもよい。ステップ406において、ホストコントローラ108は、データストレージデバイス106に向かうデータ、データストレージデバイス106から出てくるデータ、或いは、データストレージデバイス106に出入りするデータなし、というように、コマンドの結果としてデータが流れる方向を判定してもよい。
コマンドパケットが解析されると、ステップ312において、ホストコントローラ108は、(例えば、ステップ404の解析に基づいて)コマンドパケットがベンダコマンドであるか否かを判定してもよい。コマンドパケットがベンダコマンドである場合、ステップ314において、図5に示されるプロセス500が実行されてもよい。ステップ502において、ホストコントローラ108は、その動作が、ベンダコマンドに対応するベンダに関連付けられたモードにあるか否かを判定してもよい。そうではない場合、プロセス500は終了してもよい。あるいは、ホストコントローラ108のモードが、それに応じて調整されてもよい。ホストコントローラ108がベンダモードにある場合、ステップ504において、ベンダコマンドがホストコントローラ108によって実行され、対応するアクションが実行されてもよい。
ステップ312において、コマンドパケットが非ベンダコマンドのものであるとホストコントローラ108が判定した場合、ステップ316において、ホストコントローラ108は、図6に示されるプロセス600を実行してもよい。ステップ602において、コマンドの前に実行されるベンダに関連付けられた任意のプロセスが、ホストコントローラ108によって実行されてもよい。ステップ604において、(例えばコマンドパケットに示されるように)実行されるべきコマンドがパターンエンジンに追加されてもよい。ステップ606において、パターンエンジンは、(例えばコマンドの)パターンが正常であるか否か、及び、(署名、実行されるべきコマンドなどに基づいて)パターンが脅威イベントであることの何らかの兆候を示すか否かを判定するために照会されてもよい。ステップ608において、ホストコントローラ108は、パターンエンジンのチェックが失敗したか否か(例えば、脅威又は異常イベントが検出されたか否か)を判定する。チェックが失敗した場合、ステップ610において、ステップ308に記載されているように、構成可能な応答テーブルに示されるような適切な応答が実行されてもよい。ある場合には、プロセス600は、応答が実行されると完了されてもよい。他の場合、又はチェックが合格した場合、ステップ612において、コマンドパケット内のコマンド(例えばデータ読み出し、書き込み、上書き、変更など)が実行されてもよい。コマンドの実行は、図8に示され、以下で詳細に説明されるプロセス800を使用してもよい。
ステップ614において、コマンド後処理が実行されてもよい。ある場合には、コマンド後処理は、コマンドの実行の結果として生じるような脅威イベントの識別を含んでもよい。脅威イベントが発生した場合、脅威イベントは、適切な応答の実行のために(例えばステップ306で)ホストコントローラ108にフィードバックされてもよい。ステップ616において、コマンドの実行に関するメトリクスがキャプチャされ、後続のイテレーションにおけるステップ606で行われる将来の判定に使用されるためにパターンエンジンにフィードバックされてもよい。
コマンドが処理されると、ステップ318において、ホストコントローラ108は、プロセス300がアイドルであるか否かを判定してもよい。この判定は、例えば、実行を待っている受信されたコマンドのプロンプトリストに基づいてもよく、ホストコントローラ108は、ホストコントローラ108による処理を現在待っているコマンドパケットがない場合にはアイドルであってもよい。ホストコントローラ108がアイドルではない場合、ステップ322において、プロセス300は、ステップ304に戻り、次のコマンドパケットを処理してもよい。
ホストコントローラ108がアイドルである場合、ステップ320において、ホストコントローラ108は、図7に示されるような、アイドルプロセス700を実行してもよい。アイドルプロセスでは、ステップ702において、ホストコントローラ108は、何らかの実行されるべき処理が(例えば古いデータのクリア、データセクタの切り替えなどのために)データストレージデバイス106に記憶されたデータを変更するか否かを判定してもよい。変更が行われる場合、ステップ704において、ホストコントローラ108は、独立コンポーネントのステータス、該当する規則の遵守などに基づいて、このような変更が許可されるか否かを判定してもよい。変更が許可されないが、コマンドに必要である場合、プロセス700は、コマンドを実行せずに完了してもよい。変更が許可される場合、又は変更が必要ではない場合、ステップ706において、ホストコントローラ108は、アイドル処理コマンドを実行してもよい。アイドル処理コマンドは、例えば、ガーベッジコレクション、古い又はインアクティブなブロックのクリア、パターンエンジンの更新、及び当業者には明らかな他のアクションを含んでもよい。
ホストコントローラ108によるコマンドの実行は、図8に示されるプロセス800を使用してもよい。ステップ802において、ホストコントローラ108は、(例えばステップ406で判定されるように)コマンドが読み出しコマンドであるか否かを判定する。コマンドが読み出しコマンドである場合、ステップ804において、ホストコントローラ108は、ユーザ制限、ユーザパーミッション、独立コンポーネント状態などに基づいて、データの読み出しが現在許可されるか否かを判定してもよい。読み出しが許可されない場合、ステップ806において、ホストコントローラ108は、試みられた読み出しアクセスがログに記録されるべきか否かを判定してもよい。このような判定は、コンピューティングシステム100のオペレータ、データストレージデバイス106の製造者、コマンドの性質などにより行われる、ホストコントローラ108の設定に基づいてもよい。アクセスがログに記録されるべきではない場合、プロセス800は完了されてもよい。アクセスがログに記録されるべきである場合、ステップ808において、試みられた読み出しコマンドは、ホストコントローラ108において(或いは、例えば中継装置118のSATAドライブ210などの他の適切なコンポーネントにおいて)ログに記録されてもよい。
ステップ804において、読み出しが許可されるとホストコントローラ108が判定した場合、ステップ810において、ホストコントローラ108は、アクションの実行がログに記録されるべきか否かを判定してもよい。そうであれば、ステップ812において、ホストコントローラ108は(或いは、例えば他の適切なコンポーネントは)、コマンドの実行をログに記録してもよい。ステップ814において、ホストコントローラ108は、読み出されるデータが(例えば、コマンドパケットに示されるなどにより)返される前に変更されるべきか否かを判定してもよい。データが変更される場合、ステップ816において、データはそれに応じて変更されてもよい。データが変更された場合、或いは、変更が行われなかった場合、ステップ818において、データは、ファイルシステムコントローラ122又はコマンドパケットに示される他の該当するコンポーネントに返され、プロセス800が完了してもよい。
ステップ802において、コマンドパケットがデータの読み出しに関するものではないとホストコントローラ108が判定した場合、ステップ820において、ホストコントローラ108は、コマンドパケットがデータの書き込みに関するものであるか否かを判定してもよい。コマンドパケットがデータの読み出し又は書き込みを行わないコマンドに関するものである場合、ステップ822において、ホストコントローラ108によって、データなし(non-data)コマンドが実行されてもよい。コマンドがデータの書き込みを伴う場合、ステップ824において、ホストコントローラ108は、上述のように、対応するデータへの変更が許可される否かを判定してもよい。変更が許可されない場合、ステップ826及び828において、ホストコントローラ108は、試みられた変更がログに記録されるべきか否かを判定し、それに応じて処理を進めてもよい。
変更が許可される場合、ステップ830において、ホストコントローラ108は、変更がログに記録されるべきか否かを判定してもよく、そうであれば、ステップ832において、実行される変更をログに記録してもよい。ステップ834において、ホストコントローラ108は、変更されるデータが変更前にバックアップされるべきか否かを判定してもよい。このような判定は、コマンドのタイプ、ホストコントローラ108で設定されたポリシー、脅威イベントとしてのコマンドパケットの検出などに基づいてもよい。バックアップが実行される場合、ステップ836において、ホストコントローラ108は、データをデータストレージデバイス106内の所定のブロック及び/又はセクタにコピーすることなどにより、変更されるデータをバックアップしてもよい。バックアップが完了した場合、又はバックアップが実行されない場合、ステップ838において、ホストコントローラ108は、対応するデータブロック又はセクタへの変更を実行して、コマンドパケットに示されるとおりに、データの書き込みを達成してもよい。
<コンピュータシステムアーキテクチャ>
図9は、本開示の実施形態又はその一部がコンピュータ可読コードとして実装され得るコンピュータシステム900を示す。例えば、図1のコンピューティングシステム100は、ハードウェア、ソフトウェア、ファームウェア、命令を記憶した非一時的コンピュータ可読媒体、又はそれらの組み合わせを使用してコンピュータシステム900に実装されてもよく、1つ以上のコンピュータシステム又は他の処理システムに実装されてもよい。ハードウェア、ソフトウェア、又はそれらの任意の組合せにより、図3〜図8の方法を実施するために使用されるモジュール及びコンポーネントが具現化されてもよい。
プログラマブルロジックが使用される場合、このようなロジックは、専用のコンピュータ又は専用のデバイスとなるように、実行可能なソフトウェアコードによって構成された市販の処理プラットホーム上(例えばプログラマブルロジックアレイ、特定用途向け集積回路など)で実行されてもよい。開示された主題の実施形態が、マルチコアマルチプロセッサシステム、ミニコンピュータ、メインフレームコンピュータ、分散機能を用いてリンク又はクラスタ化されたコンピュータ、並びに、実質的に任意のデバイスに組み込まれ得るパーベイシブ又はミニチュアコンピュータを含む、様々なコンピュータシステム構成で実施され得ることは、当業者であれば理解されよう。例えば、少なくとも1つのプロセッサデバイス及びメモリを使用して、上述の実施形態が実装されてもよい。
本明細書で説明されるプロセッサユニット又はデバイスは、単一のプロセッサ、複数のプロセッサ、又はそれらの組み合わせとされてもよい。プロセッサデバイスは、1つ以上のプロセッサ「コア」を有してもよい。本明細書で論じられる「コンピュータプログラム媒体」、「非一時的コンピュータ可読媒体」、及び「コンピュータ使用可能媒体」という用語は、一般に、リムーバブルストレージユニット918、リムーバブルストレージユニット922、及びハードディスクドライブ912に設置されるハードディスクのような、有形媒体を指すために使用される。
本開示の様々な実施形態は、この例示的なコンピュータシステム900に関連付けて説明されている。本説明を読んだ後、他のコンピュータシステム及び/又はコンピュータアーキテクチャを使用して、どのように本開示を実装するかは、当業者には明らかになるであろう。動作は連続的なプロセスとして記述されてもよいが、動作のいくつかは実際には並列、同時、及び/又は分散環境において実行されてもよく、シングル又はマルチプロセッサマシンによるアクセスのためにローカル又はリモートに記憶されたプログラムコードを用いて実行されてもよい。さらに、ある実施形態では、動作の順序は、開示された主題の趣旨から逸脱することなく再構成されてもよい。
プロセッサデバイス904は、本明細書で説明される機能を実行するように特に構成された、専用又は汎用プロセッサデバイスであってもよい。プロセッサデバイス904は、バス、メッセージキュー、ネットワーク、マルチコアメッセージパッシングスキームなどの、通信インフラストラクチャ906に接続されてもよい。ネットワークは、本明細書で開示されるような機能を実行するのに適した任意のネットワークであってもよく、ローカルエリアネットワーク(LAN)、ワイドエリアネットワーク(WAN)、ワイヤレスネットワーク(例えば、WiFi)、移動体通信網、衛星ネットワーク、インターネット、光ファイバ、同軸ケーブル、赤外線、無線周波数(RF)、又はそれらの任意の組合せを含んでもよい。他の適切なネットワークのタイプ及び構成は、当業者には明らかであろう。コンピュータシステム900は、メインメモリ908(例えば、ランダムアクセスメモリ、リードオンリーメモリなど)を含んでもよく、セカンダリメモリ910を含んでもよい。セカンダリメモリ910は、ハードディスクドライブ912と、フロッピーディスクドライブ、磁気テープドライブ、光ディスクドライブ、フラッシュメモリなどのリムーバブルストレージドライブ914と、を含んでもよい。
リムーバブルストレージドライブ914は、周知の方法で、リムーバブルストレージユニット918への読み出し及び/又は書き込みを実施可能であってもよい。リムーバブルストレージユニット918は、リムーバブルストレージドライブ914によって読み出し及び書き込みされ得る、取り外し可能な記憶媒体を含んでもよい。例えば、リムーバブルストレージデバイス914がフロッピーディスクドライブ又はユニバーサルシリアルバスポートである場合、リムーバブルストレージユニット918は、それぞれフロッピーディスク又はポータブルフラッシュドライブであってもよい。一実施形態では、リムーバブルストレージユニット918は、非一時的コンピュータ可読記録媒体であってもよい。
ある実施形態では、セカンダリメモリ910は、例えばリムーバブルストレージユニット922及びインタフェース920など、コンピュータプログラム又は他の命令をコンピュータシステム900にロードすることを可能にする代替手段を含んでもよい。このような手段の例は、当業者には明らかなように、(例えばビデオゲームシステムに見られるような)プログラムカートリッジ及びカートリッジインタフェース、(例えばEEPROM、PROMなどの)リムーバブルメモリチップ及び関連付けられたソケット、並びに他のリムーバブルストレージユニット922及びインタフェース920を含んでもよい。
コンピュータシステム900に(例えば、メインメモリ908及び/又はセカンダリメモリ910に)記憶されるデータは、光学ストレージ(例えば、コンパクトディスク、デジタルバーサタイルディスク、ブルーレイディスク等)又は磁気テープストレージ(例えば、ハードディスクドライブ)のような、任意のタイプの適切なコンピュータ可読媒体に記憶されてもよい。データは、リレーショナルデータベース、ストラクチャードクエリランゲージ(SQL)データベース、分散データベース、オブジェクトデータベースなど、任意のタイプの適切なデータベース構成で構成されてもよい。好適な構成及びストレージタイプは、当業者には明らかであろう。
コンピュータシステム900は、通信インタフェース924を含んでもよい。通信インタフェース924は、コンピュータシステム900と外部デバイスとの間でソフトウェア及びデータを転送可能にするように構成されてもよい。例示的な通信インタフェース924は、モデム、ネットワークインタフェース(例えば、イーサネットカード)、通信ポート、PCMCIAスロット及びカードなどを含んでもよい。通信インタフェース924を介して転送されるソフトウェア及びデータは、当業者には明らかなように、電子的、電磁気的、光学的、又は他の信号などの、信号の形態であってもよい。信号は、信号を伝送するように構成され、ワイヤ、ケーブル、光ファイバ、電話回線、携帯電話リンク、無線周波数リンクなどを使用して実施され得る、通信パス926を介して移動してもよい。
コンピュータシステム900は、表示インタフェース902を更に含んでもよい。表示インタフェース902は、コンピュータシステム900と外部ディスプレイ930との間でデータを転送可能にするように構成されてもよい。例示的なディスプレイインタフェース902は、高精細度マルチメディアインタフェース(HDMI)、デジタルビジュアルインタフェース(DVI)、ビデオグラフィックスアレイ(VGA)などを含んでもよい。ディスプレイ930は、陰極線管(CRT)ディスプレイ、液晶ディスプレイ(LCD)、発光ダイオード(LED)ディスプレイ、静電容量タッチディスプレイ、薄膜トランジスタ(TFT)ディスプレイなどを含む、コンピュータシステム900の表示インタフェース902を介して送信されるデータを表示するための任意の適切なタイプのディスプレイであってもよい。
コンピュータプログラム媒体及びコンピュータ使用可能媒体は、メモリ半導体(例えばDRAMなど)であり得る、メインメモリ908及びセカンダリメモリ910などのメモリを指してもよい。これらのコンピュータプログラム製品は、コンピュータシステム900にソフトウェアを提供するために手段である。コンピュータプログラム(例えば、コンピュータ制御ロジック)は、メインメモリ908及び/又はセカンダリメモリ910に記憶されてもよい。コンピュータプログラムは、通信インタフェース924を介して受信されてもよい。このようなコンピュータプログラムは、実行されると、コンピュータシステム900が本明細書で論じられる本方法を実施できるようにしてもよい。具体的には、コンピュータプログラムは、実行されると、本明細書で説明すされるように、プロセッサデバイス904が図3〜図8に示される方法を実施できるようにしてもよい。したがって、このようなコンピュータプログラムは、コンピュータシステム900のコントローラを表してもよい。本開示がソフトウェアを使用して実装される場合、ソフトウェアは、コンピュータプログラム製品に記憶され、リムーバブルストレージドライブ914、インタフェース920、及びハードディスクドライブ912、又は通信インタフェース924を使用して、コンピュータシステム900にロードされてもよい。
プロセッサデバイス904は、コンピュータシステム900の機能を実行するように構成された1つ以上のモジュール又はエンジンを備えてもよい。モジュール又はエンジンのそれぞれは、ハードウェアを使用して実装されてもよく、ある実施例では、メインメモリ908又はセカンダリメモリ910に記憶されたプログラムコード及び/又はプログラムに対応するようなソフトウェアを使用してもよい。このような場合、プログラムコードは、コンピュータシステム900のハードウェアによる実行の前に、プロセッサデバイス904(例えばコンパイルモジュール又はエンジン)によってコンパイルされてもよい。例えば、プログラムコードは、プロセッサデバイス904及び/又はコンピュータシステム900の任意の追加のハードウェアコンポーネントによる実行のために、アセンブリ言語又はマシンコードのような下位言語(lower level language)に翻訳されるプログラミング言語で書かれたソースコードであってもよい。コンパイルのプロセスは、語彙分析、前処理、構文解析、意味解析、構文指向翻訳、コード生成、コード最適化、及び本明細書に開示される機能を実行するためにコンピュータシステム900を制御するのに適した下位言語へのプログラムコードの翻訳に適している他の任意の技術の使用を含んでもよい。このようなプロセスの結果、コンピュータシステム900が、上述の機能を実行するように一意にプログラムされた、特別に構成されたコンピュータシステム900になることは、当業者には明らかであろう。
本開示と整合性のある技術は、特に、データアクセスの監視及び制御のシステム及び方法を提供する。開示されたデバイス及び方法の様々な例示的な実施形態が上述されたが、限定ではなく、単に例示の目的のために提示されたことを理解されるべきである。これは網羅的ではなく、開示された厳密な形態に限定するものではない。上記の教示に照らして、変更及び変形が可能であり、あるいは、本開示の実施から、その範囲又はスコープから逸脱することなく、変更及び変形を得ることができる。

Claims (134)

  1. データフローを制御する方法であって、
    コンピューティングシステム内のデータストレージデバイスのホストコントローラにより、前記コンピューティングシステムによって実行されるオペレーティングシステムのファイルシステムコントローラによって送信されるデータ要求コマンドを受信することと、
    前記コンピューティングシステムにおいて、前記オペレーティングシステムのユーザを識別することと、
    前記コンピューティングシステムにおいて、前記識別されたユーザに関連付けられたユーザパーミッションを識別すること、
    前記ホストコントローラにより、前記識別されたユーザパーミッションに基づいてデータの取得を制御することと、
    前記ホストコントローラにより、前記データ要求コマンドに応答して、前記取得されたデータを前記ファイルシステムコントローラに送信することと、を含む、方法。
  2. 前記取得されたデータは、前記識別されたユーザパーミッションに基づいて前記ユーザによる閲覧が許可されていないデータを含まない、請求項1に記載の方法。
  3. 前記取得されたデータは、前記識別されたユーザパーミッションに基づいて前記ユーザによる閲覧が許可されていないデータのサブセットを含み、
    前記ファイルシステムコントローラは、前記オペレーティングシステムの前記ユーザに、前記データのサブセットを提示しない、請求項1に記載の方法。
  4. 前記ホストコントローラは、前記識別されたユーザパーミッションに基づいて、前記データストレージデバイスに記憶されたデータの変更を阻止する、請求項1に記載の方法。
  5. オペレーティングシステムの自動復元の方法であって、
    コンピューティングシステムのデータストレージデバイスにおいて、第1のデータセクタに第1のオペレーティングシステムファイルのセットを記憶することと、
    前記コンピューティングシステムの前記データストレージデバイスにおいて、第2のデータセクタに第2のオペレーティングシステムファイルのセットを記憶することと、
    前記データストレージデバイスのホストコントローラにより、復元コマンドを受信することと、
    前記データストレージデバイスの前記ホストコントローラにより、前記第1のオペレーティングシステムファイルのセットのデータ取得要求を受信することと、
    前記データストレージデバイスの前記ホストコントローラにより、前記データ取得要求に前記第2のオペレーティングシステムファイルのセットを応答することと、を含む、方法。
  6. 前記データストレージデバイスの前記ホストコントローラにより、前記第1のデータセクタ内の前記第1のオペレーティングシステムファイルのセットを前記第2のオペレーティングシステムファイルのセットで上書きすることを更に含む、請求項5に記載の方法。
  7. 前記上書きすることは、前記データストレージデバイスのアイドルサイクル中に実行される、請求項6に記載の方法。
  8. 前記コンピューティングシステムのメモリに、前記データストレージデバイスで実行された動作の変更ログを記憶することと、
    前記データストレージデバイスの前記ホストコントローラにより、前記変更ログに示される、前記データストレージデバイスで実行された前記動作を逆行させることを更に含む、請求項5に記載の方法。
  9. 前記データストレージデバイスで実行された前記動作は、前記第1のデータセクタに記憶された前記第1のオペレーティングシステムファイルのセットを変更する、請求項8に記載の方法。
  10. データをバックアップする方法であって、
    コンピューティングシステムにおけるデータストレージデバイスのホストコントローラにより、前記コンピューティングシステムにおける脅威イベントのインディケーションを受信することと、
    前記ホストコントローラにより、前記脅威イベントを遅延させることと、
    前記ホストコントローラにより、前記データストレージデバイス内の1つ以上のデータファイルをバックアップすることと、
    前記1つ以上のデータファイルのバックアップの完了後、前記ホストコントローラにより、前記脅威イベントを許可することと、を含む、方法。
  11. 前記脅威イベントは、前記1つ以上のデータファイルに脅威をもたらす、請求項10に記載の方法。
  12. 前記1つ以上のデータファイルは、前記コンピューティングシステムのユーザによってバックアップのために予め選択される、請求項10に記載の方法。
  13. 前記1つ以上のデータファイルは、前記データストレージデバイスの所定の位置に前記1つ以上のデータファイルを記憶することによりバックアップされる、請求項10に記載の方法。
  14. 前記脅威イベントは、前記1つ以上のデータファイルの削除又は変更である、請求項10に記載の方法。
  15. コンピューティングネットワークにおいて相互接続されたセキュリティを提供する方法であって、
    コンピューティングネットワークにより、第1の通信チャネルのシリーズを使用する複数のコンピューティングデバイスを接続することと、
    前記複数のコンピューティングデバイスのそれぞれにより、前記複数のコンピューティングデバイス内の他のコンピューティングデバイスのそれぞれと、代替の安全な通信チャネルを第2の通信チャネルのシリーズとして確立することと、
    前記複数のコンピューティングデバイスのうちの1つにより、前記コンピューティングネットワーク又は前記複数のコンピューティングデバイスのうちの前記1つに対する脅威を示す脅威イベントを検出することと、
    前記複数のコンピューティングデバイスのうちの前記1つにより、前記第2の通信チャネルのシリーズを用いて、前記複数のコンピューティングデバイス内の前記他のコンピューティングデバイスのそれぞれに、前記検出された脅威イベントの通知を送信することと、を含む、方法。
  16. 前記第1の通信チャネルのシリーズは、第1の通信プロトコルを使用し、
    前記第2の通信チャネルのシリーズは、第2の通信プロトコルを使用する、請求項15に記載の方法。
  17. 前記第1の通信チャネルのシリーズ及び前記第2の通信チャネルのシリーズは、共通の通信プロトコルを使用し、
    前記第2の通信チャネルのシリーズは、1つ以上の暗号化ツールを使用する、請求項15に記載の方法。
  18. 前記複数のコンピューティングデバイスのそれぞれにおいて、前記第1の通信チャネルのシリーズを無効にすることを更に含む、請求項15に記載の方法。
  19. 異常なシステムアクティビティを検出する方法であって、
    コンピューティングシステム内のデータストレージデバイスのホストコントローラにより、前記コンピューティングシステムのユーザによって実行された複数のアクションを経時的にログに記録することと、
    前記ホストコントローラにより、前記ログに記録された複数のアクションに基づいて、使用アクションのセットを含む、前記ユーザのユーザフィンガープリントを判定することと、
    前記ホストコントローラにより、コンピューティングデバイスを使用して実行される複数の新たなアクションを監視することと、
    前記ホストコントローラにより、前記複数の新たなアクションと前記使用アクションのセットとの比較に基づいて、異常なシステムアクティビティを検出することと、
    前記ホストコントローラにより、前記検出された異常なシステムアクティビティの結果として、前記コンピューティングシステム内の脅威イベントの通知をトリガすることと、を含む、方法。
  20. 前記複数のアクションは、前記データストレージデバイスに記憶されたデータに影響を及ぼすアクションである、請求項19に記載の方法。
  21. 前記使用アクションのセットは、ランサムウェア攻撃に関連付けられ、
    前記複数の新たなアクションは、前記使用アクションのセットに一致する、請求項19に記載の方法。
  22. 前記複数の新たなアクションは、前記使用アクションのセットに含まれない所定の数のアクションを含む、請求項19に記載の方法。
  23. データアクセスを制御する方法であって、
    コンピューティングシステム内のハードウェアデバイスにより、前記コンピューティングシステム内のデータストレージデバイスのホストコントローラとの第1の通信チャネルを確立することと、
    前記ハードウェアデバイスにより、前記コンピューティングシステム内の別のデバイスとの第2の通信チャネルを確立することと、
    前記ハードウェアデバイスの受信機により、前記第2の通信チャネルを使用して、前記別のデバイスからのデータ要求を受信することと、
    前記ハードウェアデバイスのメモリに、前記受信されたデータ要求を記憶することと、
    前記ハードウェアデバイスの送信機により、前記第1の通信チャネルを使用して、前記受信されたデータ要求を前記ホストコントローラに転送することと、を含む、方法。
  24. 前記ハードウェアデバイスは、前記ホストコントローラに送信されたすべてのデータ信号をインターセプトする、請求項23に記載の方法。
  25. 前記ハードウェアデバイスは、コンピューティングデバイスにおいて、前記データストレージデバイスと前記コンピューティングデバイス内の1つ以上の追加のコンポーネントとの間に物理的に接続される、請求項23に記載の方法。
  26. 前記データストレージデバイスは、前記コンピューティングデバイス内の追加のコンポーネントに接続されない、請求項25に記載の方法。
  27. データアクセスを制御する方法であって、
    コンピューティングシステム内のデータストレージデバイスのホストコントローラのメモリに、1つ以上の確立された規則を記憶することと、
    前記ホストコントローラの受信機により、データコマンドと1つ以上の影響を受けるデータ項目とを示す、データアクション要求を受信することと、
    前記ホストコントローラにより、前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することと、
    前記データアクション要求が遵守している場合に、前記ホストコントローラにより、前記1つ以上の影響を受けるデータ項目に対する前記データコマンドを実行することと、
    前記データアクション要求が遵守していない場合に、前記ホストコントローラの送信機により、前記1つ以上の影響を受けるデータ項目に対する阻止されたアクセスを示す、前記データアクション要求に対する応答を送信することと、を含む、方法。
  28. 前記1つ以上の確立された規則のそれぞれは、複数のデータコマンドのうちの1つに関連付けられ、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することは、前記データアクション要求が、前記1つ以上の確立された規則のうち、前記データアクション要求に示される前記データコマンドに関連付けられた規則を遵守しているか否かを判定することを含む、請求項27に記載の方法。
  29. 前記1つ以上の確立された規則は、地理的領域を含み、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することは、前記コンピューティングシステムが前記地理的領域内にあるか否かを判定することを含む、請求項27に記載の方法。
  30. 前記判定することは、前記コンピューティングシステムとインタフェース接続された全地球測位デバイスから地理的位置を受信することを含む、請求項29に記載の方法。
  31. 前記1つ以上の確立された規則は、セキュリティデバイスの存在を要求する規則を含み、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することは、前記コンピューティングシステム内の前記セキュリティデバイスの存在を検出することを含む、請求項27に記載の方法。
  32. データの使用を監視する方法であって、
    コンピューティングシステムのデータストレージデバイスに、複数のデータ項目及び1つ以上のデータアクセス制限を記憶することと、
    前記データストレージデバイスのホストコントローラにより、前記複数のデータ項目内のデータ項目を前記コンピューティングシステム内の1つ以上のホストデバイスに転送するために、前記ホストコントローラによって受信された複数のデータアクセスアクションを実行することと、
    前記データストレージデバイスのデバイスコントローラにより、前記複数のデータアクセスアクションの実行中に前記データストレージデバイスから前記1つ以上のホストデバイスに転送されたデータ量を検出することと、
    前記データストレージデバイスから転送された前記データ量が前記1つ以上のデータアクセス制限に達したか超えた場合に、前記デバイスコントローラにより、新たなデータアクセスアクションの実行を阻止することと、を含む、方法。
  33. 前記デバイスコントローラ及び前記ホストコントローラは、単一のコンポーネントである、請求項32に記載の方法。
  34. 前記デバイスコントローラは、前記データストレージデバイスのファイルシステムレベルで動作する、請求項32に記載の方法。
  35. 前記1つ以上のデータアクセス制限は、データタイプ、データ量、及びデータの記憶セクタのうちの少なくとも1つを指定する、請求項32に記載の方法。
  36. データ保護をトリガする方法であって、
    コンピューティングシステム内のデータストレージデバイスのストレージプラットホームコントローラとインタフェース接続された入力回路により、所定のコマンドのパフォーマンスを検出することと、
    前記ストレージプラットホームコントローラにより、前記検出されたパフォーマンスの結果として、所定のアクションを実行することと、を含み、
    前記入力回路は、前記データストレージデバイスのホストコントローラとインタフェース接続されない、方法。
  37. 前記所定のコマンドは、前記入力回路とインタフェース接続された1つ以上のハードウェア要素を使用して実行される物理アクションである、請求項36に記載の方法。
  38. 前記物理アクションは、ボタンを押すこと、前記1つ以上のハードウェア要素のうちの1つを振ること、音声コマンドを話すこと、又はスイッチをトグルすることのうちの1つを含む、請求項37に記載の方法。
  39. 前記所定のアクションは、前記データストレージデバイスに記憶されたデータを消去すること、前記データストレージデバイスに記憶されたデータを暗号化すること、及び前記データストレージデバイスに記憶されたデータへのアクセスを阻止することのうちの1つである、請求項36に記載の方法。
  40. 前記データストレージデバイスに記憶された前記データは、前記所定のアクションの一部として定義される、請求項39に記載の方法。
  41. データストレージアクセスを追跡する方法であって、
    コンピューティングシステム内のデータストレージデバイスのメモリに、前記データストレージデバイス内の記憶範囲のリストと、監視される記憶範囲のセットであって、前記監視される記憶範囲のセット内の監視される記憶範囲のそれぞれが前記記憶範囲のリスト内の前記記憶範囲内にある、監視される記憶範囲のセットと、を記憶することと、
    ホストコントローラの受信機により、データコマンド及び影響を受けるデータ項目を含むデータアクション要求を、前記コンピューティングシステム内のホストデバイスから受信することと、
    前記ホストコントローラにより、前記データコマンドを実行することと、
    前記ホストコントローラにより、前記影響を受けるデータ項目の記憶位置であって、前記監視される記憶範囲のセットのうちの1つに含まれる記憶位置を識別することと、
    前記データストレージデバイス内のデータアクセスログに、前記監視される記憶範囲のセットのうちの前記1つへのアクセスを示すログエントリを記憶することと、を含む、方法。
  42. 前記ログエントリは、前記データコマンドと、前記影響を受けるデータ項目のインディケーションとを更に含む、請求項41に記載の方法。
  43. 前記ログエントリは、タイムスタンプと、前記コンピューティングシステムのユーザに関連付けられたユーザ情報とを更に含む、請求項41に記載の方法。
  44. 前記データアクセスログは、前記データストレージデバイスの前記メモリに記憶される、請求項41に記載の方法。
  45. 前記データストレージデバイスの前記メモリは、前記影響を受けるデータ項目を記憶するために使用される記憶領域とは別である、請求項41に記載の方法。
  46. 使用されないフラッシュメモリをクリアする方法であって、
    コンピューティングシステム内のフラッシュメモリ・ストレージデバイスに、それぞれのデータ記憶ブロックが1つ以上のデータ項目を記憶可能である、複数のデータ記憶ブロックを記憶することと、
    前記フラッシュメモリ・ストレージデバイスのホストコントローラにおいて、前記複数のデータ記憶ブロックのうちの1つ以上のインアクティブなブロックを検出することと、
    前記ホストコントローラにより、前記検出された1つ以上のインアクティブなブロックにおいてデータ除去のための1つ以上のアクションを実行することと、を含む、方法。
  47. データ除去のための前記1つ以上のアクションは、所定の期間に実行される、請求項46に記載の方法。
  48. データ除去のための前記1つ以上のアクションは、前記フラッシュメモリ・ストレージデバイスのアイドルサイクル中に実行される、請求項46に記載の方法。
  49. 前記1つ以上のアクションは、前記1つ以上のインアクティブなブロックのデータを解読不可能なデータで上書きすることを含む、請求項46に記載の方法。
  50. データ除去のための前記1つ以上のアクションは、前記ホストコントローラの受信機によって受信される、前記コンピューティングシステムのユーザによるコマンド入力の受信時に実行される、請求項46に記載の方法。
  51. 使用されないフラッシュメモリをクリアする方法であって、
    コンピューティングシステムのフラッシュメモリ・ストレージデバイスにおいて、ウェアレベリング・プロセスを実行することと、
    前記フラッシュメモリ・ストレージデバイス内のホストコントローラにより、前記フラッシュメモリ・ストレージデバイス内の1つ以上のブロックを識別することであって、前記ウェアレベリング・プロセスの一部として、新たなデータが前記1つ以上のブロックに転送されずに、古いデータが前記1つ以上のブロックから転送されることと、
    前記ホストコントローラにより、前記識別された1つ以上のブロックにおいてデータ除去のための1つ以上のアクションを実行することと、を含む、方法。
  52. データ除去のための前記1つ以上のアクションは、所定の期間に実行される、請求項51に記載の方法。
  53. データ除去のための前記1つ以上のアクションは、前記フラッシュメモリ・ストレージデバイスのアイドルサイクル中に実行される、請求項51に記載の方法。
  54. 前記1つ以上のアクションは、前記1つ以上のインアクティブなブロックのデータを解読不可能なデータで上書きすることを含む、請求項51記載の方法。
  55. データ除去のための前記1つ以上のアクションは、前記ホストコントローラの受信機によって受信される、前記コンピューティングシステムのユーザによるコマンド入力の受信時に実行される、請求項51に記載の方法。
  56. データアクセスを制御する方法であって、
    コンピューティングシステムのデータストレージデバイスのメモリに、それぞれのデータアクセス規則が、(i)1つ以上のデータファイル、又は(ii)前記データストレージデバイスのセクタ/ブロック範囲を指定し、第1の認証要素、第2の認証要素、及び時間範囲を含む、複数のデータアクセス規則を記憶することと、
    前記データストレージデバイスのホストコントローラの受信機により、前記コンピューティングシステム内のホストデバイスからのデータアクション要求であって、データコマンド及び影響を受けるデータ項目を含むデータアクション要求を受信することと、
    前記ホストコントローラにより、該当するデータアクセス規則に含まれる前記1つ以上のデータファイルと一致する、或いは前記該当するデータアクセス規則に含まれる前記セクタ/ブロック範囲に記憶されている、前記影響を受けるデータ項目に基づいて、前記該当するデータアクセス規則を識別することと、
    前記ホストコントローラの送信機により、前記該当するデータアクセス規則内の前記第1の認証要素を使用する第1の認証要求を送信することと、
    前記ホストコントローラの前記送信機により、前記該当するデータアクセス規則内の前記第2の認証要素を使用する第2の認証要求を送信することと、
    前記ホストコントローラの前記受信機により、認証成功を示す前記第1の認証要求に対する第1の応答と、認証成功を示す前記第2の認証要求に対する第2の応答とを受信することと、
    前記ホストコントローラにより、前記受信された第1の応答と、前記受信された第2の応答と、前記該当するデータアクセス規則に含まれる前記時間範囲内の前記データアクション要求の受信とに基づいて、前記該当するデータアクセス規則の遵守を判定することと、
    前記ホストコントローラにより、前記データアクション要求に含まれる前記データコマンドを実行することと、を含む、方法。
  57. 前記第1の認証要素は、前記コンピューティングシステムのユーザが前記コンピューティングシステムに既知のデータ値を入力することを要求し、
    前記第2の認証要素は、前記コンピューティングシステムとインタフェース接続されるセキュリティデバイスの存在を要求する、請求項56に記載の方法。
  58. 前記第1の認証要素は、パスワード及びセキュリティコードのうちの少なくとも1つを使用する、請求項57に記載の方法。
  59. 前記セキュリティデバイスは、セキュリティドングル及びバイオメトリックスキャナのうちの1つである、請求項57に記載の方法。
  60. 前記該当するデータアクセス規則に含まれる前記時間範囲は、時刻、曜日、及び月日のうちの少なくとも1つを含む、請求項56に記載の方法。
  61. 拡張現実を用いた認証方法であって、
    コンピューティングシステムのメモリに、少なくとも地理的位置、位置データ、及びオブジェクトデータを含む、第1の認証データのセットを記憶することと、
    前記コンピューティングシステムの受信機により、光学撮像装置によってキャプチャされた画像データと前記光学撮像装置の地理的座標とを少なくとも含む、認証要求を受信することと、
    前記コンピューティングシステムの処理装置により、(i)前記地理的座標が前記地理的位置から所定の距離内にあること、(ii)前記画像データが前記位置データに対応する物理的領域のキャプチャであること、及び(iii)前記画像データが前記オブジェクトデータに対応する物理的オブジェクトの画像を含むことを判定することと、
    前記コンピューティングシステムの送信機により、前記受信された認証要求に応答して認証成功のインディケーションを送信することと、を含む、方法。
  62. 前記コンピューティングシステムの前記メモリに、パスワードを含む、第2の認証データのセットを記憶することを更に含み、
    前記認証要求は、提供されたデータ値を更に含み、
    前記判定することは、(iv)前記提供されたデータ値が前記パスワードに対応することを判定することを更に含む、請求項61に記載の方法。
  63. 前記コンピューティングシステムの前記メモリに、受け入れられたパスワードを含むパスワードのリストを含む、第2の認証データのセットを記憶することと、
    前記コンピューティングシステムの前記送信機により、前記認証要求に応答して前記パスワードのリストを送信することと、
    前記コンピューティングシステムの前記受信機により、前記送信されたパスワードのリストに応答して、提供されたデータ値を受信することと、
    前記コンピューティングシステムの前記処理装置により、前記提供されたデータ値が前記受け入れられたパスワードに対応することを判定することと、を更に含み、
    前記提供されたデータ値が前記受け入れられたパスワードに対応すると判定された後に、前記認証成功のインディケーションが送信される、請求項61に記載の方法。
  64. タイピングヒューリスティックによるユーザ認証の方法であって、
    コンピューティングシステムとインタフェース接続された入力装置により、前記コンピューティングシステムのユーザによって入力された複数のキーストロークを受信することと、
    前記コンピューティングシステムの処理装置により、前記受信された複数のキーストロークに基づいてタイピングパターンを検出することと、
    前記コンピューティングシステムの前記処理装置により、前記検出されたタイピングパターンに基づいて、前記ユーザに関連付けられた認証キーを生成することと、
    前記コンピューティングシステムとインタフェース接続された前記入力装置により、データメッセージを含む、新たなキーストロークのセットを受信することと、
    前記コンピューティングシステムの前記処理装置により、前記受信された新たなキーストロークのセットに基づいて、新たなキーを生成することと、
    前記コンピューティングシステムの前記処理装置により、前記新たなキーと前記認証キーとの比較に基づいて、前記データメッセージを認証することと、
    前記コンピューティングシステムの送信機により、(i)前記認証が成功した場合には前記データメッセージを含み、(ii)前記認証が失敗した場合には認証失敗を示す通知を含む、データ信号を、外部システムに送信することと、を含む、方法。
  65. 前記データメッセージは、電子メールメッセージである、請求項64に記載の方法。
  66. 前記タイピングパターンは、タイピング速度、タイピング精度、キーストローク圧力、及び特定のキーストローク間の時間のうちの少なくとも1つを含むヒューリスティックを含む、請求項64に記載の方法。
  67. 認証失敗を示す前記通知は、前記データメッセージを更に含む、請求項64に記載の方法。
  68. データフローを制御するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記コンピューティングシステムは、
    ファイルシステムコントローラを含むオペレーティングシステムを実行し、
    前記オペレーティングシステムのユーザを識別し、
    前記識別されたユーザに関連付けられたユーザパーミッションを識別するように構成され、
    前記データストレージデバイスは、ホストコントローラを含み、
    前記ホストコントローラは、
    前記ファイルシステムコントローラによって送信されたデータ要求コマンドを受信し、
    前記識別されたユーザパーミッションに基づいてデータの取得を制御し、
    前記データ要求コマンドに応答して、前記取得されたデータを前記ファイルシステムコントローラに送信するように構成されている、システム。
  69. 前記取得されたデータは、前記識別されたユーザパーミッションに基づいて前記ユーザによる閲覧が許可されていないデータを含まない、請求項68に記載のシステム。
  70. 前記取得されたデータは、前記識別されたユーザパーミッションに基づいて前記ユーザによる閲覧が許可されていないデータのサブセットを含み、
    前記ファイルシステムコントローラは、前記オペレーティングシステムの前記ユーザに、前記データのサブセットを提示しない、請求項68に記載のシステム。
  71. 前記ホストコントローラは、前記識別されたユーザパーミッションに基づいて、前記データストレージデバイスに記憶されたデータの変更を阻止する、請求項68に記載のシステム。
  72. オペレーティングシステムを自動復元するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラを含み、
    第1のオペレーティングシステムファイルのセットを第1のデータセクタに記憶し、
    第2のオペレーティングシステムファイルのセットを第2のデータセクタに記憶するように構成され、
    前記ホストコントローラは、
    復元コマンドを受信し、
    前記第1のオペレーティングシステムファイルのセットのデータ取得要求を受信し、
    前記データ取得要求に前記第2のオペレーティングシステムファイルのセットを応答するように構成されている、システム。
  73. 前記データストレージデバイスの前記ホストコントローラは、前記第1のデータセクタ内の前記第1のオペレーティングシステムファイルのセットを、前記第2のオペレーティングシステムファイルのセットで上書きするように更に構成されている、請求項72に記載のシステム。
  74. 前記上書きは、前記データストレージデバイスのアイドルサイクル中に実行される、請求項73に記載のシステム。
  75. 前記データストレージデバイスで実行された動作の変更ログを記憶する、前記コンピューティングシステムのメモリを更に含み、
    前記データストレージデバイスの前記ホストコントローラは、前記変更ログに示される前記データストレージデバイスで実行された前記動作を逆行させるように更に構成されている、請求項72に記載のシステム。
  76. 前記データストレージデバイスで実行された前記動作は、前記第1のデータセクタに記憶された前記第1のオペレーティングシステムファイルのセットを変更する、請求項75に記載のシステム。
  77. データをバックアップするシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラを含み、
    前記ホストコントローラは、
    前記コンピューティングシステムにおける脅威イベントのインディケーションを受信し、
    前記脅威イベントを遅延させ、
    前記データストレージデバイス内の1つ以上のデータファイルをバックアップし、
    前記1つ以上のデータファイルのバックアップの完了後、前記脅威イベントを許可にするように構成されている、システム。
  78. 前記脅威イベントは、前記1つ以上のデータファイルに脅威をもたらす、請求項77に記載のシステム。
  79. 前記1つ以上のデータファイルは、前記コンピューティングシステムのユーザによってバックアップのために予め選択される、請求項77に記載のシステム。
  80. 前記1つ以上のデータファイルは、前記データストレージデバイスの所定の位置に前記1つ以上のデータファイルを記憶することによりバックアップされる、請求項77に記載のシステム。
  81. 前記脅威イベントは、前記1つ以上のデータファイルの削除又は変更である、請求項77に記載のシステム。
  82. コンピューティングネットワークにおいて相互接続されたセキュリティを提供するシステムであって、
    複数のコンピューティングデバイスから構成されるコンピューティングネットワークを含み、
    前記複数のコンピューティングデバイスのそれぞれは、第1の通信チャネルのシリーズを用いて、前記コンピューティングネットワークに接続され、
    前記複数のコンピューティングデバイスのそれぞれは、前記複数のコンピューティングデバイス内の他のコンピューティングデバイスのそれぞれとの代替の安全な通信チャネルを、第2の通信チャネルのシリーズとして確立し、
    前記複数のコンピューティングデバイスのうちの1つは、
    前記コンピューティングネットワーク又は前記複数のコンピューティングデバイスのうちの前記1つに対する脅威を示す脅威イベントを検出し、
    前記第2の通信チャネルのシリーズを用いて、前記複数のコンピューティングデバイス内の前記他のコンピューティングデバイスのそれぞれに、前記検出された脅威イベントの通知を送信する、システム。
  83. 前記第1の通信チャネルのシリーズは、第1の通信プロトコルを使用し、
    前記第2の通信チャネルのシリーズは、第2の通信プロトコルを使用する、請求項82に記載のシステム。
  84. 前記第1の通信チャネルのシリーズ及び前記第2の通信チャネルのシリーズは、共通の通信プロトコルを使用し、
    前記第2の通信チャネルのシリーズは、1つ以上の暗号化ツールを使用する、請求項82に記載のシステム。
  85. 前記複数のコンピューティングデバイスのそれぞれは、前記第1の通信チャネルのシリーズを無効にするように構成されている、請求項82に記載のシステム。
  86. 異常なシステムアクティビティを検出するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラを含み、
    前記ホストコントローラは、
    前記コンピューティングシステムのユーザによって実行された複数のアクションを経時的にログに記録し、
    前記ログに記録された複数のアクションに基づいて、使用アクションのセットを含む、前記ユーザのユーザフィンガープリントを判定し、
    コンピューティングデバイスを使用して実行される複数の新たなアクションを監視し、
    前記複数の新たなアクションと前記使用アクションのセットとの比較に基づいて、異常なシステムアクティビティを検出し、
    前記検出された異常なシステムアクティビティの結果として、前記コンピューティングシステム内の脅威イベントの通知をトリガするように構成されている、システム。
  87. 前記複数のアクションは、前記データストレージデバイスに記憶されたデータに影響を及ぼすアクションである、請求項86に記載のシステム。
  88. 前記使用アクションのセットは、ランサムウェア攻撃に関連付けられ、
    前記複数の新たなアクションは、前記使用アクションのセットに一致する、請求項86に記載のシステム。
  89. 前記複数の新たなアクションは、前記使用アクションのセットに含まれない所定の数のアクションを含む、請求項86に記載のシステム。
  90. データアクセスを制御するシステムであって、
    ハードウェアデバイスと別のデバイスとデータストレージデバイスとを含む、コンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラを含み、
    前記ハードウェアデバイスは、
    前記コンピューティングシステム内のデータストレージデバイスのホストコントローラとの第1の通信チャネルを確立し、
    前記コンピューティングシステム内の前記別のデバイスとの第2の通信チャネルを確立し、
    前記第2の通信チャネルを使用して、前記別のデバイスからのデータ要求を受信し、
    前記ハードウェアデバイスのメモリに、前記受信されたデータ要求を記憶し、
    前記第1の通信チャネルを使用して、前記受信されたデータ要求を前記ホストコントローラに転送するように構成されている、システム。
  91. 前記ハードウェアデバイスは、前記ホストコントローラに送信されたすべてのデータ信号をインターセプトする、請求項90に記載のシステム。
  92. 前記ハードウェアデバイスは、コンピューティングデバイスにおいて、前記データストレージデバイスと前記コンピューティングデバイス内の1つ以上の追加のコンポーネントとの間に物理的に接続される、請求項90に記載のシステム。
  93. 前記データストレージデバイスは、前記コンピューティングデバイス内の追加のコンポーネントに接続されない、請求項92に記載のシステム。
  94. データアクセスを制御するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラを含み、
    前記ホストコントローラは、
    前記ホストコントローラのメモリに、1つ以上の確立された規則を記憶し、
    データコマンドと1つ以上の影響を受けるデータ項目とを示す、データアクション要求を受信し、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定し、
    前記データアクション要求が遵守している場合に、前記1つ以上の影響を受けるデータ項目に対する前記データコマンドを実行し、
    前記データアクション要求が遵守していない場合に、前記1つ以上の影響を受けるデータ項目に対する阻止されたアクセスを示す、前記データアクション要求に対する応答を送信するように構成されている、システム。
  95. 前記1つ以上の確立された規則のそれぞれは、複数のデータコマンドのうちの1つに関連付けられ、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することは、前記データアクション要求が、前記1つ以上の確立された規則のうち、前記データアクション要求に示される前記データコマンドに関連付けられた規則を遵守しているか否かを判定することを含む、請求項94に記載のシステム。
  96. 前記1つ以上の確立された規則は、地理的領域を含み、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することは、前記コンピューティングシステムが前記地理的領域内にあるか否かを判定することを含む、請求項94に記載のシステム。
  97. 前記判定することは、前記コンピューティングシステムとインタフェース接続された全地球測位デバイスから地理的位置を受信することを含む、請求項96に記載のシステム。
  98. 前記1つ以上の確立された規則は、セキュリティデバイスの存在を要求する規則を含み、
    前記データアクション要求が前記1つ以上の確立された規則を遵守しているか否かを判定することは、前記コンピューティングシステム内の前記セキュリティデバイスの存在を検出することを含む、請求項94に記載のシステム。
  99. データの使用を監視するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラ及びデバイスコントローラを含み、複数のデータ項目及び1つ以上のデータアクセス制限を記憶するように構成され、
    前記ホストコントローラは、前記ホストコントローラによって受信された複数のデータアクセスアクションを実行して、前記複数のデータ項目内のデータ項目を前記コンピューティングシステム内の1つ以上のホストデバイスに転送するように構成され、
    前記デバイスコントローラは、
    前記複数のデータアクセスアクションの実行中に前記データストレージデバイスから前記1つ以上のホストデバイスに転送されたデータ量を検出し、
    前記データストレージデバイスから転送された前記データ量が前記1つ以上のデータアクセス制限に達したか超えた場合に、新たなデータアクセスアクションの実行を阻止するように構成されている、システム。
  100. 前記デバイスコントローラ及び前記ホストコントローラは、単一のコンポーネントである、請求項99に記載のシステム。
  101. 前記デバイスコントローラは、前記データストレージデバイスのファイルシステムレベルで動作する、請求項99に記載のシステム。
  102. 前記1つ以上のデータアクセス制限は、データタイプ、データ量、及びデータの記憶セクタのうちの少なくとも1つを指定する、請求項99に記載のシステム。
  103. データ保護をトリガするシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ストレージプラットホームコントローラ及びホストコントローラを含み、入力回路とインタフェース接続され、
    前記入力回路は、所定のコマンドのパフォーマンスを検出するように構成され、
    前記ストレージプラットホームコントローラは、前記検出されたパフォーマンスの結果として、所定のアクションを実行するように構成され、
    前記入力回路は、前記データストレージデバイスの前記ホストコントローラとインタフェース接続されない、システム。
  104. 前記所定のコマンドは、前記入力回路とインタフェース接続された1つ以上のハードウェア要素を使用して実行される物理アクションである、請求項103に記載のシステム。
  105. 前記物理アクションは、ボタンを押すこと、前記1つ以上のハードウェア要素のうちの1つを振ること、音声コマンドを話すこと、又はスイッチをトグルすることのうちの1つを含む、請求項104に記載のシステム。
  106. 前記所定のアクションは、前記データストレージデバイスに記憶されたデータを消去すること、前記データストレージデバイスに記憶されたデータを暗号化すること、及び前記データストレージデバイスに記憶されたデータへのアクセスを阻止することのうちの1つである、請求項103に記載のシステム。
  107. 前記データストレージデバイスに記憶された前記データは、前記所定のアクションの一部として定義される、請求項106に記載のシステム。
  108. データストレージアクセスを追跡するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラと、前記データストレージデバイス内の記憶範囲のリスト及び監視される記憶範囲のセットを含むメモリとを含み、前記監視される記憶範囲のセット内の監視される記憶範囲のそれぞれは、前記記憶範囲のリスト内の前記記憶範囲内にあり、
    前記ホストコントローラは、
    データコマンド及び影響を受けるデータ項目を含むデータアクション要求を、前記コンピューティングシステム内のホストデバイスから受信し、
    前記データコマンドを実行し、
    前記影響を受けるデータ項目の記憶位置であって、前記監視される記憶範囲のセットのうちの1つに含まれる記憶位置を識別し、
    前記データストレージデバイス内のデータアクセスログに、前記監視される記憶範囲のセットのうちの前記1つへのアクセスを示すログエントリを記憶するように構成されている、システム。
  109. 前記ログエントリは、前記データコマンドと、前記影響を受けるデータ項目のインディケーションとを更に含む、請求項108に記載のシステム。
  110. 前記ログエントリは、タイムスタンプと、前記コンピューティングシステムのユーザに関連付けられたユーザ情報とを更に含む、請求項108に記載のシステム。
  111. 前記データアクセスログは、前記データストレージデバイスの前記メモリに記憶される、請求項108に記載のシステム。
  112. 前記データストレージデバイスの前記メモリは、前記影響を受けるデータ項目を記憶するために使用される記憶領域とは別である、請求項108に記載のシステム。
  113. 使用されないフラッシュメモリをクリアするシステムであって、
    フラッシュメモリ・ストレージデバイスを含むコンピューティングシステムを含み、
    前記フラッシュメモリ・ストレージデバイスは、ホストコントローラを含み、複数のデータ記憶ブロックを記憶し、それぞれのデータ記憶ブロックは、1つ以上のデータ項目を記憶可能であり、
    前記ホストコントローラは、
    前記複数のデータ記憶ブロック内の1つ以上のインアクティブなブロックを検出し、
    前記検出された1つ以上のインアクティブなブロックにおいてデータ除去のための1つ以上のアクションを実行するように構成されている、システム。
  114. データ除去のための前記1つ以上のアクションは、所定の期間に実行される、請求項113に記載のシステム。
  115. データ除去のための前記1つ以上のアクションは、前記フラッシュメモリ・ストレージデバイスのアイドルサイクル中に実行される、請求項113に記載のシステム。
  116. 前記1つ以上のアクションは、前記1つ以上のインアクティブなブロックのデータを解読不可能なデータで上書きすることを含む、請求項113に記載のシステム。
  117. データ除去のための前記1つ以上のアクションは、前記ホストコントローラの受信機によって受信される、前記コンピューティングシステムのユーザによるコマンド入力の受信時に実行される、請求項113に記載のシステム。
  118. 使用されないフラッシュメモリをクリアするシステムであって、
    フラッシュメモリ・ストレージデバイスを含むコンピューティングシステムを含み、
    前記フラッシュメモリ・ストレージデバイスは、ホストコントローラを含み、ウェアレベリング・プロセスを実行し、
    前記ホストコントローラは、
    前記フラッシュメモリ・ストレージデバイス内の1つ以上のブロックを識別し、前記ウェアレベリング・プロセスの一部として、新たなデータが前記1つ以上のブロックに転送されずに、古いデータが前記1つ以上のブロックから転送され、
    前記識別された1つ以上のブロックにおいてデータ除去のための1つ以上のアクションを実行するように構成されている、システム。
  119. データ除去のための前記1つ以上のアクションは、所定の期間に実行される、請求項118に記載のシステム。
  120. データ除去のための前記1つ以上のアクションは、前記フラッシュメモリ・ストレージデバイスのアイドルサイクル中に実行される、請求項118に記載のシステム。
  121. 前記1つ以上のアクションは、前記1つ以上のインアクティブなブロックのデータを解読不可能なデータで上書きすることを含む、請求項118に記載のシステム。
  122. データ除去のための前記1つ以上のアクションは、前記ホストコントローラの受信機によって受信される、前記コンピューティングシステムのユーザによるコマンド入力の受信時に実行される、請求項118に記載のシステム。
  123. データアクセスを制御するシステムであって、
    データストレージデバイスを含むコンピューティングシステムを含み、
    前記データストレージデバイスは、ホストコントローラを含み、それぞれのデータアクセス規則が、(i)1つ以上のデータファイル、又は(ii)前記データストレージデバイスのセクタ/ブロック範囲を指定し、第1の認証要素、第2の認証要素、及び時間範囲を含む、複数のデータアクセス規則を記憶し、
    前記ホストコントローラは、
    前記コンピューティングシステム内のホストデバイスから、データコマンド及び影響を受けるデータ項目を含む、データアクション要求を受信し、
    該当するデータアクセス規則に含まれる前記1つ以上のデータファイルと一致する、或いは前記該当するデータアクセス規則に含まれる前記セクタ/ブロック範囲に記憶されている、前記影響を受けるデータ項目に基づいて、前記該当するデータアクセス規則を識別し、
    前記該当するデータアクセス規則内の前記第1の認証要素を使用する第1の認証要求を送信し、
    前記該当するデータアクセス規則内の前記第2の認証要素を使用する第2の認証要求を送信し、
    認証成功を示す前記第1の認証要求に対する第1の応答と、認証成功を示す前記第2の認証要求に対する第2の応答とを受信し、
    前記受信された第1の応答と、前記受信された第2の応答と、前記該当するデータアクセス規則に含まれる前記時間範囲内の前記データアクション要求の受信とに基づいて、前記該当するデータアクセス規則の遵守を判定し、
    前記データアクション要求に含まれる前記データコマンドを実行するように構成されている、システム。
  124. 前記第1の認証要素は、前記コンピューティングシステムのユーザが前記コンピューティングシステムに既知のデータ値を入力することを要求し、
    前記第2の認証要素は、前記コンピューティングシステムとインタフェース接続されるセキュリティデバイスの存在を要求する、請求項123に記載のシステム。
  125. 前記第1の認証要素は、パスワード及びセキュリティコードのうちの少なくとも1つを使用する、請求項124に記載のシステム。
  126. 前記セキュリティデバイスは、セキュリティドングル及びバイオメトリックスキャナのうちの1つである、請求項124に記載のシステム。
  127. 前記該当するデータアクセス規則に含まれる前記時間範囲は、時刻、曜日、及び月日のうちの少なくとも1つを含む、請求項123に記載のシステム。
  128. 拡張現実を用いた認証システムであって、
    メモリ、受信機、処理装置、及び送信機を含む、コンピューティングシステムを含み、
    前記コンピューティングシステムの前記メモリは、少なくとも地理的位置、位置データ、及びオブジェクトデータを含む、第1の認証データのセットを記憶し、
    前記コンピューティングシステムの前記受信機は、光学撮像装置によってキャプチャされた画像データと前記光学撮像装置の地理的座標とを少なくとも含む、認証要求を受信し、
    前記コンピューティングシステムの前記処理装置は、(i)前記地理的座標が前記地理的位置から所定の距離内にあること、(ii)前記画像データが前記位置データに対応する物理的領域のキャプチャであること、及び(iii)前記画像データが前記オブジェクトデータに対応する物理的オブジェクトの画像を含むことを判定し、
    前記コンピューティングシステムの前記送信機は、前記受信された認証要求に応答して認証成功のインディケーションを送信する、システム。
  129. 前記コンピューティングシステムの前記メモリは、パスワードを含む、第2の認証データのセットを更に記憶し、
    前記認証要求は、提供されたデータ値を更に含み、
    前記判定は、(iv)前記提供されたデータ値が前記パスワードに対応することを判定することを更に含む、請求項128に記載のシステム。
  130. 前記コンピューティングシステムの前記メモリは、受け入れられたパスワードを含むパスワードのリストを含む、第2の認証データのセットを更に記憶し、
    前記コンピューティングシステムの前記送信機は、前記認証要求に応答して前記パスワードのリストを更に送信し、
    前記コンピューティングシステムの前記受信機は、前記送信されたパスワードのリストに応答して、提供されたデータ値を更に受信し、
    前記コンピューティングシステムの前記処理装置は、前記提供されたデータ値が前記受け入れられたパスワードに対応することを更に判定し、
    前記提供されたデータ値が前記受け入れられたパスワードに対応すると判定された後に、前記認証成功のインディケーションが送信される、請求項128に記載のシステム。
  131. タイピングヒューリスティックによるユーザ認証のシステムであって、
    処理装置及び送信機を含み、入力装置とインタフェース接続された、コンピューティングシステムを含み、
    前記コンピューティングシステムとインタフェース接続された前記入力装置は、前記コンピューティングシステムのユーザによって入力された複数のキーストロークを受信し、
    前記処理装置は、
    前記受信された複数のキーストロークに基づいて、タイピングパターンを検出し、
    前記検出されたタイピングパターンに基づいて、前記ユーザに関連付けられた認証キーを生成するように構成され、
    前記入力装置は、データメッセージを含む、新たなキーストロークのセットを更に受信し、
    前記処理装置は、更に、前記受信された新たなキーストロークのセットに基づいて、新たなキーを生成し、前記新たなキーと前記認証キーとの比較に基づいて、前記データメッセージを認証し、
    前記コンピューティングシステムの前記送信機は、(i)前記認証が成功した場合には前記データメッセージを含み、(ii)前記認証が失敗した場合には認証失敗を示す通知を含む、データ信号を外部システムに送信する、システム。
  132. 前記データメッセージは、電子メールメッセージである、請求項131に記載のシステム。
  133. 前記タイピングパターンは、タイピング速度、タイピング精度、キーストローク圧力、及び特定のキーストローク間の時間のうちの少なくとも1つを含むヒューリスティックを含む、請求項131に記載のシステム。
  134. 認証失敗を示す前記通知は、前記データメッセージを更に含む、請求項131に記載のシステム。
JP2021513372A 2018-05-11 2019-05-09 改良されたデータ制御及びアクセスの方法及びシステム Active JP7288045B2 (ja)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2022113269A JP7448593B2 (ja) 2018-05-11 2022-07-14 改良されたデータ制御及びアクセスの方法及びシステム
JP2023038294A JP7487372B2 (ja) 2018-05-11 2023-03-13 改良されたデータ制御及びアクセスの方法及びシステム
JP2024011526A JP2024054167A (ja) 2018-05-11 2024-01-30 改良されたデータ制御及びアクセスの方法及びシステム

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201862670073P 2018-05-11 2018-05-11
US62/670,073 2018-05-11
US201862764777P 2018-08-16 2018-08-16
US62/764,777 2018-08-16
PCT/US2019/031472 WO2019217649A2 (en) 2018-05-11 2019-05-09 Method and system for improved data control and access

Related Child Applications (2)

Application Number Title Priority Date Filing Date
JP2022113269A Division JP7448593B2 (ja) 2018-05-11 2022-07-14 改良されたデータ制御及びアクセスの方法及びシステム
JP2023038294A Division JP7487372B2 (ja) 2018-05-11 2023-03-13 改良されたデータ制御及びアクセスの方法及びシステム

Publications (2)

Publication Number Publication Date
JP2021521575A true JP2021521575A (ja) 2021-08-26
JP7288045B2 JP7288045B2 (ja) 2023-06-06

Family

ID=68101983

Family Applications (4)

Application Number Title Priority Date Filing Date
JP2021513372A Active JP7288045B2 (ja) 2018-05-11 2019-05-09 改良されたデータ制御及びアクセスの方法及びシステム
JP2022113269A Active JP7448593B2 (ja) 2018-05-11 2022-07-14 改良されたデータ制御及びアクセスの方法及びシステム
JP2023038294A Active JP7487372B2 (ja) 2018-05-11 2023-03-13 改良されたデータ制御及びアクセスの方法及びシステム
JP2024011526A Pending JP2024054167A (ja) 2018-05-11 2024-01-30 改良されたデータ制御及びアクセスの方法及びシステム

Family Applications After (3)

Application Number Title Priority Date Filing Date
JP2022113269A Active JP7448593B2 (ja) 2018-05-11 2022-07-14 改良されたデータ制御及びアクセスの方法及びシステム
JP2023038294A Active JP7487372B2 (ja) 2018-05-11 2023-03-13 改良されたデータ制御及びアクセスの方法及びシステム
JP2024011526A Pending JP2024054167A (ja) 2018-05-11 2024-01-30 改良されたデータ制御及びアクセスの方法及びシステム

Country Status (4)

Country Link
US (4) US10437983B1 (ja)
EP (1) EP3791279A4 (ja)
JP (4) JP7288045B2 (ja)
WO (1) WO2019217649A2 (ja)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP7288045B2 (ja) 2018-05-11 2023-06-06 サイジェント テクノロジー インコーポレイテッド 改良されたデータ制御及びアクセスの方法及びシステム
JP7244352B2 (ja) * 2019-05-22 2023-03-22 ファナック株式会社 ファイル管理装置
US11334677B2 (en) * 2020-01-09 2022-05-17 Western Digital Technologies, Inc. Multi-role unlocking of a data storage device
JP7452921B1 (ja) * 2023-12-11 2024-03-19 Game Server Services株式会社 制御システム、サーバおよび制御方法

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060242159A1 (en) * 2005-03-10 2006-10-26 Bishop Robert J Methods and apparatus for distributing digital medical images via a redirected system
JP2009512947A (ja) * 2005-10-18 2009-03-26 ザ・マクレガー・グループ・インコーポレーテッド シンクライアント上にデータを表示するためのシステムおよび方法
WO2009096089A1 (ja) * 2008-01-31 2009-08-06 Nec Corporation 状態情報提供システム、提供方法、及び、プログラム
JP2010224840A (ja) * 2009-03-23 2010-10-07 Dainippon Printing Co Ltd ネットワーク機器設定方法
US8312064B1 (en) * 2005-05-11 2012-11-13 Symantec Corporation Method and apparatus for securing documents using a position dependent file system
JP2013008121A (ja) * 2011-06-23 2013-01-10 Hitachi Systems Ltd データベースアクセス管理システム、方法、及びプログラム
JP2013045292A (ja) * 2011-08-24 2013-03-04 Hitachi Systems Ltd アクセス管理システム、アクセス管理方法、アクセス管理プログラム
WO2013154936A1 (en) * 2012-04-09 2013-10-17 Brivas Llc Systems, methods and apparatus for multivariate authentication
JP2017098658A (ja) * 2015-11-19 2017-06-01 株式会社Nttドコモ 閲覧ポリシー決定装置

Family Cites Families (60)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6266773B1 (en) * 1998-12-31 2001-07-24 Intel. Corp. Computer security system
JP2001052495A (ja) * 1999-06-03 2001-02-23 Toshiba Corp 半導体メモリ
WO2001037096A1 (en) * 1999-11-18 2001-05-25 Bullant Technology Pty Ltd Data object identification and removal system
US6507895B1 (en) * 2000-03-30 2003-01-14 Intel Corporation Method and apparatus for access demarcation
US20020133586A1 (en) * 2001-01-16 2002-09-19 Carter Shanklin Method and device for monitoring data traffic and preventing unauthorized access to a network
US6948038B2 (en) * 2001-07-24 2005-09-20 Microsoft Corporation System and method for backing up and restoring data
US6898668B2 (en) * 2002-06-24 2005-05-24 Hewlett-Packard Development Company, L.P. System and method for reorganizing data in a raid storage system
US7908401B2 (en) * 2002-12-12 2011-03-15 Flexiworld Technology, Inc. Method and device for wireless communication between computing devices
US8001348B2 (en) * 2003-12-24 2011-08-16 Intel Corporation Method to qualify access to a block storage device via augmentation of the device's controller and firmware flow
US7318550B2 (en) * 2004-07-01 2008-01-15 American Express Travel Related Services Company, Inc. Biometric safeguard method for use with a smartcard
JP4483535B2 (ja) * 2004-11-05 2010-06-16 株式会社日立製作所 ネットワーク装置
US7392358B2 (en) * 2005-01-14 2008-06-24 Sandisk Corporation Delivery of a message to a user of a portable data storage device as a condition of its use
US7702646B2 (en) 2005-02-18 2010-04-20 The Macgregor Group, Inc. System and method for displaying data on a thin client
US7636872B2 (en) * 2005-03-23 2009-12-22 Microsoft Corporation Threat event-driven backup
US7761618B2 (en) * 2005-03-25 2010-07-20 Microsoft Corporation Using a USB host controller security extension for controlling changes in and auditing USB topology
US20060242156A1 (en) * 2005-04-20 2006-10-26 Bish Thomas W Communication path management system
US7697942B2 (en) * 2005-09-02 2010-04-13 Stevens Gilman R Location based rules architecture systems and methods
US7634629B2 (en) * 2005-12-19 2009-12-15 Intel Corporation Mechanism to control access to a storage device
US7693889B1 (en) * 2005-12-28 2010-04-06 Emc Corporation Automated backup and recovery for content repository
US7461216B2 (en) * 2006-02-23 2008-12-02 Hewlett-Packard Development Company, L.P. Memory controller
JP4705489B2 (ja) * 2006-03-07 2011-06-22 富士通株式会社 デバイスドライバプログラムを記録したコンピュータ読取可能なポータブル記録媒体、記憶装置アクセス方法および記憶装置アクセスシステム
US7564721B2 (en) * 2006-05-25 2009-07-21 Micron Technology, Inc. Method and apparatus for improving storage performance using a background erase
US7975109B2 (en) * 2007-05-30 2011-07-05 Schooner Information Technology, Inc. System including a fine-grained memory and a less-fine-grained memory
TWI537732B (zh) * 2007-09-27 2016-06-11 克萊夫公司 加密之資料保全系統
GB2460275B (en) * 2008-05-23 2012-12-19 Exacttrak Ltd A Communications and Security Device
US8769684B2 (en) * 2008-12-02 2014-07-01 The Trustees Of Columbia University In The City Of New York Methods, systems, and media for masquerade attack detection by monitoring computer user behavior
US8606997B2 (en) * 2008-12-23 2013-12-10 Oracle America, Inc. Cache hierarchy with bounds on levels accessed
US8166067B2 (en) * 2008-12-26 2012-04-24 Sandisk Il Ltd. Method and apparatus for providing access to files based on user identity
JP5310053B2 (ja) * 2009-02-12 2013-10-09 住友電気工業株式会社 マイクロコントローラを備えた光データリンク
GB0905377D0 (en) 2009-03-30 2009-05-13 Danmedical Ltd Medical apparatus
US8341189B2 (en) 2009-03-31 2012-12-25 Microsoft Corporation Extending collaboration capabilities to external data
GB0906057D0 (en) * 2009-04-07 2009-05-20 Cambridge Silicon Radio Ltd Device security
CN102439532A (zh) * 2009-05-20 2012-05-02 克罗诺洛吉克有限公司 超高速和非超高速usb装置的同步网络
US8352941B1 (en) * 2009-06-29 2013-01-08 Emc Corporation Scalable and secure high-level storage access for cloud computing platforms
US8474018B2 (en) * 2010-09-03 2013-06-25 Ebay Inc. Role-based attribute based access control (RABAC)
US8706701B1 (en) * 2010-11-18 2014-04-22 Emc Corporation Scalable cloud file system with efficient integrity checks
US9087189B1 (en) * 2011-05-03 2015-07-21 Symantec Corporation Network access control for cloud services
US9026737B1 (en) * 2011-06-29 2015-05-05 Emc Corporation Enhancing memory buffering by using secondary storage
KR20140035600A (ko) * 2012-09-14 2014-03-24 한국전자통신연구원 무선 침입방지 동글 장치
US8769651B2 (en) * 2012-09-19 2014-07-01 Secureauth Corporation Mobile multifactor single-sign-on authentication
US9813499B2 (en) * 2013-07-23 2017-11-07 Virtual Strongbox, Inc. Virtual storage system and method of sharing access to the virtual storage system for adding electronic documents
US9117086B2 (en) * 2013-08-28 2015-08-25 Seagate Technology Llc Virtual bands concentration for self encrypting drives
US9176896B2 (en) * 2013-10-30 2015-11-03 Seagate Technology Llc Method of managing aligned and unaligned data bands in a self encrypting solid state drive
US9692789B2 (en) * 2013-12-13 2017-06-27 Oracle International Corporation Techniques for cloud security monitoring and threat intelligence
US9635024B2 (en) * 2013-12-16 2017-04-25 F5 Networks, Inc. Methods for facilitating improved user authentication using persistent data and devices thereof
US9197751B2 (en) * 2014-03-26 2015-11-24 Genesys Telecommunications Laboratories, Inc. Rules-based compliance system
US9411513B2 (en) * 2014-05-08 2016-08-09 Unisys Corporation Sensitive data file attribute
US20150363785A1 (en) * 2014-06-12 2015-12-17 Mastercard International Incorporated Systems and methods for consumer authentication using behavioral biometrics
US10509769B1 (en) * 2014-06-12 2019-12-17 EMC IP Holding Company LLC Method to efficiently track I/O access history
GB201420496D0 (en) * 2014-10-01 2014-12-31 Continental Intelligent Transporation Systems Llc Package delivery to and pick-up from a vehicle
US9906510B2 (en) * 2015-02-10 2018-02-27 Airwatch Llc Virtual content repository
US10387665B2 (en) * 2015-03-25 2019-08-20 Vera Policy enforcement
US9654481B1 (en) * 2015-04-25 2017-05-16 Tp Lab, Inc. Location based secure data device
US10073964B2 (en) * 2015-09-25 2018-09-11 Intel Corporation Secure authentication protocol systems and methods
US10231128B1 (en) * 2016-02-08 2019-03-12 Microstrategy Incorporated Proximity-based device access
US10764155B2 (en) * 2016-11-29 2020-09-01 CloudSmartz, Inc. System and method for on-demand network communication
US10430292B2 (en) * 2017-12-19 2019-10-01 Robin Systems, Inc. Snapshot deletion in a distributed storage system
KR102641521B1 (ko) * 2018-02-22 2024-02-28 삼성전자주식회사 키-밸류 스토리지 장치 및 이의 동작 방법
JP7288045B2 (ja) 2018-05-11 2023-06-06 サイジェント テクノロジー インコーポレイテッド 改良されたデータ制御及びアクセスの方法及びシステム
KR20200036461A (ko) * 2018-09-28 2020-04-07 삼성전자주식회사 메모리 디바이스들 사이의 직접 통신을 위한 메모리 시스템 및 메모리 디바이스

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060242159A1 (en) * 2005-03-10 2006-10-26 Bishop Robert J Methods and apparatus for distributing digital medical images via a redirected system
US8312064B1 (en) * 2005-05-11 2012-11-13 Symantec Corporation Method and apparatus for securing documents using a position dependent file system
JP2009512947A (ja) * 2005-10-18 2009-03-26 ザ・マクレガー・グループ・インコーポレーテッド シンクライアント上にデータを表示するためのシステムおよび方法
WO2009096089A1 (ja) * 2008-01-31 2009-08-06 Nec Corporation 状態情報提供システム、提供方法、及び、プログラム
JP2010224840A (ja) * 2009-03-23 2010-10-07 Dainippon Printing Co Ltd ネットワーク機器設定方法
JP2013008121A (ja) * 2011-06-23 2013-01-10 Hitachi Systems Ltd データベースアクセス管理システム、方法、及びプログラム
JP2013045292A (ja) * 2011-08-24 2013-03-04 Hitachi Systems Ltd アクセス管理システム、アクセス管理方法、アクセス管理プログラム
WO2013154936A1 (en) * 2012-04-09 2013-10-17 Brivas Llc Systems, methods and apparatus for multivariate authentication
JP2017098658A (ja) * 2015-11-19 2017-06-01 株式会社Nttドコモ 閲覧ポリシー決定装置

Also Published As

Publication number Publication date
US20210357492A1 (en) 2021-11-18
JP7487372B2 (ja) 2024-05-20
JP2023078262A (ja) 2023-06-06
JP7288045B2 (ja) 2023-06-06
JP2022153473A (ja) 2022-10-12
WO2019217649A3 (en) 2020-02-13
US20220342977A1 (en) 2022-10-27
JP2024054167A (ja) 2024-04-16
US11106779B2 (en) 2021-08-31
US11416601B2 (en) 2022-08-16
EP3791279A2 (en) 2021-03-17
WO2019217649A2 (en) 2019-11-14
JP7448593B2 (ja) 2024-03-12
US10437983B1 (en) 2019-10-08
EP3791279A4 (en) 2022-01-26
US20190377865A1 (en) 2019-12-12

Similar Documents

Publication Publication Date Title
JP7448593B2 (ja) 改良されたデータ制御及びアクセスの方法及びシステム
US9811682B2 (en) Security policy for device data
US20170180332A1 (en) System and method to provide server control for access to mobile client data
US9652610B1 (en) Hierarchical data security measures for a mobile device
US20190332765A1 (en) File processing method and system, and data processing method
US10114960B1 (en) Identifying sensitive data writes to data stores
US20160371500A1 (en) Fast Data Protection Using Dual File Systems
US10733594B1 (en) Data security measures for mobile devices
KR20170101159A (ko) 디바이스의 상태 기반 암호화 키를 위한 방법 및 디바이스
WO2009051336A1 (en) Apparatus and method for managing terminal users
CN111475832A (zh) 一种数据管理的方法以及相关装置
KR102657388B1 (ko) 암호화될 데이터의 정보량에 기반하여 암호화에 사용될 키를 선택하는 전자 장치 및 전자 장치의 동작 방법
US20160072849A1 (en) Determining security factors associated with an operating environment
KR20210026233A (ko) 디바이스 리소스에 대한 접근을 제어하기 위한 전자 장치 및 그의 동작 방법
JP6832413B2 (ja) 情報処理装置およびプログラム
US20240163287A1 (en) Secure reuse of cloud at customer hardware
KR20170056369A (ko) 전자 장치를 보호하기 위한 장치 및 방법
WO2023278266A1 (en) Optimizing application security based on malicious user intent
KR20240078135A (ko) Dpapi 기반 데이터 재생성을 통한 클라우드 데이터 획득 장치 및 방법

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20201202

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20201202

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20220215

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20220512

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20220714

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20221115

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20230313

C60 Trial request (containing other claim documents, opposition documents)

Free format text: JAPANESE INTERMEDIATE CODE: C60

Effective date: 20230313

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20230314

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20230331

C21 Notice of transfer of a case for reconsideration by examiners before appeal proceedings

Free format text: JAPANESE INTERMEDIATE CODE: C21

Effective date: 20230404

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: 20230509

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20230525

R150 Certificate of patent or registration of utility model

Ref document number: 7288045

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150