Home
last modified time | relevance | path

Searched refs:di (Results 1 – 25 of 213) sorted by relevance

123456789

/linux/drivers/net/wireless/broadcom/brcm80211/brcmsmac/
H A Ddma.c38 #define DMA64TXREGOFFS(di, field) (di->d64txregbase + DMA64REGOFFS(field)) argument
39 #define DMA64RXREGOFFS(di, field) (di->d64rxregbase + DMA64REGOFFS(field)) argument
313 static uint txd(struct dma_info *di, uint x) in txd() argument
315 return xxd(x, di->ntxd); in txd()
318 static uint rxd(struct dma_info *di, uint x) in rxd() argument
320 return xxd(x, di->nrxd); in rxd()
323 static uint nexttxd(struct dma_info *di, uint i) in nexttxd() argument
325 return txd(di, i + 1); in nexttxd()
328 static uint prevtxd(struct dma_info *di, uint i) in prevtxd() argument
330 return txd(di, i - 1); in prevtxd()
[all …]
/linux/drivers/regulator/
H A Dfan53555.c156 struct fan53555_device_info *di = rdev_get_drvdata(rdev); in fan53555_set_suspend_voltage() local
159 if (di->sleep_vol_cache == uV) in fan53555_set_suspend_voltage()
164 ret = regmap_update_bits(rdev->regmap, di->sleep_reg, in fan53555_set_suspend_voltage()
165 di->desc.vsel_mask, ret); in fan53555_set_suspend_voltage()
170 di->sleep_vol_cache = uV; in fan53555_set_suspend_voltage()
177 struct fan53555_device_info *di = rdev_get_drvdata(rdev); in fan53555_set_suspend_enable() local
179 return regmap_update_bits(rdev->regmap, di->sleep_en_reg, in fan53555_set_suspend_enable()
185 struct fan53555_device_info *di = rdev_get_drvdata(rdev); in fan53555_set_suspend_disable() local
187 return regmap_update_bits(rdev->regmap, di->sleep_en_reg, in fan53555_set_suspend_disable()
193 struct fan53555_device_info *di = rdev_get_drvdata(rdev); in fan53555_set_mode() local
[all …]
H A Dsy8827n.c41 struct sy8827n_device_info *di = rdev_get_drvdata(rdev); in sy8827n_set_mode() local
45 regmap_update_bits(rdev->regmap, di->vsel_reg, in sy8827n_set_mode()
49 regmap_update_bits(rdev->regmap, di->vsel_reg, in sy8827n_set_mode()
60 struct sy8827n_device_info *di = rdev_get_drvdata(rdev); in sy8827n_get_mode() local
64 ret = regmap_read(rdev->regmap, di->vsel_reg, &val); in sy8827n_get_mode()
86 static int sy8827n_regulator_register(struct sy8827n_device_info *di, in sy8827n_regulator_register() argument
89 struct regulator_desc *rdesc = &di->desc; in sy8827n_regulator_register()
97 rdesc->enable_reg = di->vsel_reg; in sy8827n_regulator_register()
101 rdesc->vsel_reg = di->vsel_reg; in sy8827n_regulator_register()
105 rdev = devm_regulator_register(di->dev, &di->desc, config); in sy8827n_regulator_register()
[all …]
H A Dmp886x.c45 static void mp886x_set_switch_freq(struct mp886x_device_info *di, in mp886x_set_switch_freq() argument
49 const struct mp886x_cfg_info *ci = di->ci; in mp886x_set_switch_freq()
60 dev_err(di->dev, "invalid frequency %d\n", freq); in mp886x_set_switch_freq()
117 struct mp886x_device_info *di = rdev_get_drvdata(rdev); in mp8869_get_voltage_sel() local
129 uv = mp8869_scale(uv, di->r[0], di->r[1]); in mp8869_get_voltage_sel()
177 struct mp886x_device_info *di = rdev_get_drvdata(rdev); in mp8867_set_voltage_sel() local
184 delta = di->sel - sel; in mp8867_set_voltage_sel()
188 di->sel = sel; in mp8867_set_voltage_sel()
195 struct mp886x_device_info *di = rdev_get_drvdata(rdev); in mp8867_get_voltage_sel() local
211 uv = mp8869_scale(uv, di->r[0], di->r[1]); in mp8867_get_voltage_sel()
[all …]
H A Dsy8824x.c40 struct sy8824_device_info *di = rdev_get_drvdata(rdev); in sy8824_set_mode() local
41 const struct sy8824_config *cfg = di->cfg; in sy8824_set_mode()
60 struct sy8824_device_info *di = rdev_get_drvdata(rdev); in sy8824_get_mode() local
61 const struct sy8824_config *cfg = di->cfg; in sy8824_get_mode()
87 static int sy8824_regulator_register(struct sy8824_device_info *di, in sy8824_regulator_register() argument
90 struct regulator_desc *rdesc = &di->desc; in sy8824_regulator_register()
91 const struct sy8824_config *cfg = di->cfg; in sy8824_regulator_register()
107 rdev = devm_regulator_register(di->dev, &di->desc, config); in sy8824_regulator_register()
129 struct sy8824_device_info *di; in sy8824_i2c_probe() local
134 di = devm_kzalloc(dev, sizeof(struct sy8824_device_info), GFP_KERNEL); in sy8824_i2c_probe()
[all …]
/linux/drivers/power/supply/
H A Dds2760_battery.c254 static int ds2760_battery_read_status(struct ds2760_device_info *di) in ds2760_battery_read_status() argument
258 if (di->update_time && time_before(jiffies, di->update_time + in ds2760_battery_read_status()
264 if (di->update_time == 0) { in ds2760_battery_read_status()
272 ret = w1_ds2760_read(di->dev, di->raw + start, start, count); in ds2760_battery_read_status()
274 dev_warn(di->dev, "call to w1_ds2760_read failed (0x%p)\n", in ds2760_battery_read_status()
275 di->dev); in ds2760_battery_read_status()
279 di->update_time = jiffies; in ds2760_battery_read_status()
283 di->voltage_raw = (di->raw[DS2760_VOLTAGE_MSB] << 3) | in ds2760_battery_read_status()
284 (di->raw[DS2760_VOLTAGE_LSB] >> 5); in ds2760_battery_read_status()
285 di->voltage_uV = di->voltage_raw * 4880; in ds2760_battery_read_status()
[all …]
H A Dbq27xxx_battery_i2c.c21 struct bq27xxx_device_info *di = data; in bq27xxx_battery_irq_handler_thread() local
23 bq27xxx_battery_update(di); in bq27xxx_battery_irq_handler_thread()
28 static int bq27xxx_battery_i2c_read(struct bq27xxx_device_info *di, u8 reg, in bq27xxx_battery_i2c_read() argument
31 struct i2c_client *client = to_i2c_client(di->dev); in bq27xxx_battery_i2c_read()
73 static int bq27xxx_battery_i2c_write(struct bq27xxx_device_info *di, u8 reg, in bq27xxx_battery_i2c_write() argument
76 struct i2c_client *client = to_i2c_client(di->dev); in bq27xxx_battery_i2c_write()
105 static int bq27xxx_battery_i2c_bulk_read(struct bq27xxx_device_info *di, u8 reg, in bq27xxx_battery_i2c_bulk_read() argument
108 struct i2c_client *client = to_i2c_client(di->dev); in bq27xxx_battery_i2c_bulk_read()
122 static int bq27xxx_battery_i2c_bulk_write(struct bq27xxx_device_info *di, in bq27xxx_battery_i2c_bulk_write() argument
125 struct i2c_client *client = to_i2c_client(di->dev); in bq27xxx_battery_i2c_bulk_write()
[all …]
H A Dbq27xxx_battery_hdq.c40 static int bq27xxx_battery_hdq_read(struct bq27xxx_device_info *di, u8 reg, in bq27xxx_battery_hdq_read() argument
43 struct w1_slave *sl = dev_to_w1_slave(di->dev); in bq27xxx_battery_hdq_read()
77 struct bq27xxx_device_info *di; in bq27xxx_battery_hdq_add_slave() local
79 di = devm_kzalloc(&sl->dev, sizeof(*di), GFP_KERNEL); in bq27xxx_battery_hdq_add_slave()
80 if (!di) in bq27xxx_battery_hdq_add_slave()
83 dev_set_drvdata(&sl->dev, di); in bq27xxx_battery_hdq_add_slave()
85 di->dev = &sl->dev; in bq27xxx_battery_hdq_add_slave()
86 di->chip = BQ27000; in bq27xxx_battery_hdq_add_slave()
87 di->name = "bq27000-battery"; in bq27xxx_battery_hdq_add_slave()
88 di->bus.read = bq27xxx_battery_hdq_read; in bq27xxx_battery_hdq_add_slave()
[all …]
/linux/drivers/gpu/ipu-v3/
H A Dipu-di.c123 static inline u32 ipu_di_read(struct ipu_di *di, unsigned offset) in ipu_di_read() argument
125 return readl(di->base + offset); in ipu_di_read()
128 static inline void ipu_di_write(struct ipu_di *di, u32 value, unsigned offset) in ipu_di_write() argument
130 writel(value, di->base + offset); in ipu_di_write()
133 static void ipu_di_data_wave_config(struct ipu_di *di, in ipu_di_data_wave_config() argument
140 ipu_di_write(di, reg, DI_DW_GEN(wave_gen)); in ipu_di_data_wave_config()
143 static void ipu_di_data_pin_config(struct ipu_di *di, int wave_gen, int di_pin, in ipu_di_data_pin_config() argument
148 reg = ipu_di_read(di, DI_DW_GEN(wave_gen)); in ipu_di_data_pin_config()
151 ipu_di_write(di, reg, DI_DW_GEN(wave_gen)); in ipu_di_data_pin_config()
153 ipu_di_write(di, (down << 16) | up, DI_DW_SET(wave_gen, set)); in ipu_di_data_pin_config()
[all …]
/linux/Documentation/translations/it_IT/locking/
H A Dlocktorture.rst12 L'opzione di configurazione CONFIG_LOCK_TORTURE_TEST fornisce un
13 modulo kernel che esegue delle verifiche che *torturano* le primitive di
20 programma si basa sulle modalità di verifica di RCU tramite rcutorture.
22 Questa verifica consiste nella creazione di un certo numero di thread
24 quantità di tempo così da simulare diversi comportamenti nelle sezioni
25 critiche. La quantità di contese su un blocco può essere simulata
35 Specifici di locktorture
39 Numero di thread del kernel che stresseranno l'acquisizione
40 esclusiva dei blocchi (scrittori). Il valore di base è il
41 doppio del numero di processori attivi presenti.
[all …]
H A Dlockstat.rst24 *Lockdep* ha punti di collegamento nelle funzioni di blocco e inoltre
25 mappa le istanze di blocco con le relative classi. Partiamo da questo punto
28 funzioni di blocco e i vari punti di collegamenti che ci sono al loro
51 lock, unlock - le classiche funzioni di blocco
52 __* - i punti di collegamento
55 Grazie a questi punti di collegamento possiamo fornire le seguenti statistiche:
58 - numero di contese su un blocco che riguarda dati di un processore
61 - numero di acquisizioni di blocchi che hanno dovuto attendere
65 - tempo minimo (diverso da zero) che sia mai stato speso in attesa di
69 - tempo massimo che sia mai stato speso in attesa di un blocco
[all …]
H A Dlockdep-design.rst5 Validatore di sincronizzazione durante l'esecuzione
8 Classi di blocchi
11 L'oggetto su cui il validatore lavora è una "classe" di blocchi.
13 Una classe di blocchi è un gruppo di blocchi che seguono le stesse regole di
15 decine di migliaia). Per esempio un blocco nella struttura inode è una classe,
16 mentre ogni inode sarà un'istanza di questa classe di blocco.
18 Il validatore traccia lo "stato d'uso" di una classe di blocchi e le sue
19 dipendenze con altre classi. L'uso di un blocco indica come quel blocco viene
20 usato rispetto al suo contesto d'interruzione, mentre le dipendenze di un blocco
22 che un processo cerca di acquisire L2 mentre già trattiene L1. Dal punto di
[all …]
/linux/Documentation/translations/it_IT/process/
H A D1.Intro.rst14 Il resto di questa sezione riguarda il processo di sviluppo del kernel e
15 quella sorta di frustrazione che gli sviluppatori e i loro datori di lavoro
19 differenti modalità, e la capacità di influenzare la direzione dello sviluppo
24 La sezione :ref:`it_development_process` introduce il processo di sviluppo,
25 il ciclo di rilascio del kernel, ed i meccanismi della finestra
26 d'incorporazione. Il capitolo copre le varie fasi di una modifica: sviluppo,
28 liste di discussione. Gli sviluppatori che sono in attesa di poter sviluppare
33 pianificazione di un progetto di sviluppo, con particolare enfasi sul
36 La sezione :ref:`it_development_coding` riguarda il processo di scrittura
42 La sezione :ref:`it_development_posting` parla del processo di pubblicazione
[all …]
H A Ddeprecated.rst14 In un mondo perfetto, sarebbe possibile prendere tutti gli usi di
16 possibile rimuovere la vecchia interfaccia in un singolo ciclo di sviluppo.
18 le tempistiche, non è sempre possibile fare questo tipo di conversione tutta
19 in una volta. Questo significa che nuove istanze di una vecchia interfaccia
20 potrebbero aggiungersi al kernel proprio quando si sta cercando di rimuoverle,
21 aumentando così il carico di lavoro. Al fine di istruire gli sviluppatori su
30 perché uno degli obiettivi del kernel è quello di compilare senza avvisi;
32 di `__deprecated` in un file d'intestazione sia opportuno per segnare una
45 sono stati ripristinati?). Molto spesso l'uso di BUG()
47 impossibile un'attività di debug o anche solo leggere un rapporto
[all …]
H A D3.Early-stage.rst11 Osservando un progetto di sviluppo per il kernel Linux, si potrebbe essere
14 viene fatta prima che una sola linea di codice venga scritta. Il tempo speso
21 Come qualsiasi progetto ingegneristico, un miglioramento del kernel di
26 può portare all'emergere di problemi.
35 lista di discussione linux-kernel, dove incontrò subito dei problemi.
37 Per gli sviluppatori audio, questo modulo di sicurezza era sufficiente a
41 e un rischio per la stabilità del sistema. Le loro soluzioni di punta nel
46 La comunità audio, comunque, non poteva vedere al di là della singola
48 Il conseguente dissenso lasciò in quegli sviluppatori un senso di
49 disillusione nei confronti dell'intero processo di sviluppo; uno di loro
[all …]
H A Dvolatile-considered-harmful.rst12 essere cambiate al di fuori dal thread di esecuzione corrente; come risultato,
15 *volatile* come una variabile atomica di facile utilizzo, ma non è così.
16 L'uso di *volatile* nel kernel non è quasi mai corretto; questo documento ne
19 Il punto chiave da capire su *volatile* è che il suo scopo è quello di
23 Il processo di protezione contro gli accessi concorrenti indesiderati eviterà
28 (spinlock, mutex, barriere di sincronizzazione, ecc) sono progettate per
30 non ci sarà bisogno di utilizzare *volatile*. Se vi sembra che *volatile* sia
32 In un pezzo di codice kernel scritto a dovere, *volatile* può solo servire a
35 Considerate questo tipico blocco di codice kernel::
42 Se tutto il codice seguisse le regole di sincronizzazione, il valore di un
[all …]
H A Dmanagement-style.rst8 Il modello di gestione del kernel Linux
11 Questo breve documento descrive il modello di gestione del kernel Linux.
14 ed è principalmente scritto per evitare di rispondere [#f1]_ in continuazione
17 Il modello di gestione è qualcosa di molto personale e molto più difficile da
18 qualificare rispetto a delle semplici regole di codifica, quindi questo
26 occupate di convalidare acquisti o avete una qualche idea sul budget del vostro
30 Prima di tutto, suggerirei di acquistare "Le sette regole per avere successo",
31 e di non leggerlo. Bruciatelo, è un grande gesto simbolico.
35 di come rispondere.
49 Il gioco consiste nell'"evitare" di dover prendere decisioni. In particolare
[all …]
H A Dmaintainer-pgp-guide.rst23 Il ruolo di PGP nello sviluppo del kernel Linux
27 di sviluppo del kernel e, in secondo luogo, stabilisce canali di comunicazione
28 affidabili tra sviluppatori attraverso lo scambio di email firmate con PGP.
33 - repositori distribuiti di sorgenti (git)
34 - rilasci periodici di istantanee (archivi tar)
40 hanno sul loro posto di lavoro. A tal scopo:
50 Fin dal 2011, quando i sistemi di kernel.org furono compromessi, il principio
51 generale del progetto Kernel Archives è stato quello di assumere che qualsiasi
56 pratiche di sicurezza messe in atto.
60 non sia fatto semplicemente per incolpare qualcun'altro per future falle di
[all …]
H A Dbotching-up-ioctls.rst6 (Come evitare di) Raffazzonare delle ioctl
14 imparato negli ultimi anni è l'inutilità di cercare di creare un'interfaccia
15 unificata per gestire la memoria e le unità esecutive di diverse GPU. Dunque,
16 oggigiorno ogni driver ha il suo insieme di ioctl per allocare memoria ed
18 sistema che finge di essere generico, ma al suo posto ci sono interfacce
21 Per evitare di ripetere gli stessi errori ho preso nota delle lezioni imparate
22 mentre raffazzonavo il driver drm/i915. La maggior parte di queste lezioni si
25 GPU. Probabilmente, ogni sviluppatore di driver per GPU dovrebbe imparare queste
33 partenza e ritrovarvi ad aggiungere un livello di compatibilità a 32-bit.
48 quando si passano vettori di strutture dati al kernel, o quando il kernel
[all …]
H A D7.AdvancedTopics.rst12 di sviluppo. Ma rimane comunque molto da imparare! Questo capitolo copre
14 per diventare parte integrante del processo di sviluppo del kernel.
19 L'uso di un sistema distribuito per il controllo delle versioni del kernel
21 BitKeeper. Nonostante l'uso di BitKeeper fosse opinabile, di certo il suo
25 peggio, il progetto del kernel ha deciso di usare git per gestire i sorgenti.
30 strumento giovane e potente che è ancora in fase di civilizzazione da parte
31 dei suoi sviluppatori. Questo documento non ha lo scopo di insegnare l'uso
32 di git ai suoi lettori; ci sarebbe materiale a sufficienza per un lungo
34 git è parte del processo di sviluppo del kernel. Gli sviluppatori che
44 La prima cosa da fare prima di usarlo per produrre patch che saranno
[all …]
H A D6.Followthrough.rst14 perfetta di patch. Uno dei più grandi errori che possono essere commessi
15 persino da sviluppatori kernel esperti è quello di concludere che il
18 probabilmente, ancora un po' di lavoro da fare.
21 ci sia alcuno spazio di miglioramento. Il programma di sviluppo del kernel
23 del codice pubblicato. Voi, in qualità di autori del codice, dovrete
33 da parte di altri sviluppatori dato che avranno revisionato il codice.
35 più intimidatoria del processo di sviluppo del kernel. La vita può esservi
39 comprenderanno il valore e il perché vi siete presi il disturbo di
43 richiesti - da piccoli problemi di stile a sostanziali ristesure -
53 tentazione di rispondere a tono. La revisione riguarda il codice e non
[all …]
/linux/Documentation/translations/it_IT/i2c/
H A Di2c-protocol.rst5 Questo documento è una panoramica delle transazioni di base I2C e delle API
12 S Condizione di avvio
13 P Condizione di stop
14 Rd/Wr (1 bit) Bit di lettura/scrittura. Rd vale 1, Wr vale 0.
15 A, NA (1 bit) Bit di riconoscimento (ACK) e di non riconoscimento (NACK).
18 Dati (8 bit) Un byte di dati.
25 Transazione semplice di invio
33 Transazione semplice di ricezione
46 Sono come le transazioni di cui sopra, ma invece di uno condizione di stop P
47 viene inviata una condizione di inizio S e la transazione continua.
[all …]
/linux/fs/bfs/
H A Dinode.c37 struct bfs_inode *di; in bfs_iget() local
62 di = (struct bfs_inode *)bh->b_data + off; in bfs_iget()
76 inode->i_mode = 0x00000FFF & le32_to_cpu(di->i_mode); in bfs_iget()
77 if (le32_to_cpu(di->i_vtype) == BFS_VDIR) { in bfs_iget()
81 } else if (le32_to_cpu(di->i_vtype) == BFS_VREG) { in bfs_iget()
89 le32_to_cpu(di->i_vtype), inode->i_sb->s_id, ino); in bfs_iget()
93 BFS_I(inode)->i_sblock = le32_to_cpu(di->i_sblock); in bfs_iget()
94 BFS_I(inode)->i_eblock = le32_to_cpu(di->i_eblock); in bfs_iget()
95 BFS_I(inode)->i_dsk_ino = le16_to_cpu(di->i_ino); in bfs_iget()
96 i_uid_write(inode, le32_to_cpu(di->i_uid)); in bfs_iget()
[all …]
/linux/Documentation/translations/it_IT/RCU/
H A Dtorture.rst12 L'opzione CONFIG_RCU_TORTURE_TEST è disponibile per tutte le implementazione di
18 I parametri di modulo hanno tutti il prefisso "rcutortute.", vedere
35 usare altri comandi per visualizzare i messaggi di printk(). La funzione
38 La prima e l'ultima riga mostrano i parametri di module di rcutorture, e solo
47 * "ver": Il numero di volte dall'avvio che il processo scrittore di RCU ha
50 * "tfle": se non è zero, indica la lista di strutture "torture freelist" da
54 * "rta": numero di strutture allocate dalla lista "torture freelist".
56 * "rtaf": il numero di allocazioni fallite dalla lista "torture freelist" a
58 un brutto segno se questo numero rappresenta una frazione troppo alta di
61 * "rtf": il numero di rilasci nella lista "torture freelist"
[all …]
/linux/Documentation/translations/it_IT/core-api/
H A Dsymbol-namespaces.rst17 l'API esposta internamente al kernel. Permette ai manutentori di un
18 sottosistema di organizzare i simboli esportati in diversi spazi di
21 la disponibilità di un gruppo di simboli in altre parti del kernel. Ad
22 oggi, i moduli che usano simboli esportati da uno spazio di nomi
24 della configurazione, potrebbe rifiutare di caricare il modulo o
25 avvisare l'utente di un'importazione mancante.
32 EXPORT_SYMBOL e simili vengono guidati verso la creazione di voci in ksymtab.
38 di esportare simboli del kernel nella rispettiva tabella, ci sono
39 varianti che permettono di esportare simboli all'interno di uno spazio dei
43 essere un simbolo di preprocessore. Per esempio per esportare il
[all …]

123456789