Commit 2a130b7e authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'kbuild-fixes-v6.12' of...

Merge tag 'kbuild-fixes-v6.12' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild

Pull Kbuild fixes from Masahiro Yamada:

 - Move non-boot built-in DTBs to the .rodata section

 - Fix Kconfig bugs

 - Fix maint scripts in the linux-image Debian package

 - Import some list macros to scripts/include/

* tag 'kbuild-fixes-v6.12' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild:
  kbuild: deb-pkg: Remove blank first line from maint scripts
  kbuild: fix a typo dt_binding_schema -> dt_binding_schemas
  scripts: import more list macros
  kconfig: qconf: fix buffer overflow in debug links
  kconfig: qconf: move conf_read() before drawing tree pain
  kconfig: clear expr::val_is_valid when allocated
  kconfig: fix infinite loop in sym_calc_choice()
  kbuild: move non-boot built-in DTBs to .rodata section
parents c8d9f2c7 82cb4430
...@@ -1645,7 +1645,7 @@ help: ...@@ -1645,7 +1645,7 @@ help:
echo '* dtbs - Build device tree blobs for enabled boards'; \ echo '* dtbs - Build device tree blobs for enabled boards'; \
echo ' dtbs_install - Install dtbs to $(INSTALL_DTBS_PATH)'; \ echo ' dtbs_install - Install dtbs to $(INSTALL_DTBS_PATH)'; \
echo ' dt_binding_check - Validate device tree binding documents and examples'; \ echo ' dt_binding_check - Validate device tree binding documents and examples'; \
echo ' dt_binding_schema - Build processed device tree binding schemas'; \ echo ' dt_binding_schemas - Build processed device tree binding schemas'; \
echo ' dtbs_check - Validate device tree source files';\ echo ' dtbs_check - Validate device tree source files';\
echo '') echo '')
......
...@@ -34,12 +34,14 @@ $(obj)/dtbs-list: $(dtb-y) FORCE ...@@ -34,12 +34,14 @@ $(obj)/dtbs-list: $(dtb-y) FORCE
# Assembly file to wrap dtb(o) # Assembly file to wrap dtb(o)
# --------------------------------------------------------------------------- # ---------------------------------------------------------------------------
builtin-dtb-section = $(if $(filter arch/$(SRCARCH)/boot/dts%, $(obj)),.dtb.init.rodata,.rodata)
# Generate an assembly file to wrap the output of the device tree compiler # Generate an assembly file to wrap the output of the device tree compiler
quiet_cmd_wrap_S_dtb = WRAP $@ quiet_cmd_wrap_S_dtb = WRAP $@
cmd_wrap_S_dtb = { \ cmd_wrap_S_dtb = { \
symbase=__$(patsubst .%,%,$(suffix $<))_$(subst -,_,$(notdir $*)); \ symbase=__$(patsubst .%,%,$(suffix $<))_$(subst -,_,$(notdir $*)); \
echo '\#include <asm-generic/vmlinux.lds.h>'; \ echo '\#include <asm-generic/vmlinux.lds.h>'; \
echo '.section .dtb.init.rodata,"a"'; \ echo '.section $(builtin-dtb-section),"a"'; \
echo '.balign STRUCT_ALIGNMENT'; \ echo '.balign STRUCT_ALIGNMENT'; \
echo ".global $${symbase}_begin"; \ echo ".global $${symbase}_begin"; \
echo "$${symbase}_begin:"; \ echo "$${symbase}_begin:"; \
......
...@@ -127,6 +127,36 @@ static inline void list_del(struct list_head *entry) ...@@ -127,6 +127,36 @@ static inline void list_del(struct list_head *entry)
entry->prev = LIST_POISON2; entry->prev = LIST_POISON2;
} }
/**
* list_replace - replace old entry by new one
* @old : the element to be replaced
* @new : the new element to insert
*
* If @old was empty, it will be overwritten.
*/
static inline void list_replace(struct list_head *old,
struct list_head *new)
{
new->next = old->next;
new->next->prev = new;
new->prev = old->prev;
new->prev->next = new;
}
/**
* list_replace_init - replace old entry by new one and initialize the old one
* @old : the element to be replaced
* @new : the new element to insert
*
* If @old was empty, it will be overwritten.
*/
static inline void list_replace_init(struct list_head *old,
struct list_head *new)
{
list_replace(old, new);
INIT_LIST_HEAD(old);
}
/** /**
* list_move - delete from one list and add as another's head * list_move - delete from one list and add as another's head
* @list: the entry to move * @list: the entry to move
...@@ -150,6 +180,26 @@ static inline void list_move_tail(struct list_head *list, ...@@ -150,6 +180,26 @@ static inline void list_move_tail(struct list_head *list,
list_add_tail(list, head); list_add_tail(list, head);
} }
/**
* list_is_first -- tests whether @list is the first entry in list @head
* @list: the entry to test
* @head: the head of the list
*/
static inline int list_is_first(const struct list_head *list, const struct list_head *head)
{
return list->prev == head;
}
/**
* list_is_last - tests whether @list is the last entry in list @head
* @list: the entry to test
* @head: the head of the list
*/
static inline int list_is_last(const struct list_head *list, const struct list_head *head)
{
return list->next == head;
}
/** /**
* list_is_head - tests whether @list is the list @head * list_is_head - tests whether @list is the list @head
* @list: the entry to test * @list: the entry to test
......
...@@ -47,6 +47,7 @@ static struct expr *expr_lookup(enum expr_type type, void *l, void *r) ...@@ -47,6 +47,7 @@ static struct expr *expr_lookup(enum expr_type type, void *l, void *r)
e->type = type; e->type = type;
e->left._initdata = l; e->left._initdata = l;
e->right._initdata = r; e->right._initdata = r;
e->val_is_valid = false;
hash_add(expr_hashtable, &e->node, hash); hash_add(expr_hashtable, &e->node, hash);
......
...@@ -159,6 +159,12 @@ config_stmt: config_entry_start config_option_list ...@@ -159,6 +159,12 @@ config_stmt: config_entry_start config_option_list
yynerrs++; yynerrs++;
} }
/*
* If the same symbol appears twice in a choice block, the list
* node would be added twice, leading to a broken linked list.
* list_empty() ensures that this symbol has not yet added.
*/
if (list_empty(&current_entry->sym->choice_link))
list_add_tail(&current_entry->sym->choice_link, list_add_tail(&current_entry->sym->choice_link,
&current_choice->choice_members); &current_choice->choice_members);
} }
......
...@@ -1166,7 +1166,7 @@ void ConfigInfoView::clicked(const QUrl &url) ...@@ -1166,7 +1166,7 @@ void ConfigInfoView::clicked(const QUrl &url)
{ {
QByteArray str = url.toEncoded(); QByteArray str = url.toEncoded();
const std::size_t count = str.size(); const std::size_t count = str.size();
char *data = new char[count + 1]; char *data = new char[count + 2]; // '$' + '\0'
struct symbol **result; struct symbol **result;
struct menu *m = NULL; struct menu *m = NULL;
...@@ -1505,6 +1505,8 @@ ConfigMainWindow::ConfigMainWindow(void) ...@@ -1505,6 +1505,8 @@ ConfigMainWindow::ConfigMainWindow(void)
connect(helpText, &ConfigInfoView::menuSelected, connect(helpText, &ConfigInfoView::menuSelected,
this, &ConfigMainWindow::setMenuLink); this, &ConfigMainWindow::setMenuLink);
conf_read(NULL);
QString listMode = configSettings->value("/listMode", "symbol").toString(); QString listMode = configSettings->value("/listMode", "symbol").toString();
if (listMode == "single") if (listMode == "single")
showSingleView(); showSingleView();
...@@ -1906,8 +1908,6 @@ int main(int ac, char** av) ...@@ -1906,8 +1908,6 @@ int main(int ac, char** av)
configApp->connect(configApp, SIGNAL(lastWindowClosed()), SLOT(quit())); configApp->connect(configApp, SIGNAL(lastWindowClosed()), SLOT(quit()));
configApp->connect(configApp, SIGNAL(aboutToQuit()), v, SLOT(saveSettings())); configApp->connect(configApp, SIGNAL(aboutToQuit()), v, SLOT(saveSettings()));
conf_read(NULL);
v->show(); v->show();
configApp->exec(); configApp->exec();
......
...@@ -74,7 +74,6 @@ install_linux_image () { ...@@ -74,7 +74,6 @@ install_linux_image () {
mkdir -p "${pdir}/DEBIAN" mkdir -p "${pdir}/DEBIAN"
cat <<-EOF > "${pdir}/DEBIAN/${script}" cat <<-EOF > "${pdir}/DEBIAN/${script}"
#!/bin/sh #!/bin/sh
set -e set -e
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment