/* * Copyright (C) 1996-2015 The Squid Software Foundation and contributors * * Squid software is distributed under GPLv2+ license and includes * contributions from numerous individuals and organizations. * Please see the COPYING and CONTRIBUTORS files for details. */ /* DEBUG: section 54 Interprocess Communication */ #include "squid.h" #include "base/TextException.h" #include "globals.h" #include "ipc/Kids.h" #include "SquidConfig.h" #include "tools.h" Kids TheKids; KidName TheKidName; Kids::Kids() { } /// maintain n kids void Kids::init() { storage.clear(); storage.reserve(NumberOfKids()); char kid_name[32]; // add Kid records for all workers for (int i = 0; i < Config.workers; ++i) { snprintf(kid_name, sizeof(kid_name), "(squid-%d)", (int)(storage.size()+1)); storage.push_back(Kid(kid_name)); } // add Kid records for all disk processes for (int i = 0; i < Config.cacheSwap.n_strands; ++i) { snprintf(kid_name, sizeof(kid_name), "(squid-disk-%d)", (int)(storage.size()+1)); storage.push_back(Kid(kid_name)); } // if coordination is needed, add a Kid record for Coordinator if (storage.size() > 1) { snprintf(kid_name, sizeof(kid_name), "(squid-coord-%d)", (int)(storage.size()+1)); storage.push_back(Kid(kid_name)); } Must(storage.size() == static_cast(NumberOfKids())); } /// returns kid by pid Kid* Kids::find(pid_t pid) { assert(pid > 0); assert(count() > 0); for (size_t i = 0; i < storage.size(); ++i) { if (storage[i].getPid() == pid) return &storage[i]; } return NULL; } /// returns the kid by index, useful for kids iteration Kid& Kids::get(size_t i) { assert(i < count()); return storage[i]; } /// whether all kids are hopeless bool Kids::allHopeless() const { for (size_t i = 0; i < storage.size(); ++i) { if (!storage[i].hopeless()) return false; } return true; } /// whether all kids called exited happy bool Kids::allExitedHappy() const { for (size_t i = 0; i < storage.size(); ++i) { if (!storage[i].exitedHappy()) return false; } return true; } /// whether some kids died from a given signal bool Kids::someSignaled(const int sgnl) const { for (size_t i = 0; i < storage.size(); ++i) { if (storage[i].signaled(sgnl)) return true; } return false; } /// whether some kids are running bool Kids::someRunning() const { for (size_t i = 0; i < storage.size(); ++i) { if (storage[i].running()) return true; } return false; } /// whether some kids should be restarted by master bool Kids::shouldRestartSome() const { for (size_t i = 0; i < storage.size(); ++i) { if (storage[i].shouldRestart()) return true; } return false; } /// returns the number of kids size_t Kids::count() const { return storage.size(); }