~ubuntu-branches/ubuntu/saucy/lvm2/saucy

« back to all changes in this revision

Viewing changes to daemons/cmirrord/local.c

  • Committer: Package Import Robot
  • Author(s): Dmitrijs Ledkovs
  • Date: 2013-05-30 11:02:10 UTC
  • mfrom: (3.1.28 sid)
  • Revision ID: package-import@ubuntu.com-20130530110210-q8bou4f333ruwhn0
Tags: 2.02.98-1ubuntu1
* Merge from Debian unstable, remaining changes:
  - debian/patches/avoid-dev-block.patch: Prefer any other device name over
    names in /dev/block/ since lvm.conf won't handle this.
  - debian/rules:
    - copy .po file to .pot file for Rosetta (Ubuntu specific).
  - debian/{dmsetup,lvm2}-udeb.install:
    - install initramfs and udev hooks in udebs (Debian bug 504341).
  - auto-start VGs as their PVs are discovered (Ubuntu specific):
    - add debian/tree/lvm2/lib/udev/rules.d/85-lvm2.rules: use watershed plus
      the sledgehammer of vgscan/vgchange to turn on VGs as they come online.
    - debian/tree/lvm2/usr/share/initramfs-tools/scripts/hooks/lvm2:
      - add 85-lvm2.rules to the list of udev rules to copy.
      - depend on udev.
    - debian/control:
      - add versioned Depend on watershed in lvm2 for udev rules.
      - add Depends on watershed-udeb in lvm2-udeb for udev rules.
      - add versioned Depend/Breaks on udev in dmsetup for udev rules.
      - add Depend on initramfs-tools in dmsetup so system is not potentially
        rendered unbootable by out-of-order dpkg configuration.
      - In libdevmapper-event1.02.1 add Breaks: dmeventd
        (<< 2.02.95-4ubuntu1) due to debian symbol rename
    - debian/rules:
      - do not install local-top scripts since Ubuntu mounts root using udev.
      - do not install init scripts for lvm2, since udev starts LVM.
      - continue to build clvm support.
    - debian/lvm2.postinst: handle missing lvm2 init script.
    - debian/tree/dmsetup/lib/udev/rules.d/60-persistent-storage-dm.rules:
      watch dm devices for changes with inotify
  - add mountroot failure hooks to help fix bad boots (Debian bug 468115):
    - debian/tree/lvm2/usr/share/initramfs-tools/scripts/init-premount/lvm2
  - remaining changes to upstream event manager packages (Debian bug 514706):
    - debian/rules:
      - enable dmeventd during configure.
    - debian/dmeventd.{8,manpages}: install dmeventd files.
  - rename debian/clvm.defaults to debian/clvm.default so it is installed
    correctly.
  - debian/control: add dmsetup-udeb to libdevmapper1.02.1-udeb recommends.
  - debian/rules: make sure dmsetup and lvm2 initramfs-tools scripts are
    executable.  When the Ubuntu-specific ones are added with a patch,
    they may lose their executable bit.
  - Add and install clvmd resource agent
  - Add dependency on libudev-dev to libdevmapper-dev so that the .pc file
    works.
  - debian/{clvmd.ra,clvm.init}:
    - create /run/lvm if it doesn't exist.
  - debian/clvm.init:
    - exit 3 if not running on status action.
  - Call dh_installman so that our dmeventd manpage actually gets installed
  - Install the missing fsadm manpage.
  - Complete libdevmapper-dev multiarch:
    - move .so symlinks and pkgconfig files to multiarched locations.
    - mark libdevmapper-dev M-A: same

* Dropped changes, applied upstream:
  - Update Micron PCIe SSD and other device-types to latest available.
  - Cherry pick from upstream, remove unsupported udev_get_dev_path() call.
  - Move thin check to global section.

Show diffs side-by-side

added added

removed removed

Lines of Context:
27
27
#define CN_VAL_DM_USERSPACE_LOG         0x1
28
28
#endif
29
29
 
30
 
static int cn_fd;  /* Connector (netlink) socket fd */
 
30
static int cn_fd = -1;  /* Connector (netlink) socket fd */
31
31
static char recv_buf[2048];
32
32
static char send_buf[2048];
33
33
 
237
237
        case DM_ULOG_GET_REGION_SIZE:
238
238
        case DM_ULOG_IN_SYNC:
239
239
        case DM_ULOG_GET_SYNC_COUNT:
240
 
        case DM_ULOG_STATUS_INFO:
241
240
        case DM_ULOG_STATUS_TABLE:
242
241
        case DM_ULOG_PRESUSPEND:
243
242
                /* We do not specify ourselves as server here */
249
248
                if (r)
250
249
                        LOG_ERROR("Failed to respond to kernel [%s]",
251
250
                                  RQ_TYPE(u_rq->request_type));
252
 
                        
 
251
 
253
252
                break;
254
253
        case DM_ULOG_RESUME:
255
254
                /*
273
272
        case DM_ULOG_MARK_REGION:
274
273
        case DM_ULOG_GET_RESYNC_WORK:
275
274
        case DM_ULOG_SET_REGION_SYNC:
 
275
        case DM_ULOG_STATUS_INFO:
276
276
        case DM_ULOG_IS_REMOTE_RECOVERING:
277
277
        case DM_ULOG_POSTSUSPEND:
278
278
                r = cluster_send(rq);
279
279
                if (r) {
280
280
                        u_rq->data_size = 0;
281
281
                        u_rq->error = r;
282
 
                        kernel_send(u_rq);
 
282
                        if (kernel_send(u_rq))
 
283
                                LOG_ERROR("Failed to respond to kernel [%s]",
 
284
                                          RQ_TYPE(u_rq->request_type));
283
285
                }
284
286
 
285
287
                break;
384
386
 
385
387
        r = bind(cn_fd, (struct sockaddr *) &addr, sizeof(addr));
386
388
        if (r < 0) {
387
 
                close(cn_fd);
 
389
                if (close(cn_fd))
 
390
                        LOG_ERROR("Failed to close socket: %s",
 
391
                                  strerror(errno));
388
392
                return EXIT_KERNEL_BIND;
389
393
        }
390
394
 
391
395
        opt = addr.nl_groups;
392
396
        r = setsockopt(cn_fd, 270, NETLINK_ADD_MEMBERSHIP, &opt, sizeof(opt));
393
397
        if (r) {
394
 
                close(cn_fd);
 
398
                if (close(cn_fd))
 
399
                        LOG_ERROR("Failed to close socket: %s",
 
400
                                  strerror(errno));
395
401
                return EXIT_KERNEL_SETSOCKOPT;
396
402
        }
397
403
 
412
418
void cleanup_local(void)
413
419
{
414
420
        links_unregister(cn_fd);
415
 
        close(cn_fd);
 
421
        if (cn_fd >= 0 && close(cn_fd))
 
422
                LOG_ERROR("Failed to close socket: %s",
 
423
                          strerror(errno));
416
424
}