From: Sergey Vlasov <vsu@altlinux.ru> To: gosha <embedded@nm.ru>, ALT Linux kernel packages development <devel-kernel@lists.altlinux.org> Subject: Re: [d-kernel] -немного недопонял, - В kernel 2.6.16 теперь ждущие блокировки spinlock() не работают?] (Sergey Vlasov) Date: Mon, 19 Jun 2006 14:04:27 +0400 Message-ID: <20060619100427.GN3206@master.mivlgu.local> (raw) In-Reply-To: <1601758466.20060619092020@nm.ru> [-- Attachment #1: Type: text/plain, Size: 2567 bytes --] On Mon, Jun 19, 2006 at 09:20:20AM +0000, gosha wrote: > >Значит, этот тест был выполнен на ядре *-up, где spin_lock() > >действительно ничего не делает. Spinlock используются только на SMP > >для синхронизации между несколькими процессорами. Код, пытающийся > >рекурсивно захватить один и тот же spinlock на одном процессоре, > >недопустим - это гарантированный deadlock. > > > И в include/linux/spinlock*.h ничего похожего на разблокировку/ блокировку .... > > >Все реализации spinlock архитектурно-зависимые, и поэтому лежат в > >include/asm-*. [...] > Т.е. для однопроцессорных систем ждущие блокировки spinlock() и не > должны ничего делать в принципе?? Судя по коду это так, но это как бы > нелогично... И что здесь нелогичного? Блокировки этого типа предназначены только для синхронизации на SMP, при наличии только одного процессора ждать просто нечего. > Напр касок кода /kernel/irq/hahdle.c : > ------------------------------------------------------- > /* do_IRQ handles all normal device IRQ's (the special SMP cross-CPU interrupts have their own specific handlers). */ > fastcall unsigned int __do_IRQ(unsigned int irq, struct pt_regs *regs) [...] spin_lock здесь обеспечивает защиту от модификации данных другими процессорами; предполагается, что на одном и том же процессоре __do_IRQ() не может быть вызвана рекурсивно для обработки того же самого прерывания. > Также все работает в режиме CONFIG_DEBUG_SPINLOCK : [...] Да, это сделано специально, чтобы была хоть какая-то возможность отлавливать некоторые ошибки в использовании spinlock без SMP. > Так и должно быть??? У меня во всех книжках по линуксу написано, что это > ждущая блокировка и оно должно работать как мутекс! spinlock и mutex в Linux - существенно разные типы блокировок. Блокировки типа semaphore/mutex могут использоваться только в том случае, если допускается переход в состояние ожидания (sleep) - в случае, если mutex уже занят другим процессом, выполняется переключение контекста на один из других процессов, готовых к выполнению. В случае spinlock выполняется просто ожидание освобождения в цикле без переключения контекста - поэтому spinlock может использоваться, например, в обработчике прерываний. Вообще, если в однопроцессорной системе процессор ожидает освобождения spinlock-а, освободить его теоретически мог бы только какой-то обработчик прерывания (если прерывания в этот момент разрешены), но подобное использование spinlock считается ошибкой, поэтому поведение их в подобном случае может быть любым. [-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
next prev parent reply other threads:[~2006-06-19 10:04 UTC|newest] Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top 2006-06-19 9:20 ` gosha 2006-06-19 10:04 ` Sergey Vlasov [this message] 2006-06-19 14:27 ` gosha
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20060619100427.GN3206@master.mivlgu.local \ --to=vsu@altlinux.ru \ --cc=devel-kernel@lists.altlinux.org \ --cc=embedded@nm.ru \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
ALT Linux kernel packages development This inbox may be cloned and mirrored by anyone: git clone --mirror http://lore.altlinux.org/devel-kernel/0 devel-kernel/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 devel-kernel devel-kernel/ http://lore.altlinux.org/devel-kernel \ devel-kernel@altlinux.org devel-kernel@altlinux.ru devel-kernel@altlinux.com public-inbox-index devel-kernel Example config snippet for mirrors. Newsgroup available over NNTP: nntp://lore.altlinux.org/org.altlinux.lists.devel-kernel AGPL code for this site: git clone https://public-inbox.org/public-inbox.git