~ubuntu-branches/ubuntu/vivid/slurm-llnl/vivid

« back to all changes in this revision

Viewing changes to src/common/slurm_priority.h

  • Committer: Bazaar Package Importer
  • Author(s): Gennaro Oliva
  • Date: 2009-09-24 23:28:15 UTC
  • mfrom: (1.1.11 upstream) (3.2.4 sid)
  • Revision ID: james.westby@ubuntu.com-20090924232815-enh65jn32q1ebg07
Tags: 2.0.5-1
* New upstream release 
* Changed dependecy from lib-mysqlclient15 to lib-mysqlclient 
* Added Default-Start for runlevel 2 and 4 and $remote_fs requirement in
  init.d scripts (Closes: #541252)
* Postinst checks for wrong runlevels 2 and 4 links
* Upgraded to standard version 3.8.3
* Add lintian overrides for missing slurm-llnl-configurator.html in doc
  base registration
* modified postrm scripts to ignore pkill return value in order to avoid
  postrm failure when no slurm process is running
* Checking for slurmctld.pid before cancelling running and pending
  jobs during package removal 

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*****************************************************************************\
 
2
 *  slurm_priority.h - Define priority plugin functions
 
3
 *****************************************************************************
 
4
 *  Copyright (C) 2008 Lawrence Livermore National Security.
 
5
 *  Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER).
 
6
 *  Written by Danny Auble <da@llnl.gov>
 
7
 *  CODE-OCEC-09-009. All rights reserved.
 
8
 *  
 
9
 *  This file is part of SLURM, a resource management program.
 
10
 *  For details, see <https://computing.llnl.gov/linux/slurm/>.
 
11
 *  Please also read the included file: DISCLAIMER.
 
12
 *  
 
13
 *  SLURM is free software; you can redistribute it and/or modify it under
 
14
 *  the terms of the GNU General Public License as published by the Free
 
15
 *  Software Foundation; either version 2 of the License, or (at your option)
 
16
 *  any later version.
 
17
 *
 
18
 *  In addition, as a special exception, the copyright holders give permission 
 
19
 *  to link the code of portions of this program with the OpenSSL library under 
 
20
 *  certain conditions as described in each individual source file, and 
 
21
 *  distribute linked combinations including the two. You must obey the GNU 
 
22
 *  General Public License in all respects for all of the code used other than 
 
23
 *  OpenSSL. If you modify file(s) with this exception, you may extend this 
 
24
 *  exception to your version of the file(s), but you are not obligated to do 
 
25
 *  so. If you do not wish to do so, delete this exception statement from your
 
26
 *  version.  If you delete this exception statement from all source files in 
 
27
 *  the program, then also delete it here.
 
28
 *  
 
29
 *  SLURM is distributed in the hope that it will be useful, but WITHOUT ANY
 
30
 *  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 
31
 *  FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 
32
 *  details.
 
33
 *  
 
34
 *  You should have received a copy of the GNU General Public License along
 
35
 *  with SLURM; if not, write to the Free Software Foundation, Inc.,
 
36
 *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301  USA.
 
37
\*****************************************************************************/
 
38
 
 
39
#ifndef _SLURM_PRIORITY_H 
 
40
#define _SLURM_PRIORITY_H
 
41
 
 
42
#if HAVE_CONFIG_H
 
43
#  include "config.h"
 
44
#endif
 
45
#if HAVE_STDINT_H
 
46
#  include <stdint.h>           /* for uint16_t, uint32_t definitions */
 
47
#endif
 
48
#if HAVE_INTTYPES_H
 
49
#  include <inttypes.h>         /* for uint16_t, uint32_t definitions */
 
50
#endif
 
51
 
 
52
#include "src/slurmctld/slurmctld.h"
 
53
#include "src/common/slurm_accounting_storage.h"
 
54
 
 
55
extern int slurm_priority_init(void);
 
56
extern int slurm_priority_fini(void);
 
57
extern uint32_t priority_g_set(uint32_t last_prio, struct job_record *job_ptr);
 
58
extern void priority_g_reconfig();
 
59
/*
 
60
 * set up how much usage can happen on the cluster during a given half
 
61
 * life.  This can only be done after we get a correct proc count for
 
62
 * the system.
 
63
 * IN: procs - number of proccessors on the system
 
64
 * IN: half_life - time half_life is in seconds.
 
65
 * RET: SLURM_SUCCESS on SUCCESS, SLURM_ERROR else.
 
66
 */
 
67
extern int priority_g_set_max_cluster_usage(uint32_t procs, uint32_t half_life);
 
68
 
 
69
/* sets up the normalized usage and the effective usage of an
 
70
 * association.
 
71
 * IN/OUT: assoc - association to have usage set.
 
72
 */
 
73
extern void priority_g_set_assoc_usage(acct_association_rec_t *assoc);
 
74
extern List priority_g_get_priority_factors_list(
 
75
        priority_factors_request_msg_t *req_msg);
 
76
 
 
77
#endif /*_SLURM_PRIORIY_H */