Inhaltsverzeichnis
Uhrenanbieter" >Uhrenanbieter
Datenstruktur" >Datenstruktur
Registrierungsmethode" >Registrierungsmethode
Clock Consumer" >Clock Consumer
获取 clock" >获取 clock
操作 clock" >操作 clock
总结" >总结
Heim System-Tutorial LINUX In einem Artikel verstehen |. Linux-Uhr-Subsystem

In einem Artikel verstehen |. Linux-Uhr-Subsystem

Feb 12, 2024 am 09:42 AM
linux linux教程 linux系统 linux命令 shell脚本 Erste Schritte mit Linux Linux-Lernen

Uhr Die Uhr ist der Impuls im SoC, der jede Komponente so steuert, dass sie in ihrem eigenen Tempo läuft. Zum Beispiel CPU-Frequenzeinstellung, Einstellung der Baudrate der seriellen Schnittstelle, Einstellung der I2S-Abtastrate, Einstellung der I2C-Rate usw. Diese unterschiedlichen Takteinstellungen müssen von einer oder mehreren Taktquellen stammen und letztendlich einen Taktbaum bilden. Sie können diesen Uhrenbaum über den Befehl cat /sys/kernel/debug/clk/clk_summary anzeigen.

Das CCF-Framework wird im Kernel zur Verwaltung von Uhren verwendet. Wie in der Abbildung unten gezeigt, ist die rechte Seite der Taktgeber, also der Taktgeber, und die linke Seite ist der Taktgeber des Gerätetreibers, also der Taktgeber.

一文搞懂 | Linux 时钟子系统

Uhrenanbieter

  • Der Wurzelknoten ist normalerweise ein Oszillator (aktiver Oszillator) oder Quarz (passiver Oszillator).
  • Es gibt viele Arten von Zwischenknoten, darunter PLL (Phasenregelkreis, zur Frequenzerhöhung), Divider (Frequenzteiler, zur Frequenzreduzierung), Mux (Auswahl eines aus mehreren Taktpfaden), Gate (zur Steuerung von ON/ AUS).
  • Blattknoten sind HW-Blöcke mit spezifischen Funktionen, die den Takt als Eingabe verwenden.

Entsprechend den Eigenschaften der Uhr unterteilt das Uhr-Framework die Uhr in sechs Kategorien: feste Rate, Gate, Entwickler, Mux, fester Faktor und zusammengesetzt.

一文搞懂 | Linux 时钟子系统

Datenstruktur

Die oben genannten sechs Kategorien sind im Wesentlichen Taktgeräte. Der Kernel extrahiert die Eigenschaften dieser Takt-HW-Blöcke und verwendet die Struktur clk_hw, um sie wie folgt darzustellen:

struct clk_hw {
  //指向CCF模块中对应 clock device 实例
 struct clk_core *core;
  //clk是访问clk_core的实例。每当consumer通过clk_get对CCF中的clock device(也就是clk_core)发起访

问的时候都需要获取一个句柄,也就是clk
 struct clk *clk;
  //clock provider driver初始化时的数据,数据被用来初始化clk_hw对应的clk_core数据结构。
 const struct clk_init_data *init;
};

struct clk_init_data {
  //该clock设备的名字
 const char  *name;
  //clock provider driver进行具体的 HW 操作
 const struct clk_ops *ops;
  //描述该clk_hw的拓扑结构
 const char  * const *parent_names;
 const struct clk_parent_data *parent_data;
 const struct clk_hw  **parent_hws;
 u8   num_parents;
 unsigned long  flags;
};
Nach dem Login kopieren

Nehmen Sie den Vibrator mit fester Frequenz als Beispiel. Seine Datenstruktur ist:

struct clk_fixed_rate {
  //下面是fixed rate这种clock device特有的成员
  struct        clk_hw hw;
  //基类
  unsigned long    fixed_rate;
  unsigned long    fixed_accuracy;
  u8        flags;
};
Nach dem Login kopieren

Dies ist wahrscheinlich bei anderen spezifischen Uhrengeräten der Fall, daher werde ich hier nicht auf Details eingehen.

Hier ist ein Bild, das die Beziehung zwischen diesen Datenstrukturen beschreibt:

一文搞懂 | Linux 时钟子系统

Registrierungsmethode

Da wir nun die Datenstruktur verstanden haben, schauen wir uns die Registrierungsmethode jedes Uhrentyps an.

1. Festpreisuhr

Diese Art von Uhr hat eine feste Frequenz. Sie kann nicht ein- oder ausgeschaltet werden, die Frequenz kann nicht angepasst werden und die übergeordnete Uhr ist nicht wählbar. Es kann direkt über die DTS-Konfiguration unterstützt werden. Sie können eine Uhr mit festem Takt auch direkt über die Schnittstelle registrieren, wie folgt:

CLK_OF_DECLARE(fixed_clk, "fixed-clock", of_fixed_clk_setup);

struct clk *clk_register_fixed_rate(struct device *dev, const char *name,
                const char *parent_name, unsigned long flags,
                unsigned long fixed_rate);
Nach dem Login kopieren

2. Toruhr

Diese Art von Uhr kann nur ein- und ausgeschaltet werden (.enable/.disable-Rückrufe werden bereitgestellt), und Sie können die folgende Schnittstelle zur Registrierung verwenden:

struct clk *clk_register_gate(struct device *dev, const char *name,
                const char *parent_name, unsigned long flags,
                void __iomem *reg, u8 bit_idx,
                u8 clk_gate_flags, spinlock_t *lock);
Nach dem Login kopieren

3. Teileruhr

Diese Art von Uhr kann den Frequenzteilungswert festlegen (und somit .recalc_rate/.set_rate/.round_rate-Rückrufe bereitstellen) und kann über die folgenden zwei Schnittstellen registriert werden:

struct clk *clk_register_divider(struct device *dev, const char *name,
                const char *parent_name, unsigned long flags,
                void __iomem *reg, u8 shift, u8 width,
                u8 clk_divider_flags, spinlock_t *lock);
                
struct clk *clk_register_divider_table(struct device *dev, const char *name,
                const char *parent_name, unsigned long flags,
                void __iomem *reg, u8 shift, u8 width,
                u8 clk_divider_flags, const struct clk_div_table *table,
                spinlock_t *lock);
Nach dem Login kopieren

4. Mux-Uhr

Diese Art von Uhr kann mehrere Eltern auswählen, da sie den Rückruf .get_parent/.set_parent/.recalc_rate implementiert und über die folgenden zwei Schnittstellen registriert werden kann:

struct clk *clk_register_mux(struct device *dev, const char *name,
                const char **parent_names, u8 num_parents, unsigned long flags,
                void __iomem *reg, u8 shift, u8 width,
                u8 clk_mux_flags, spinlock_t *lock);
                
struct clk *clk_register_mux_table(struct device *dev, const char *name,
                const char **parent_names, u8 num_parents, unsigned long flags,
                void __iomem *reg, u8 shift, u32 mask,
                u8 clk_mux_flags, u32 *table, spinlock_t *lock);
Nach dem Login kopieren

5. Uhr mit festem Faktor

Diese Art von Uhr hat einen festen Faktor (d. h. Multiplikator und Teiler). Die Frequenz der Uhr ist die Frequenz der übergeordneten Uhr, multipliziert mit mul und dividiert durch div. Sie wird hauptsächlich für einige Uhren mit festen Frequenzteilungskoeffizienten verwendet . Da die Frequenz der übergeordneten Uhr geändert werden kann, kann auch die Frequenz der Uhr mit festem Faktor geändert werden, sodass auch Rückrufe wie .recalc_rate/.set_rate/.round_rate bereitgestellt werden. Sie können sich über die folgende Schnittstelle registrieren:

struct clk *clk_register_fixed_factor(struct device *dev, const char *name,
                const char *parent_name, unsigned long flags,
                unsigned int mult, unsigned int div);
Nach dem Login kopieren

6. Verbunduhr

Wie der Name schon sagt, handelt es sich um eine Kombination aus Mux, Divider, Gate und anderen Uhren. Sie kann über die folgende Schnittstelle registriert werden:

struct clk *clk_register_composite(struct device *dev, const char *name,
                const char **parent_names, int num_parents,
                struct clk_hw *mux_hw, const struct clk_ops *mux_ops,
                struct clk_hw *rate_hw, const struct clk_ops *rate_ops,
                struct clk_hw *gate_hw, const struct clk_ops *gate_ops,
                unsigned long flags);
Nach dem Login kopieren

Diese Registrierungsfunktionen werden schließlich im Common Clock Framework über die Funktion clk_register registriert und geben einen Struktur-Clk-Zeiger zurück. Wie unten gezeigt:

一文搞懂 | Linux 时钟子系统

Speichern Sie dann den zurückgegebenen struct clk-Zeiger in einem Array und rufen Sie die Schnittstelle of_clk_add_provider auf, um das Common Clock Framework zu informieren.

Clock Consumer

获取 clock

即通过 clock 名称获取 struct clk 指针的过程,由 clk_get、devm_clk_get、clk_get_sys、of_clk_get、of_clk_get_by_name、of_clk_get_from_provider 等接口负责实现,这里以 clk_get 为例,分析其实现过程:

struct clk *clk_get(struct device *dev, const char *con_id)
{
 const char *dev_id = dev ? dev_name(dev) : NULL;
 struct clk *clk;

 if (dev) {
  //通过扫描所有“clock-names”中的值,和传入的name比较,如果相同,获得它的index(即“clock-names”中的

第几个),调用of_clk_get,取得clock指针。
  clk = __of_clk_get_by_name(dev->of_node, dev_id, con_id);
  if (!IS_ERR(clk) || PTR_ERR(clk) == -EPROBE_DEFER)
   return clk;
 }

 return clk_get_sys(dev_id, con_id);
}
struct clk *of_clk_get(struct device_node *np, int index)
{
        struct of_phandle_args clkspec;
        struct clk *clk;
        int rc;
 
        if (index return ERR_PTR(-EINVAL);
 
        rc = of_parse_phandle_with_args(np, "clocks", "#clock-cells", index,
                                        &clkspec);
        if (rc)
                return ERR_PTR(rc);
       //获取clock指针
        clk = of_clk_get_from_provider(&clkspec);
        of_node_put(clkspec.np);
        return clk;
}
Nach dem Login kopieren

of_clk_get_from_provider 通过便利 of_clk_providers 链表,并调用每一个 provider 的 get 回调函数,获取 clock 指针。如下:

struct clk *of_clk_get_from_provider(struct of_phandle_args *clkspec)
{
        struct of_clk_provider *provider;
        struct clk *clk = ERR_PTR(-ENOENT);
 
        /* Check if we have such a provider in our array */
        mutex_lock(&of_clk_lock);
        list_for_each_entry(provider, &of_clk_providers, link) {
                if (provider->node == clkspec->np)
                        clk = provider->get(clkspec, provider->data);
                if (!IS_ERR(clk))
                        break;
        }
        mutex_unlock(&of_clk_lock);
 
        return clk;
}
Nach dem Login kopieren

至此,ConsumerProvider 里讲的 of_clk_add_provider 对应起来了。

操作 clock

//启动clock前的准备工作/停止clock后的善后工作。可能会睡眠。
int clk_prepare(struct clk *clk)
void clk_unprepare(struct clk *clk)
 
//启动/停止clock。不会睡眠。
static inline int clk_enable(struct clk *clk)
static inline void clk_disable(struct clk *clk)

//clock频率的获取和设置
static inline unsigned long clk_get_rate(struct 
clk *clk)
static inline int clk_set_rate(struct clk *clk, unsigned long rate)
static inline long clk_round_rate(struct clk *clk, unsigned long rate)

//获取/选择clock的parent clock
static inline int clk_set_parent(struct clk *clk, struct clk *parent)
static inline struct clk *clk_get_parent(struct clk *clk)
 
//将clk_prepare和clk_enable组合起来,一起调用。将clk_disable和clk_unprepare组合起来,一起调用
static inline int clk_prepare_enable(struct clk *clk)
static inline void clk_disable_unprepare(struct clk *clk)
Nach dem Login kopieren

总结

一文搞懂 | Linux 时钟子系统

Das obige ist der detaillierte Inhalt vonIn einem Artikel verstehen |. Linux-Uhr-Subsystem. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Android TV Box erhält inoffizielles Ubuntu 24.04-Upgrade Android TV Box erhält inoffizielles Ubuntu 24.04-Upgrade Sep 05, 2024 am 06:33 AM

Für viele Benutzer klingt das Hacken einer Android-TV-Box entmutigend. Allerdings stand Entwickler Murray R. Van Luyn während der Broadcom-Chipknappheit vor der Herausforderung, nach geeigneten Alternativen zum Raspberry Pi zu suchen. Seine Zusammenarbeit mit der Armbia

Deepseek Web Version Eingang Deepseek Offizielle Website Eingang Deepseek Web Version Eingang Deepseek Offizielle Website Eingang Feb 19, 2025 pm 04:54 PM

Deepseek ist ein leistungsstarkes Intelligent -Such- und Analyse -Tool, das zwei Zugriffsmethoden bietet: Webversion und offizielle Website. Die Webversion ist bequem und effizient und kann ohne Installation verwendet werden. Unabhängig davon, ob Einzelpersonen oder Unternehmensnutzer, können sie massive Daten über Deepseek problemlos erhalten und analysieren, um die Arbeitseffizienz zu verbessern, die Entscheidungsfindung zu unterstützen und Innovationen zu fördern.

So installieren Sie Deepseek So installieren Sie Deepseek Feb 19, 2025 pm 05:48 PM

Es gibt viele Möglichkeiten, Deepseek zu installieren, einschließlich: kompilieren Sie von Quelle (für erfahrene Entwickler) mit vorberechtigten Paketen (für Windows -Benutzer) mit Docker -Containern (für bequem am besten, um die Kompatibilität nicht zu sorgen), unabhängig von der Methode, die Sie auswählen, bitte lesen Die offiziellen Dokumente vorbereiten sie sorgfältig und bereiten sie voll und ganz vor, um unnötige Schwierigkeiten zu vermeiden.

BitPie Bitpie-Wallet-App-Download-Adresse BitPie Bitpie-Wallet-App-Download-Adresse Sep 10, 2024 pm 12:10 PM

Wie lade ich die BitPie Bitpie Wallet-App herunter? Die Schritte sind wie folgt: Suchen Sie im AppStore (Apple-Geräte) oder Google Play Store (Android-Geräte) nach „BitPie Bitpie Wallet“. Klicken Sie auf die Schaltfläche „Get“ oder „Install“, um die App herunterzuladen. Besuchen Sie für die Computerversion die offizielle BitPie-Wallet-Website und laden Sie das entsprechende Softwarepaket herunter.

Bitget Offizielle Website -Installation (2025 Anfängerhandbuch) Bitget Offizielle Website -Installation (2025 Anfängerhandbuch) Feb 21, 2025 pm 08:42 PM

Bitget ist eine Kryptowährungsbörse, die eine Vielzahl von Handelsdienstleistungen anbietet, darunter Spot -Handel, Vertragshandel und Derivate. Der 2018 gegründete Austausch hat seinen Hauptsitz in Singapur und verpflichtet sich, den Benutzern eine sichere und zuverlässige Handelsplattform zu bieten. Bitget bietet eine Vielzahl von Handelspaaren, einschließlich BTC/USDT, ETH/USDT und XRP/USDT. Darüber hinaus hat der Austausch einen Ruf für Sicherheit und Liquidität und bietet eine Vielzahl von Funktionen wie Premium -Bestellarten, gehebelter Handel und Kundenunterstützung rund um die Uhr.

Installation der Quellcode-Kompilierung von Zabbix 3.4 Installation der Quellcode-Kompilierung von Zabbix 3.4 Sep 04, 2024 am 07:32 AM

1. Installationsumgebung (virtuelle Hyper-V-Maschine): $hostnamectlStatichostname:localhost.localdomainIconname:computer-vmChassis:vmMachineID:renwoles1d8743989a40cb81db696400BootID:renwoles272f4aa59935dcdd0d456501Virtualisierung:microsoftOperatingSystem:CentOS 7(Kern)CPEOSName:cpe:

Ouyi OKX Installationspaket ist direkt enthalten Ouyi OKX Installationspaket ist direkt enthalten Feb 21, 2025 pm 08:00 PM

Ouyi Okx, die weltweit führende digitale Asset Exchange, hat jetzt ein offizielles Installationspaket gestartet, um ein sicheres und bequemes Handelserlebnis zu bieten. Auf das OKX -Installationspaket von Ouyi muss nicht über einen Browser zugegriffen werden. Der Installationsprozess ist einfach und einfach zu verstehen.

Holen Sie sich das Installationspaket Gate.io kostenlos Holen Sie sich das Installationspaket Gate.io kostenlos Feb 21, 2025 pm 08:21 PM

Gate.io ist ein beliebter Kryptowährungsaustausch, den Benutzer verwenden können, indem sie sein Installationspaket herunterladen und auf ihren Geräten installieren. Die Schritte zum Abholen des Installationspakets sind wie folgt: Besuchen Sie die offizielle Website von Gate.io, klicken Sie auf "Download", wählen Sie das entsprechende Betriebssystem (Windows, Mac oder Linux) und laden Sie das Installationspaket auf Ihren Computer herunter. Es wird empfohlen, die Antiviren -Software oder -Firewall während der Installation vorübergehend zu deaktivieren, um eine reibungslose Installation zu gewährleisten. Nach Abschluss muss der Benutzer ein Gate.io -Konto erstellen, um es zu verwenden.

See all articles