* [PATCH 0/2] kconfig: allow use of relations other than (in)equality @ 2015-06-15 11:59 ` Jan Beulich 0 siblings, 0 replies; 7+ messages in thread From: Jan Beulich @ 2015-06-15 11:59 UTC (permalink / raw) To: Michal Marek; +Cc: pebolle, linux-kbuild, linux-kernel 1: allow use of relations other than (in)equality 2: re-generate *.c_shipped files after previous change Signed-off-by: Jan Beulich <jbeulich@suse.com> --- Note that while benign for the first patch, the second patch can only be applied cleanly on top of "kconfig: don't silently ignore unhandled characters" (commit 2e0d737fc7 in kbuild.git). ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH 0/2] kconfig: allow use of relations other than (in)equality @ 2015-06-15 11:59 ` Jan Beulich 0 siblings, 0 replies; 7+ messages in thread From: Jan Beulich @ 2015-06-15 11:59 UTC (permalink / raw) To: Michal Marek; +Cc: pebolle, linux-kbuild, linux-kernel 1: allow use of relations other than (in)equality 2: re-generate *.c_shipped files after previous change Signed-off-by: Jan Beulich <jbeulich@suse.com> --- Note that while benign for the first patch, the second patch can only be applied cleanly on top of "kconfig: don't silently ignore unhandled characters" (commit 2e0d737fc7 in kbuild.git). ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 0/2] kconfig: allow use of relations other than (in)equality 2015-06-15 11:59 ` Jan Beulich (?) @ 2015-06-15 12:18 ` Michal Marek -1 siblings, 0 replies; 7+ messages in thread From: Michal Marek @ 2015-06-15 12:18 UTC (permalink / raw) To: Jan Beulich; +Cc: pebolle, linux-kbuild, linux-kernel On 2015-06-15 13:59, Jan Beulich wrote: > 1: allow use of relations other than (in)equality > 2: re-generate *.c_shipped files after previous change > > Signed-off-by: Jan Beulich <jbeulich@suse.com> Applied to kbuild.git#kconfig now, thanks. Michal ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 0/2] kconfig: allow use of relations other than (in)equality 2015-06-15 11:59 ` Jan Beulich (?) (?) @ 2015-07-02 13:04 ` Martin Walch 2015-07-02 20:06 ` Michal Marek -1 siblings, 1 reply; 7+ messages in thread From: Martin Walch @ 2015-07-02 13:04 UTC (permalink / raw) To: Jan Beulich; +Cc: Michal Marek, pebolle, linux-kbuild, linux-kernel Hi, > 1: allow use of relations other than (in)equality I know it is a bit late for objections. Still, I want to point out that this looks to me like a major extension to the language. Kconfig is a configuration language, and as far as I can tell it is (intentionally) not Turing complete to keep the configuration simple and controllable. All relations that have been defined so far check for equality (or for being not equal). The new relations "<=", ">=", "<", and ">" add more expressiveness, potentially making the language actually more complex and reasoning harder. Once the new relations are added, it will be hard to get rid of them again. So, should this patch be reconsidered? Regards, Martin Walch -- ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 0/2] kconfig: allow use of relations other than (in)equality 2015-07-02 13:04 ` Martin Walch @ 2015-07-02 20:06 ` Michal Marek 2015-07-03 9:18 ` Paul Bolle 2015-07-04 15:47 ` Martin Walch 0 siblings, 2 replies; 7+ messages in thread From: Michal Marek @ 2015-07-02 20:06 UTC (permalink / raw) To: Martin Walch; +Cc: Jan Beulich, pebolle, linux-kbuild, linux-kernel Dne 2.7.2015 v 15:04 Martin Walch napsal(a): > Hi, > >> 1: allow use of relations other than (in)equality > > I know it is a bit late for objections. Still, I want to point out that > this looks to me like a major extension to the language. > > Kconfig is a configuration language, and as far as I can tell it is > (intentionally) not Turing complete to keep the configuration simple and > controllable. All relations that have been defined so far check for equality > (or for being not equal). The new relations "<=", ">=", "<", and ">" add more > expressiveness, potentially making the language actually more complex and > reasoning harder. The patch just adds four new binary operations of the same order as the existing == and !=, with a the semantics that everybody expects. And the grammar for kconfig expressions is so simplistic that you cannot even write things like (A && B) == (C && D). So turing completeness is not a topic here, neither before nor after this patch. Michal ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 0/2] kconfig: allow use of relations other than (in)equality 2015-07-02 20:06 ` Michal Marek @ 2015-07-03 9:18 ` Paul Bolle 2015-07-04 15:47 ` Martin Walch 1 sibling, 0 replies; 7+ messages in thread From: Paul Bolle @ 2015-07-03 9:18 UTC (permalink / raw) To: Martin Walch; +Cc: Michal Marek, Jan Beulich, linux-kbuild, linux-kernel On do, 2015-07-02 at 22:06 +0200, Michal Marek wrote: > The patch just adds four new binary operations of the same order as > the > existing == and !=, with a the semantics that everybody expects. And > the > grammar for kconfig expressions is so simplistic that you cannot even > write things like (A && B) == (C && D). So turing completeness is not > a > topic here, neither before nor after this patch. So, if you're worried by the complexity added by allowing these operations, you might considering keeping an eye out for patches that use them. Because, obviously, the review of those patches could also be used to demonstrate their downsides. Actually, since DEBUG_UART_8250_WORD already uses ">=", and that's now become legal, perhaps the downsides can already be demonstrated. Thanks, Paul Bolle ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 0/2] kconfig: allow use of relations other than (in)equality 2015-07-02 20:06 ` Michal Marek 2015-07-03 9:18 ` Paul Bolle @ 2015-07-04 15:47 ` Martin Walch 1 sibling, 0 replies; 7+ messages in thread From: Martin Walch @ 2015-07-04 15:47 UTC (permalink / raw) To: Michal Marek; +Cc: Jan Beulich, pebolle, linux-kbuild, linux-kernel On Thursday 02 July 2015 22:06:26 Michal Marek wrote: > The patch just adds four new binary operations of the same order as the > existing == and !=, with a the semantics that everybody expects. And the > grammar for kconfig expressions is so simplistic that you cannot even > write things like (A && B) == (C && D). So turing completeness is not a > topic here, neither before nor after this patch. I am not trying to say that the patch results in Turing completeness. The point of mentioning that the language is *not* Turing complete is that the language is simple enough to encode the configuration with formal methods, i.e. in particular with the means of propositional logic and SAT solving. This is also done by the VAMOS project [1] and has uncovered hundreds of bugs leading to more than 100 applied patches. Encoding equality in propositional logic is viable, while the new relations are predicates that are quite hard to capture in propositional logic. I do not say that there is no way at all to get this done, but "less than" and "greater than" are much more difficult in propositional logic than "equal to" and "not equal to". On Friday 03 July 2015 11:18:23 Paul Bolle wrote: > Actually, since > DEBUG_UART_8250_WORD already uses ">=", and that's now become legal, > perhaps the downsides can already be demonstrated. Thanks for the hint. That particular case is actually not that bad: > depends on DEBUG_UART_8250_SHIFT >= 2 The 2 is treated as the integer 2 (as long as there is no "config 2" floating around somewhere). So it is a relation between a symbol of type int and a constant integer. Getting this right in general in propositional logic will require some work, but it is feasible: From a propositional point of view, DEBUG_UART_8250_SHIFT >= 2 is either true or false, and if somewhere else it says DEBUG_UART_8250_SHIFT <= 1 then the two propositions exclude each other. Both are simple propositions that can be added to a formula and their exclusiveness is easy to encode. No matter how many "less than" or "greater than" relations there are with DEBUG_UART_8250_SHIFT and constant integer values: is it not too hard to add implications accordingly. However, if the relation is used with two (not constant) symbols of type int, things become hard due to the transitivity. Imagine something like this > ... > depends on A >= B > ... > depends on B >= C > ... > depends on C > A > ... > depends on B = 1 > ... > depends on C = 1 > ... It is possible to define a propositional variable for each of these propositions. But now if B = 1 and C = 1 hold true, then B >= C is also true and A >= B may be true. But if A >= B is true, then C > A is not. If vice versa A >= B is false then C > A must be true. (Of course still provided that B = 1 and C = 1.) Next, there is the case that B = 1 is true and C = 1 is false and the resulting implications and the same with B = 1 false and C = 1 true and with both of them false. And it probably needs even more constraints to get the first three propositions consistent in general. Yes, it is possible to get this right in propositional logic, but it is really cumbersome and lots of new code will be necessary. Regards, Martin Walch [1] https://www4.cs.fau.de/Research/VAMOS/ -- ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2015-07-05 9:24 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2015-06-15 11:59 [PATCH 0/2] kconfig: allow use of relations other than (in)equality Jan Beulich 2015-06-15 11:59 ` Jan Beulich 2015-06-15 12:18 ` Michal Marek 2015-07-02 13:04 ` Martin Walch 2015-07-02 20:06 ` Michal Marek 2015-07-03 9:18 ` Paul Bolle 2015-07-04 15:47 ` Martin Walch
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.