The Samba-Bugzilla – Attachment 6474 Details for
Bug 7836
A newly added printer isn't visbile to clients
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
[patch]
3-5-test.patch
v3-5-test.patch (text/plain), 12.67 KB, created by
Guenther Deschner
on 2011-05-23 13:06:56 UTC
(
hide
)
Description:
3-5-test.patch
Filename:
MIME Type:
Creator:
Guenther Deschner
Created:
2011-05-23 13:06:56 UTC
Size:
12.67 KB
patch
obsolete
>From 262d96a61425755d1a80ba3daf5782fb7ed6c5ce Mon Sep 17 00:00:00 2001 >From: David Disseldorp <ddiss@suse.de> >Date: Thu, 19 May 2011 11:22:18 +0200 >Subject: [PATCH 1/3] Revert "Revert "s3-printing: reload shares after pcap > cache fill"" >MIME-Version: 1.0 >Content-Type: text/plain; charset=UTF-8 >Content-Transfer-Encoding: 8bit > >This reverts commit e4579eab7fe3eab7a5209e6de74e6fd2f53099d0. > >Signed-off-by: Günther Deschner <gd@samba.org> >--- > source3/include/proto.h | 4 ++-- > source3/printing/load.c | 5 ++--- > source3/printing/pcap.c | 18 ++++++++++++++---- > source3/printing/print_cups.c | 33 ++++++++++++++++++++++++--------- > source3/smbd/server.c | 12 ++++++------ > source3/web/swat.c | 4 ++-- > 6 files changed, 50 insertions(+), 26 deletions(-) > >diff --git a/source3/include/proto.h b/source3/include/proto.h >index e15a020..d560ee5 100644 >--- a/source3/include/proto.h >+++ b/source3/include/proto.h >@@ -4899,7 +4899,7 @@ void pcap_cache_destroy_specific(struct pcap_cache **ppcache); > bool pcap_cache_add(const char *name, const char *comment); > bool pcap_cache_loaded(void); > void pcap_cache_replace(const struct pcap_cache *cache); >-void pcap_cache_reload(void); >+void pcap_cache_reload(void (*post_cache_fill_fn)(void)); > bool pcap_printername_ok(const char *printername); > void pcap_printer_fn_specific(const struct pcap_cache *, void (*fn)(const char *, const char *, void *), void *); > void pcap_printer_fn(void (*fn)(const char *, const char *, void *), void *); >@@ -4910,7 +4910,7 @@ bool aix_cache_reload(void); > > /* The following definitions come from printing/print_cups.c */ > >-bool cups_cache_reload(void); >+bool cups_cache_reload(void (*post_cache_fill_fn)(void)); > bool cups_pull_comment_location(NT_PRINTER_INFO_LEVEL_2 *printer); > > /* The following definitions come from printing/print_generic.c */ >diff --git a/source3/printing/load.c b/source3/printing/load.c >index 874f7f2..00da9cb 100644 >--- a/source3/printing/load.c >+++ b/source3/printing/load.c >@@ -53,12 +53,11 @@ static void add_auto_printers(void) > } > > /*************************************************************************** >-load automatic printer services >+load automatic printer services from pre-populated pcap cache > ***************************************************************************/ > void load_printers(void) > { >- if (!pcap_cache_loaded()) >- pcap_cache_reload(); >+ SMB_ASSERT(pcap_cache_loaded()); > > add_auto_printers(); > >diff --git a/source3/printing/pcap.c b/source3/printing/pcap.c >index a6bf52a..0d6480c 100644 >--- a/source3/printing/pcap.c >+++ b/source3/printing/pcap.c >@@ -125,13 +125,14 @@ void pcap_cache_replace(const struct pcap_cache *pcache) > } > } > >-void pcap_cache_reload(void) >+void pcap_cache_reload(void (*post_cache_fill_fn)(void)) > { > const char *pcap_name = lp_printcapname(); > bool pcap_reloaded = False; > struct pcap_cache *tmp_cache = NULL; > XFILE *pcap_file; > char *pcap_line; >+ bool post_cache_fill_fn_handled = false; > > DEBUG(3, ("reloading printcap cache\n")); > >@@ -146,7 +147,12 @@ void pcap_cache_reload(void) > > #ifdef HAVE_CUPS > if (strequal(pcap_name, "cups")) { >- pcap_reloaded = cups_cache_reload(); >+ pcap_reloaded = cups_cache_reload(post_cache_fill_fn); >+ /* >+ * cups_cache_reload() is async and calls post_cache_fill_fn() >+ * on successful completion >+ */ >+ post_cache_fill_fn_handled = true; > goto done; > } > #endif >@@ -242,9 +248,13 @@ void pcap_cache_reload(void) > done: > DEBUG(3, ("reload status: %s\n", (pcap_reloaded) ? "ok" : "error")); > >- if (pcap_reloaded) >+ if (pcap_reloaded) { > pcap_cache_destroy_specific(&tmp_cache); >- else { >+ if ((post_cache_fill_fn_handled == false) >+ && (post_cache_fill_fn != NULL)) { >+ post_cache_fill_fn(); >+ } >+ } else { > pcap_cache_destroy_specific(&pcap_cache); > pcap_cache = tmp_cache; > } >diff --git a/source3/printing/print_cups.c b/source3/printing/print_cups.c >index 6e8cc12..49932e3 100644 >--- a/source3/printing/print_cups.c >+++ b/source3/printing/print_cups.c >@@ -445,13 +445,19 @@ static bool cups_pcap_load_async(int *pfd) > _exit(0); > } > >+struct cups_async_cb_args { >+ int pipe_fd; >+ void (*post_cache_fill_fn)(void); >+}; >+ > static void cups_async_callback(struct event_context *event_ctx, > struct fd_event *event, > uint16 flags, > void *p) > { > TALLOC_CTX *frame = talloc_stackframe(); >- int fd = *(int *)p; >+ struct cups_async_cb_args *cb_args = (struct cups_async_cb_args *)p; >+ int fd = cb_args->pipe_fd; > struct pcap_cache *tmp_pcap_cache = NULL; > > DEBUG(5,("cups_async_callback: callback received for printer data. " >@@ -545,27 +551,36 @@ static void cups_async_callback(struct event_context *event_ctx, > > /* And the systemwide pcap cache. */ > pcap_cache_replace(local_pcap_copy); >+ >+ /* Caller may have requested post cache fill callback */ >+ if (cb_args->post_cache_fill_fn) { >+ cb_args->post_cache_fill_fn(); >+ } > } else { > DEBUG(2,("cups_async_callback: failed to read a new " > "printer list\n")); > } > close(fd); >- TALLOC_FREE(p); >+ TALLOC_FREE(cb_args); > TALLOC_FREE(cache_fd_event); > } > >-bool cups_cache_reload(void) >+bool cups_cache_reload(void (*post_cache_fill_fn)(void)) > { >- int *p_pipe_fd = TALLOC_P(NULL, int); >+ struct cups_async_cb_args *cb_args; >+ int *p_pipe_fd; > >- if (!p_pipe_fd) { >+ cb_args = TALLOC_P(NULL, struct cups_async_cb_args); >+ if (!cb_args) { > return false; > } >- >+ cb_args->post_cache_fill_fn = post_cache_fill_fn; >+ p_pipe_fd = &cb_args->pipe_fd; > *p_pipe_fd = -1; > > /* Set up an async refresh. */ > if (!cups_pcap_load_async(p_pipe_fd)) { >+ talloc_free(cb_args); > return false; > } > if (!local_pcap_copy) { >@@ -578,7 +593,7 @@ bool cups_cache_reload(void) > cups_async_callback(smbd_event_context(), > NULL, > EVENT_FD_READ, >- (void *)p_pipe_fd); >+ (void *)cb_args); > if (!local_pcap_copy) { > return false; > } >@@ -595,10 +610,10 @@ bool cups_cache_reload(void) > NULL, *p_pipe_fd, > EVENT_FD_READ, > cups_async_callback, >- (void *)p_pipe_fd); >+ (void *)cb_args); > if (!cache_fd_event) { > close(*p_pipe_fd); >- TALLOC_FREE(p_pipe_fd); >+ talloc_free(cb_args); > return false; > } > } >diff --git a/source3/smbd/server.c b/source3/smbd/server.c >index 8c0fa80..94605f6 100644 >--- a/source3/smbd/server.c >+++ b/source3/smbd/server.c >@@ -741,9 +741,9 @@ static void smbd_parent_loop(struct smbd_parent_context *parent) > /* NOTREACHED return True; */ > } > >-/**************************************************************************** >- Reload printers >-**************************************************************************/ >+/*************************************************************************** >+ purge stale printers and reload from pre-populated pcap cache >+***************************************************************************/ > void reload_printers(void) > { > int snum; >@@ -751,9 +751,9 @@ void reload_printers(void) > int pnum = lp_servicenumber(PRINTERS_NAME); > const char *pname; > >- pcap_cache_reload(); >+ SMB_ASSERT(pcap_cache_loaded()); > >- /* remove stale printers */ >+ DEBUG(10, ("reloading printer services from pcap cache\n")); > for (snum = 0; snum < n_services; snum++) { > /* avoid removing PRINTERS_NAME or non-autoloaded printers */ > if (snum == pnum || !(lp_snum_ok(snum) && lp_print_ok(snum) && >@@ -800,7 +800,7 @@ bool reload_services(bool test) > > ret = lp_load(get_dyn_CONFIGFILE(), False, False, True, True); > >- reload_printers(); >+ pcap_cache_reload(&reload_printers); > > /* perhaps the config filename is now set */ > if (!test) >diff --git a/source3/web/swat.c b/source3/web/swat.c >index 230b161..baffa44 100644 >--- a/source3/web/swat.c >+++ b/source3/web/swat.c >@@ -490,7 +490,7 @@ static int save_reload(int snum) > return 0; > } > iNumNonAutoPrintServices = lp_numservices(); >- load_printers(); >+ pcap_cache_reload(&load_printers); > > return 1; > } >@@ -1434,7 +1434,7 @@ const char *lang_msg_rotate(TALLOC_CTX *ctx, const char *msgid) > load_config(True); > load_interfaces(); > iNumNonAutoPrintServices = lp_numservices(); >- load_printers(); >+ pcap_cache_reload(&load_printers); > > cgi_setup(get_dyn_SWATDIR(), !demo_mode); > >-- >1.7.4.4 > > >From 04454c5a6b5bcc7ddeaeb6b80b21d590bfab660f Mon Sep 17 00:00:00 2001 >From: David Disseldorp <ddiss@suse.de> >Date: Thu, 19 May 2011 11:22:37 +0200 >Subject: [PATCH 2/3] Revert "Revert "s3-printing: update parent smbd pcap > cache"" >MIME-Version: 1.0 >Content-Type: text/plain; charset=UTF-8 >Content-Transfer-Encoding: 8bit > >This reverts commit b6268f507fa3276c2ef22c58bad400a3fed48cd9. > >Signed-off-by: Günther Deschner <gd@samba.org> >--- > source3/include/local.h | 1 + > source3/smbd/process.c | 4 ++-- > source3/smbd/server.c | 16 ++++++++++++++++ > 3 files changed, 19 insertions(+), 2 deletions(-) > >diff --git a/source3/include/local.h b/source3/include/local.h >index a88b17b..d65cc00 100644 >--- a/source3/include/local.h >+++ b/source3/include/local.h >@@ -148,6 +148,7 @@ > #define LPQ_LOCK_TIMEOUT (5) > #define NMBD_INTERFACES_RELOAD (120) > #define NMBD_UNEXPECTED_TIMEOUT (15) >+#define SMBD_HOUSEKEEPING_INTERVAL SMBD_SELECT_TIMEOUT > > /* the following are in milliseconds */ > #define LOCK_RETRY_TIMEOUT (100) >diff --git a/source3/smbd/process.c b/source3/smbd/process.c >index 5292060..12cc467 100644 >--- a/source3/smbd/process.c >+++ b/source3/smbd/process.c >@@ -2083,7 +2083,7 @@ void check_reload(time_t t) > || (t-last_printer_reload_time < 0) ) > { > DEBUG( 3,( "Printcap cache time expired.\n")); >- reload_printers(); >+ pcap_cache_reload(&reload_printers); > last_printer_reload_time = t; > } > } >@@ -2369,7 +2369,7 @@ void smbd_process(void) > } > > if (!(event_add_idle(smbd_event_context(), NULL, >- timeval_set(SMBD_SELECT_TIMEOUT, 0), >+ timeval_set(SMBD_HOUSEKEEPING_INTERVAL, 0), > "housekeeping", housekeeping_fn, NULL))) { > DEBUG(0, ("Could not add housekeeping event\n")); > exit(1); >diff --git a/source3/smbd/server.c b/source3/smbd/server.c >index 94605f6..3401cb1 100644 >--- a/source3/smbd/server.c >+++ b/source3/smbd/server.c >@@ -541,6 +541,14 @@ static bool smbd_open_one_socket(struct smbd_parent_context *parent, > return true; > } > >+static bool parent_housekeeping_fn(const struct timeval *now, void *private_data) >+{ >+ DEBUG(5, ("houskeeping\n")); >+ /* check if we need to reload services */ >+ check_reload(time(NULL)); >+ return true; >+} >+ > /**************************************************************************** > Open the socket communication. > ****************************************************************************/ >@@ -675,6 +683,14 @@ static bool open_sockets_smbd(struct smbd_parent_context *parent, > claim_connection(NULL,"", > FLAG_MSG_GENERAL|FLAG_MSG_SMBD|FLAG_MSG_DBWRAP); > >+ if (!(event_add_idle(smbd_event_context(), NULL, >+ timeval_set(SMBD_HOUSEKEEPING_INTERVAL, 0), >+ "parent_housekeeping", parent_housekeeping_fn, >+ parent))) { >+ DEBUG(0, ("Could not add housekeeping event\n")); >+ exit(1); >+ } >+ > /* Listen to messages */ > > messaging_register(smbd_messaging_context(), NULL, >-- >1.7.4.4 > > >From 3e9a027637c7eac50d1bb6f1eabd5bc6846f0efc Mon Sep 17 00:00:00 2001 >From: David Disseldorp <ddiss@suse.de> >Date: Mon, 17 Jan 2011 16:09:32 +0100 >Subject: [PATCH 3/3] s3-printing: remove pcap_cache_loaded asserts >MIME-Version: 1.0 >Content-Type: text/plain; charset=UTF-8 >Content-Transfer-Encoding: 8bit > >pcap_cache_loaded() assertions were added to the (re)load_printers() >functions, to ensure the caller had called pcap_cache_reload() prior to >reloading printer shares. > >The problem is, pcap_cache_loaded() returns false if the the pcap_cache >contains no printer entries. i.e. pcap_cache_reload() has run but not >detected any printers. > >Remove these assertions, correct call ordering is already enforced. > >Signed-off-by: Günther Deschner <gd@samba.org> >--- > source3/printing/load.c | 2 -- > source3/smbd/server.c | 2 -- > 2 files changed, 0 insertions(+), 4 deletions(-) > >diff --git a/source3/printing/load.c b/source3/printing/load.c >index 00da9cb..c80a479 100644 >--- a/source3/printing/load.c >+++ b/source3/printing/load.c >@@ -57,8 +57,6 @@ load automatic printer services from pre-populated pcap cache > ***************************************************************************/ > void load_printers(void) > { >- SMB_ASSERT(pcap_cache_loaded()); >- > add_auto_printers(); > > /* load all printcap printers */ >diff --git a/source3/smbd/server.c b/source3/smbd/server.c >index 3401cb1..11040bc 100644 >--- a/source3/smbd/server.c >+++ b/source3/smbd/server.c >@@ -767,8 +767,6 @@ void reload_printers(void) > int pnum = lp_servicenumber(PRINTERS_NAME); > const char *pname; > >- SMB_ASSERT(pcap_cache_loaded()); >- > DEBUG(10, ("reloading printer services from pcap cache\n")); > for (snum = 0; snum < n_services; snum++) { > /* avoid removing PRINTERS_NAME or non-autoloaded printers */ >-- >1.7.4.4 >
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Raw
Flags:
asn
:
review+
gd
:
review+
Actions:
View
Attachments on
bug 7836
:
6104
|
6105
|
6106
|
6107
|
6112
|
6113
|
6114
|
6115
|
6116
|
6117
|
6154
|
6170
|
6186
|
6188
|
6190
|
6191
|
6208
|
6209
| 6474 |
6475